Commit ede41ee4 authored by Nick Thomas's avatar Nick Thomas

Simplify building and testing the Go components

parent ff46222a
.PHONY: validate verify verify_ruby verify_golang test test_ruby test_golang setup _install build compile check clean .PHONY: validate verify verify_ruby verify_golang test test_ruby test_golang setup _install build compile check clean
GO_SOURCES := $(shell find go -name '*.go') GO_SOURCES := $(shell find . -name '*.go')
validate: verify test validate: verify test
...@@ -10,7 +10,7 @@ verify_ruby: ...@@ -10,7 +10,7 @@ verify_ruby:
bundle exec rubocop bundle exec rubocop
verify_golang: verify_golang:
support/go-format check gofmt -s -l $(GO_SOURCES)
test: test_ruby test_golang test: test_ruby test_golang
...@@ -19,7 +19,7 @@ test_ruby: ...@@ -19,7 +19,7 @@ test_ruby:
bundle exec rspec --color --format d spec bundle exec rspec --color --format d spec
test_golang: test_golang:
support/go-test go test ./...
setup: _install bin/gitlab-shell setup: _install bin/gitlab-shell
...@@ -29,10 +29,10 @@ _install: ...@@ -29,10 +29,10 @@ _install:
build: bin/gitlab-shell build: bin/gitlab-shell
compile: bin/gitlab-shell compile: bin/gitlab-shell
bin/gitlab-shell: $(GO_SOURCES) bin/gitlab-shell: $(GO_SOURCES)
bin/compile GOBIN="$(CURDIR)/bin" go install ./cmd/...
check: check:
bin/check bin/check
clean: clean:
rm -f bin/gitlab-shell bin/gitlab-shell-authorized-keys-check bin/gitlab-shell-authorized-principals-check rm -f bin/check bin/gitlab-shell bin/gitlab-shell-authorized-keys-check bin/gitlab-shell-authorized-principals-check
#!/usr/bin/env ruby
require 'fileutils'
require_relative '../support/go_build'
include GoBuild
BUILD_BIN_GLOB = File.join(BUILD_DIR, 'bin', '*')
ROOT_BIN = File.join(ROOT_PATH, 'bin')
def main
ensure_build_dir_exists
run!(GO_ENV, %W[go install ./cmd/...], chdir: GO_DIR)
executables = Dir[BUILD_BIN_GLOB]
FileUtils.chmod(0755, executables)
FileUtils.cp(executables, ROOT_BIN)
end
main
#!/usr/bin/env ruby #!/usr/bin/env ruby
# Load ROOT_PATH and access the minimum necessary config file # Load ROOT_PATH and access the minimum necessary config file
require_relative '../support/go_build'
require_relative '../support/gitlab_config' require_relative '../support/gitlab_config'
config = GitlabConfig.new config = GitlabConfig.new
......
module gitlab.com/gitlab-org/gitlab-shell/go module gitlab.com/gitlab-org/gitlab-shell
go 1.12 go 1.12
require ( require (
github.com/mattn/go-shellwords v0.0.0-20190425161501-2444a32a19f4 github.com/mattn/go-shellwords v0.0.0-20190425161501-2444a32a19f4
github.com/otiai10/copy v1.0.1 github.com/otiai10/copy v1.0.1
github.com/otiai10/curr v0.0.0-20190513014714-f5a3d24e5776 // indirect
github.com/sirupsen/logrus v1.2.0 github.com/sirupsen/logrus v1.2.0
github.com/stretchr/testify v1.3.0 github.com/stretchr/testify v1.3.0
gitlab.com/gitlab-org/gitaly v1.68.0 gitlab.com/gitlab-org/gitaly v1.68.0
gitlab.com/gitlab-org/labkit v0.0.0-20190221122536-0c3fc7cdd57c gitlab.com/gitlab-org/labkit v0.0.0-20190221122536-0c3fc7cdd57c
google.golang.org/grpc v1.24.0 google.golang.org/grpc v1.24.0
gopkg.in/DataDog/dd-trace-go.v1 v1.9.0 // indirect
gopkg.in/yaml.v2 v2.2.2 gopkg.in/yaml.v2 v2.2.2
) )
require 'yaml' require 'yaml'
# Determine the root of the gitlab-shell directory
ROOT_PATH = ENV.fetch('GITLAB_SHELL_DIR', File.expand_path('..', __dir__))
class GitlabConfig class GitlabConfig
attr_reader :config attr_reader :config
......
#!/usr/bin/env ruby
def main(check)
go_files = Dir['go/**/*.go']
cmd = %w[gofmt -s -l]
cmd << '-w' unless check
cmd += go_files
output = IO.popen(cmd, 'r', &:read)
$stdout.write(output)
abort 'gofmt failed' unless $?.success?
if check && output.lines.any? { |l| l != "\n" }
abort "\nPlease run #{$0} to fix formatting"
end
end
main(ARGV.first == 'check')
#!/usr/bin/env ruby
require_relative 'go_build'
include GoBuild
def main
ensure_build_dir_exists
run!(GO_ENV, %w[go test ./...], chdir: GO_DIR)
puts 'OK'
end
main
# Helper functions to build go code in gitlab-shell
require 'fileutils'
# Determine the root of the gitlab-shell directory
ROOT_PATH = ENV.fetch('GITLAB_SHELL_DIR', File.expand_path('..', __dir__))
module GoBuild
GO_DIR = File.join(ROOT_PATH, 'go')
BUILD_DIR = File.join(ROOT_PATH, 'go_build')
GO_ENV = {
# $GOBIN controls where 'go install' puts binaries. Prior to go mod,
# this was $GOPATH/bin.
'GOBIN' => File.join(BUILD_DIR, 'bin'),
# Force the use of go mod, even if $GOPATH is set.
'GO111MODULE' => 'on',
# Downloading dependencies via proxy.golang.org is faster and more
# reliable than downloading from canonical sources. We need this
# environment variable because as of Go 1.12, the default is still to
# download from canonical sources.
'GOPROXY' => 'https://proxy.golang.org'
}.freeze
def ensure_build_dir_exists
FileUtils.mkdir_p(BUILD_DIR)
end
def run!(env, cmd, options = {})
raise "env must be a hash" unless env.is_a?(Hash)
raise "cmd must be an array" unless cmd.is_a?(Array)
unless system(env, *cmd, options)
abort "command failed: #{env.inspect} #{cmd.join(' ')}"
end
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment