From 2999e15ae6528d987581967c2c573c5b9a785859 Mon Sep 17 00:00:00 2001 From: Simone Basso Date: Thu, 1 Feb 2024 18:45:38 +0100 Subject: [PATCH 1/6] feat(buildtool): fetch and use correct go version --- .github/workflows/goversion.yml | 28 +++++++++ internal/cmd/buildtool/android.go | 4 +- internal/cmd/buildtool/android_test.go | 4 +- internal/cmd/buildtool/builddeps.go | 6 +- internal/cmd/buildtool/darwin.go | 3 +- internal/cmd/buildtool/darwin_test.go | 2 +- internal/cmd/buildtool/generic.go | 8 +-- internal/cmd/buildtool/generic_test.go | 6 +- internal/cmd/buildtool/golang.go | 60 +++++++++++++++++-- internal/cmd/buildtool/golang_test.go | 10 ++-- internal/cmd/buildtool/gomobile.go | 6 +- .../internal/buildtoolmodel/buildtoolmodel.go | 5 +- .../internal/buildtooltest/buildtooltest.go | 7 ++- .../buildtooltest/buildtooltest_test.go | 7 ++- internal/cmd/buildtool/ios.go | 1 - internal/cmd/buildtool/ios_test.go | 2 +- internal/cmd/buildtool/linuxstatic.go | 3 +- internal/cmd/buildtool/linuxstatic_test.go | 2 +- internal/cmd/buildtool/oohelperd.go | 4 +- internal/cmd/buildtool/oohelperd_test.go | 2 +- internal/cmd/buildtool/windows.go | 3 +- internal/cmd/buildtool/windows_test.go | 2 +- 22 files changed, 125 insertions(+), 50 deletions(-) create mode 100644 .github/workflows/goversion.yml diff --git a/.github/workflows/goversion.yml b/.github/workflows/goversion.yml new file mode 100644 index 0000000000..9e82ba24b7 --- /dev/null +++ b/.github/workflows/goversion.yml @@ -0,0 +1,28 @@ +# Ensures that ./internal/cmd/buildtool works with different go versions + +name: goversion +on: + push: + branches: + - "release/**" + - "fullbuild" + tags: + - "v*" + schedule: + - cron: "17 7 * * *" + +jobs: + build_with_unexpected_go_version: + strategy: + matrix: + goversion: ["1.17", "1.18", "1.19", "1.21"] + system: [ubuntu-latest, windows-latest, macos-latest] + runs-on: "${{ matrix.system }}" + steps: + - uses: actions/checkout@v3 + + - uses: actions/setup-go@v4 + with: + go-version: "${{ matrix.goversion }}" + + - run: go run ./internal/cmd/buildtool generic miniooni diff --git a/internal/cmd/buildtool/android.go b/internal/cmd/buildtool/android.go index 174aa6d7a4..d0b9cb4d74 100644 --- a/internal/cmd/buildtool/android.go +++ b/internal/cmd/buildtool/android.go @@ -78,7 +78,6 @@ func androidSubcommand() *cobra.Command { // androidBuildGomobile invokes the gomobile build. func androidBuildGomobile(deps buildtoolmodel.Dependencies) { deps.PsiphonMaybeCopyConfigFiles() - deps.GolangCheck() androidHome := deps.AndroidSDKCheck() ndkDir := deps.AndroidNDKCheck(androidHome) @@ -146,7 +145,6 @@ func androidNDKCheck(androidHome string) string { // androidBuildCLIAll builds all products in CLI mode for Android func androidBuildCLIAll(deps buildtoolmodel.Dependencies) { deps.PsiphonMaybeCopyConfigFiles() - deps.GolangCheck() androidHome := deps.AndroidSDKCheck() ndkDir := deps.AndroidNDKCheck(androidHome) @@ -177,7 +175,7 @@ func androidBuildCLIProductArch( log.Infof("building %s for android/%s", product.Pkg, ooniArch) - argv := runtimex.Try1(shellx.NewArgv("go", "build")) + argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) if deps.PsiphonFilesExist() { argv.Append("-tags", "ooni_psiphon_config,ooni_libtor") } else { diff --git a/internal/cmd/buildtool/android_test.go b/internal/cmd/buildtool/android_test.go index a053bf3d8f..69ce3cbb1a 100644 --- a/internal/cmd/buildtool/android_test.go +++ b/internal/cmd/buildtool/android_test.go @@ -121,7 +121,7 @@ func TestAndroidBuildGomobile(t *testing.T) { buildtooltest.TagGOPATH: 2, buildtooltest.TagAndroidNDKCheck: 1, buildtooltest.TagAndroidSDKCheck: 1, - buildtooltest.TagGolangCheck: 1, + buildtooltest.TagGolangBinary: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 1, } @@ -406,7 +406,7 @@ func TestAndroidBuildCLIAll(t *testing.T) { expectCalls := map[string]int{ buildtooltest.TagAndroidNDKCheck: 1, buildtooltest.TagAndroidSDKCheck: 1, - buildtooltest.TagGolangCheck: 1, + buildtooltest.TagGolangBinary: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 8, } diff --git a/internal/cmd/buildtool/builddeps.go b/internal/cmd/buildtool/builddeps.go index cc4bececfb..f7dfb4a9cd 100644 --- a/internal/cmd/buildtool/builddeps.go +++ b/internal/cmd/buildtool/builddeps.go @@ -38,9 +38,9 @@ func (*buildDeps) GOPATH() string { return golangGOPATH() } -// GolangCheck implements buildtoolmodel.Dependencies -func (*buildDeps) GolangCheck() { - golangCheck("GOVERSION") +// GolangBinary implements buildtoolmodel.Dependencies +func (*buildDeps) GolangBinary() string { + return golangBinary() } // LinuxReadGOVERSION implements buildtoolmodel.Dependencies diff --git a/internal/cmd/buildtool/darwin.go b/internal/cmd/buildtool/darwin.go index e9dfd4a4a3..fa8af860bb 100644 --- a/internal/cmd/buildtool/darwin.go +++ b/internal/cmd/buildtool/darwin.go @@ -27,7 +27,6 @@ func darwinSubcommand() *cobra.Command { // darwinBuildAll builds all the packages for darwin. func darwinBuildAll(deps buildtoolmodel.Dependencies) { deps.PsiphonMaybeCopyConfigFiles() - deps.GolangCheck() archs := []string{"amd64", "arm64"} products := []*product{productMiniooni, productOoniprobe} for _, arch := range archs { @@ -41,7 +40,7 @@ func darwinBuildAll(deps buildtoolmodel.Dependencies) { func darwinBuildPackage(deps buildtoolmodel.Dependencies, goarch string, product *product) { log.Infof("building %s for darwin/%s", product.Pkg, goarch) - argv := runtimex.Try1(shellx.NewArgv("go", "build")) + argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) if deps.PsiphonFilesExist() { argv.Append("-tags", "ooni_psiphon_config") } diff --git a/internal/cmd/buildtool/darwin_test.go b/internal/cmd/buildtool/darwin_test.go index 3c7dc42fa4..b618067be5 100644 --- a/internal/cmd/buildtool/darwin_test.go +++ b/internal/cmd/buildtool/darwin_test.go @@ -130,7 +130,7 @@ func TestDarwinBuildAll(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangCheck: 1, + buildtooltest.TagGolangBinary: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 4, } diff --git a/internal/cmd/buildtool/generic.go b/internal/cmd/buildtool/generic.go index 081fa69be1..df66bd541b 100644 --- a/internal/cmd/buildtool/generic.go +++ b/internal/cmd/buildtool/generic.go @@ -48,14 +48,15 @@ func genericSubcommand() *cobra.Command { return cmd } +// TODO(bassosimone): golangBinary() MUST be a method of the buildtoolmodel.Dependencies + // genericBuildPackage is the generic function for building a package. func genericBuildPackage(deps buildtoolmodel.Dependencies, product *product) { deps.PsiphonMaybeCopyConfigFiles() - deps.GolangCheck() log.Infof("building %s for %s/%s", product.Pkg, runtime.GOOS, runtime.GOARCH) - argv := runtimex.Try1(shellx.NewArgv("go", "build")) + argv := runtimex.Try1(shellx.NewArgv(golangBinary(), "build")) if deps.PsiphonFilesExist() { argv.Append("-tags", "ooni_psiphon_config") } @@ -67,7 +68,6 @@ func genericBuildPackage(deps buildtoolmodel.Dependencies, product *product) { // genericBuildLibrary is the generic function for building a library. func genericBuildLibrary(deps buildtoolmodel.Dependencies, product *product) { - deps.GolangCheck() os := deps.GOOS() log.Infof("building %s for %s/%s", product.Pkg, os, runtime.GOARCH) @@ -76,7 +76,7 @@ func genericBuildLibrary(deps buildtoolmodel.Dependencies, product *product) { // packages paths are separated by forward slashes! library := runtimex.Try1(generateLibrary(path.Base(product.Pkg), os)) - argv := runtimex.Try1(shellx.NewArgv("go", "build")) + argv := runtimex.Try1(shellx.NewArgv(golangBinary(), "build")) argv.Append("-buildmode", "c-shared") argv.Append("-o", library) argv.Append(product.Pkg) diff --git a/internal/cmd/buildtool/generic_test.go b/internal/cmd/buildtool/generic_test.go index f41ff7bd63..f689718ce6 100644 --- a/internal/cmd/buildtool/generic_test.go +++ b/internal/cmd/buildtool/generic_test.go @@ -83,7 +83,7 @@ func TestGenericBuildPackage(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangCheck: 1, + buildtooltest.TagGolangBinary: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 1, } @@ -164,8 +164,8 @@ func TestCheckGenericBuildLibrary(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangCheck: 1, - buildtooltest.TagGOOS: 1, + buildtooltest.TagGolangBinary: 1, + buildtooltest.TagGOOS: 1, } if diff := cmp.Diff(expectCalls, deps.Counter); diff != "" { diff --git a/internal/cmd/buildtool/golang.go b/internal/cmd/buildtool/golang.go index e086534708..1e8c1cfd11 100644 --- a/internal/cmd/buildtool/golang.go +++ b/internal/cmd/buildtool/golang.go @@ -5,23 +5,73 @@ package main // import ( + "fmt" + "path/filepath" "strings" + "sync" "github.com/apex/log" "github.com/ooni/probe-cli/v3/internal/must" "github.com/ooni/probe-cli/v3/internal/runtimex" ) -// golangCheck checks whether the "go" binary is the correct version -func golangCheck(filename string) { +// golangCheckCorrectVersion returns true if the version of Go is correct. +func golangCheckCorrectVersion(filename string) bool { + // read the version of go that we would like to use expected := string(must.FirstLineBytes(must.ReadFile(filename))) + + // read the version of go that we're using firstline := string(must.FirstLineBytes(must.RunOutput(log.Log, "go", "version"))) vec := strings.Split(firstline, " ") runtimex.Assert(len(vec) == 4, "expected four tokens") - if got := vec[2]; got != "go"+expected { - log.Fatalf("expected go%s but got %s", expected, got) + + // make sure they're equal + return vec[2] == "go"+expected +} + +// golangInstall installs and returns the path to the correct version of Go. +func golangInstall(filename string) string { + // read the version of Go we would like to use + expected := string(must.FirstLineBytes(must.ReadFile(filename))) + + // install the downloaded script + packageName := fmt.Sprintf("golang.org/dl/go%s@latest", expected) + must.Run(log.Log, "go", "install", "-v", packageName) + + // run the downloader script + gobinary := filepath.Join( + string(must.FirstLineBytes(must.RunOutput(log.Log, "go", "env", "GOPATH"))), + "bin", + fmt.Sprintf("go%s", expected), + ) + must.Run(log.Log, gobinary, "download") + + // if all is good, then we have the right gobinary + return gobinary +} + +// golangBinaryWithoutCache returns the path to the correct golang binary to use. +func golangBinaryWithoutCache() string { + if !golangCheckCorrectVersion("GOVERSION") { + return golangInstall("GOVERSION") + } + return "go" +} + +// golangCachedBinary is the cached golang binary. +var golangCachedBinary string + +// golangCacheMu synchronizes accesses to [golangCachedBinary]. +var golangCacheMu sync.Mutex + +// golangBinary returns the path to the correct golang binary to use. +func golangBinary() string { + defer golangCacheMu.Unlock() + golangCacheMu.Lock() + if golangCachedBinary == "" { + golangCachedBinary = golangBinaryWithoutCache() } - log.Infof("using go%s", expected) + return golangCachedBinary } // golangGOPATH returns the GOPATH value. diff --git a/internal/cmd/buildtool/golang_test.go b/internal/cmd/buildtool/golang_test.go index 5f64e678f0..566358b7ab 100644 --- a/internal/cmd/buildtool/golang_test.go +++ b/internal/cmd/buildtool/golang_test.go @@ -1,11 +1,13 @@ package main import ( - "path/filepath" "testing" + + "github.com/ooni/probe-cli/v3/internal/must" ) -func TestGolangCheck(t *testing.T) { - // make sure the code does not panic when it runs - golangCheck(filepath.Join("..", "..", "..", "GOVERSION")) +func TestGolangBinary(t *testing.T) { + // make sure the code does not panic when it runs and returns a valid binary + value := golangBinary() + must.RunQuiet(value, "version") } diff --git a/internal/cmd/buildtool/gomobile.go b/internal/cmd/buildtool/gomobile.go index f868c7fad4..61354e25d1 100644 --- a/internal/cmd/buildtool/gomobile.go +++ b/internal/cmd/buildtool/gomobile.go @@ -35,16 +35,16 @@ type gomobileConfig struct { // gomobileBuild runs a build based on gomobile. func gomobileBuild(config *gomobileConfig) { // Undoes the effects of go-getting golang.org/x/mobile/cmd/gomobile - defer must.Run(log.Log, "go", "mod", "tidy") + defer must.Run(log.Log, config.deps.GolangBinary(), "mod", "tidy") - must.Run(log.Log, "go", "install", "golang.org/x/mobile/cmd/gomobile@latest") + must.Run(log.Log, config.deps.GolangBinary(), "install", "golang.org/x/mobile/cmd/gomobile@latest") gopath := config.deps.GOPATH() gomobile := filepath.Join(gopath, "bin", "gomobile") must.Run(log.Log, gomobile, "init") // Adding gomobile to go.mod as documented by golang.org/wiki/Mobile - must.Run(log.Log, "go", "get", "-d", "golang.org/x/mobile/cmd/gomobile") + must.Run(log.Log, config.deps.GolangBinary(), "get", "-d", "golang.org/x/mobile/cmd/gomobile") argv := runtimex.Try1(shellx.NewArgv(gomobile, "bind")) argv.Append("-target", config.target) diff --git a/internal/cmd/buildtool/internal/buildtoolmodel/buildtoolmodel.go b/internal/cmd/buildtool/internal/buildtoolmodel/buildtoolmodel.go index bac8c6856a..137a397c1b 100644 --- a/internal/cmd/buildtool/internal/buildtoolmodel/buildtoolmodel.go +++ b/internal/cmd/buildtool/internal/buildtoolmodel/buildtoolmodel.go @@ -24,9 +24,8 @@ type Dependencies interface { // GOPATH returns the current GOPATH. GOPATH() string - // GolangCheck ensures we have the correct - // version of golang as the "go" binary. - GolangCheck() + // GolangBinary returns the golang binary to use. + GolangBinary() string // LinuxWriteDockerfile writes the dockerfile for linux. LinuxWriteDockerfile(filename string, content []byte, mode fs.FileMode) diff --git a/internal/cmd/buildtool/internal/buildtooltest/buildtooltest.go b/internal/cmd/buildtool/internal/buildtooltest/buildtooltest.go index e9081489f4..d5c492aa0a 100644 --- a/internal/cmd/buildtool/internal/buildtooltest/buildtooltest.go +++ b/internal/cmd/buildtool/internal/buildtooltest/buildtooltest.go @@ -139,7 +139,7 @@ const ( TagAndroidNDKCheck = "androidNDK" TagAndroidSDKCheck = "androidSDK" TagGOPATH = "GOPATH" - TagGolangCheck = "golangCheck" + TagGolangBinary = "golangBinary" TagLinuxReadGOVERSION = "linuxReadGOVERSION" TagLinuxWriteDockerfile = "linuxWriteDockerfile" TagMustChdir = "mustChdir" @@ -188,8 +188,9 @@ func (cc *DependenciesCallCounter) GOPATH() string { } // golangCheck implements buildtoolmodel.Dependencies -func (cc *DependenciesCallCounter) GolangCheck() { - cc.increment(TagGolangCheck) +func (cc *DependenciesCallCounter) GolangBinary() string { + cc.increment(TagGolangBinary) + return "go" } // linuxReadGOVERSION implements buildtoolmodel.Dependencies diff --git a/internal/cmd/buildtool/internal/buildtooltest/buildtooltest_test.go b/internal/cmd/buildtool/internal/buildtooltest/buildtooltest_test.go index fd8dfb90a4..866a85e9d4 100644 --- a/internal/cmd/buildtool/internal/buildtooltest/buildtooltest_test.go +++ b/internal/cmd/buildtool/internal/buildtooltest/buildtooltest_test.go @@ -203,10 +203,13 @@ func TestDependenciesCallCounter(t *testing.T) { t.Run("GolangCheck", func(t *testing.T) { cc := &DependenciesCallCounter{} - cc.GolangCheck() - if cc.Counter[TagGolangCheck] != 1 { + value := cc.GolangBinary() + if cc.Counter[TagGolangBinary] != 1 { t.Fatal("did not increment") } + if value != "go" { + t.Fatal("expected 'go', got", value) + } }) t.Run("LinuxReadGOVERSION", func(t *testing.T) { diff --git a/internal/cmd/buildtool/ios.go b/internal/cmd/buildtool/ios.go index 49cb8cbb54..e725e1c36a 100644 --- a/internal/cmd/buildtool/ios.go +++ b/internal/cmd/buildtool/ios.go @@ -53,7 +53,6 @@ func iosSubcommand() *cobra.Command { // iosBuildGomobile invokes the gomobile build. func iosBuildGomobile(deps buildtoolmodel.Dependencies) { deps.PsiphonMaybeCopyConfigFiles() - deps.GolangCheck() config := &gomobileConfig{ deps: deps, diff --git a/internal/cmd/buildtool/ios_test.go b/internal/cmd/buildtool/ios_test.go index 1377704d09..931f44c40e 100644 --- a/internal/cmd/buildtool/ios_test.go +++ b/internal/cmd/buildtool/ios_test.go @@ -107,7 +107,7 @@ func TestIOSBuildGomobile(t *testing.T) { expectCalls := map[string]int{ buildtooltest.TagGOPATH: 1, - buildtooltest.TagGolangCheck: 1, + buildtooltest.TagGolangBinary: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 1, } diff --git a/internal/cmd/buildtool/linuxstatic.go b/internal/cmd/buildtool/linuxstatic.go index d04cfe99f1..c98f0b5e8d 100644 --- a/internal/cmd/buildtool/linuxstatic.go +++ b/internal/cmd/buildtool/linuxstatic.go @@ -47,7 +47,6 @@ func (b *linuxStaticBuilder) main(*cobra.Command, []string) { // linuxStaticBuildAll builds all the packages on a linux-static environment. func linuxStaticBuilAll(deps buildtoolmodel.Dependencies, goarch string, goarm int64) { deps.PsiphonMaybeCopyConfigFiles() - deps.GolangCheck() // TODO(bassosimone): I am running the container with the right userID but // apparently this is not enough to make git happy--why? @@ -73,7 +72,7 @@ func linuxStaticBuildPackage( ooniArch := linuxStaticBuildOONIArch(goarch, goarm) - argv := runtimex.Try1(shellx.NewArgv("go", "build")) + argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) if deps.PsiphonFilesExist() { argv.Append("-tags", "ooni_psiphon_config") } diff --git a/internal/cmd/buildtool/linuxstatic_test.go b/internal/cmd/buildtool/linuxstatic_test.go index 58bfbc2d08..0b18194ff2 100644 --- a/internal/cmd/buildtool/linuxstatic_test.go +++ b/internal/cmd/buildtool/linuxstatic_test.go @@ -198,7 +198,7 @@ func TestLinuxStaticBuildAll(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangCheck: 1, + buildtooltest.TagGolangBinary: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 2, } diff --git a/internal/cmd/buildtool/oohelperd.go b/internal/cmd/buildtool/oohelperd.go index 12d9110e85..d6384f71b2 100644 --- a/internal/cmd/buildtool/oohelperd.go +++ b/internal/cmd/buildtool/oohelperd.go @@ -42,8 +42,6 @@ func oohelperdSubcommand() *cobra.Command { // oohelperdBuildAndMaybeDeploy builds oohelperd for linux/amd64 and // possibly deploys the build to the 0.th.ooni.org server. func oohelperdBuildAndMaybeDeploy(deps buildtoolmodel.Dependencies, deploy bool) { - deps.GolangCheck() - log.Info("building oohelperd for linux/amd64") oohelperdBinary := filepath.Join("CLI", "oohelperd-linux-amd64") @@ -52,7 +50,7 @@ func oohelperdBuildAndMaybeDeploy(deps buildtoolmodel.Dependencies, deploy bool) envp.Append("GOOS", "linux") envp.Append("GOARCH", "amd64") - argv := runtimex.Try1(shellx.NewArgv("go", "build")) + argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) argv.Append("-o", oohelperdBinary) argv.Append("-tags", "netgo") argv.Append("-ldflags", "-s -w -extldflags -static") diff --git a/internal/cmd/buildtool/oohelperd_test.go b/internal/cmd/buildtool/oohelperd_test.go index 900d51d2ee..5c89fafa10 100644 --- a/internal/cmd/buildtool/oohelperd_test.go +++ b/internal/cmd/buildtool/oohelperd_test.go @@ -79,7 +79,7 @@ func TestOohelperdBuildAndMaybeDeploy(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangCheck: 1, + buildtooltest.TagGolangBinary: 1, } if diff := cmp.Diff(expectCalls, deps.Counter); diff != "" { diff --git a/internal/cmd/buildtool/windows.go b/internal/cmd/buildtool/windows.go index db6f0bca59..2550fb2eae 100644 --- a/internal/cmd/buildtool/windows.go +++ b/internal/cmd/buildtool/windows.go @@ -32,7 +32,6 @@ func windowsSubcommand() *cobra.Command { // windowsBuildAll is the main function of the windows subcommand. func windowsBuildAll(deps buildtoolmodel.Dependencies) { deps.PsiphonMaybeCopyConfigFiles() - deps.GolangCheck() deps.WindowsMingwCheck() archs := []string{"386", "amd64"} products := []*product{productMiniooni, productOoniprobe} @@ -48,7 +47,7 @@ func windowsBuildAll(deps buildtoolmodel.Dependencies) { func windowsBuildPackage(deps buildtoolmodel.Dependencies, goarch string, product *product) { log.Infof("building %s for windows/%s", product.Pkg, goarch) - argv := runtimex.Try1(shellx.NewArgv("go", "build")) + argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) if deps.PsiphonFilesExist() { argv.Append("-tags", "ooni_psiphon_config") } diff --git a/internal/cmd/buildtool/windows_test.go b/internal/cmd/buildtool/windows_test.go index f11e6ac45d..fb40ac3be1 100644 --- a/internal/cmd/buildtool/windows_test.go +++ b/internal/cmd/buildtool/windows_test.go @@ -138,7 +138,7 @@ func TestWindowsBuildAll(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangCheck: 1, + buildtooltest.TagGolangBinary: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 4, buildtooltest.TagWindowsMingwCheck: 1, From 8d31497994f46acc02b26f297b790d9e571d9eab Mon Sep 17 00:00:00 2001 From: Simone Basso Date: Thu, 1 Feb 2024 18:47:16 +0100 Subject: [PATCH 2/6] x --- internal/cmd/buildtool/generic.go | 2 -- 1 file changed, 2 deletions(-) diff --git a/internal/cmd/buildtool/generic.go b/internal/cmd/buildtool/generic.go index df66bd541b..b69b25b2d4 100644 --- a/internal/cmd/buildtool/generic.go +++ b/internal/cmd/buildtool/generic.go @@ -48,8 +48,6 @@ func genericSubcommand() *cobra.Command { return cmd } -// TODO(bassosimone): golangBinary() MUST be a method of the buildtoolmodel.Dependencies - // genericBuildPackage is the generic function for building a package. func genericBuildPackage(deps buildtoolmodel.Dependencies, product *product) { deps.PsiphonMaybeCopyConfigFiles() From 1fc4683bc8c06ee8cceffd8d55910551451221cf Mon Sep 17 00:00:00 2001 From: Simone Basso Date: Thu, 1 Feb 2024 19:01:22 +0100 Subject: [PATCH 3/6] x --- .github/workflows/goversion.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/goversion.yml b/.github/workflows/goversion.yml index 9e82ba24b7..f4b127b442 100644 --- a/.github/workflows/goversion.yml +++ b/.github/workflows/goversion.yml @@ -15,7 +15,7 @@ jobs: build_with_unexpected_go_version: strategy: matrix: - goversion: ["1.17", "1.18", "1.19", "1.21"] + goversion: ["1.19", "1.21"] system: [ubuntu-latest, windows-latest, macos-latest] runs-on: "${{ matrix.system }}" steps: From 9c1bf89a64495b91966b9c6d719b1a662d918be9 Mon Sep 17 00:00:00 2001 From: Simone Basso Date: Thu, 1 Feb 2024 21:37:26 +0100 Subject: [PATCH 4/6] x --- .github/workflows/goversion.yml | 6 ++++-- internal/cmd/buildtool/android_test.go | 4 ++-- internal/cmd/buildtool/darwin_test.go | 2 +- internal/cmd/buildtool/generic.go | 4 ++-- internal/cmd/buildtool/golang.go | 5 +++-- internal/cmd/buildtool/golang_test.go | 5 +++++ internal/cmd/buildtool/ios_test.go | 2 +- internal/cmd/buildtool/linuxstatic_test.go | 2 +- internal/cmd/buildtool/windows_test.go | 2 +- 9 files changed, 20 insertions(+), 12 deletions(-) diff --git a/.github/workflows/goversion.yml b/.github/workflows/goversion.yml index f4b127b442..5786cab949 100644 --- a/.github/workflows/goversion.yml +++ b/.github/workflows/goversion.yml @@ -6,8 +6,10 @@ on: branches: - "release/**" - "fullbuild" + - "master" tags: - "v*" + pull_request: schedule: - cron: "17 7 * * *" @@ -15,8 +17,8 @@ jobs: build_with_unexpected_go_version: strategy: matrix: - goversion: ["1.19", "1.21"] - system: [ubuntu-latest, windows-latest, macos-latest] + goversion: ["1.18", "1.19", "1.20", "1.21"] + system: [ubuntu-latest, macos-latest] runs-on: "${{ matrix.system }}" steps: - uses: actions/checkout@v3 diff --git a/internal/cmd/buildtool/android_test.go b/internal/cmd/buildtool/android_test.go index 69ce3cbb1a..330573fd06 100644 --- a/internal/cmd/buildtool/android_test.go +++ b/internal/cmd/buildtool/android_test.go @@ -121,7 +121,7 @@ func TestAndroidBuildGomobile(t *testing.T) { buildtooltest.TagGOPATH: 2, buildtooltest.TagAndroidNDKCheck: 1, buildtooltest.TagAndroidSDKCheck: 1, - buildtooltest.TagGolangBinary: 1, + buildtooltest.TagGolangBinary: 3, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 1, } @@ -406,7 +406,7 @@ func TestAndroidBuildCLIAll(t *testing.T) { expectCalls := map[string]int{ buildtooltest.TagAndroidNDKCheck: 1, buildtooltest.TagAndroidSDKCheck: 1, - buildtooltest.TagGolangBinary: 1, + buildtooltest.TagGolangBinary: 8, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 8, } diff --git a/internal/cmd/buildtool/darwin_test.go b/internal/cmd/buildtool/darwin_test.go index b618067be5..d6f88349a2 100644 --- a/internal/cmd/buildtool/darwin_test.go +++ b/internal/cmd/buildtool/darwin_test.go @@ -130,7 +130,7 @@ func TestDarwinBuildAll(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangBinary: 1, + buildtooltest.TagGolangBinary: 4, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 4, } diff --git a/internal/cmd/buildtool/generic.go b/internal/cmd/buildtool/generic.go index b69b25b2d4..6c8fa08ac1 100644 --- a/internal/cmd/buildtool/generic.go +++ b/internal/cmd/buildtool/generic.go @@ -54,7 +54,7 @@ func genericBuildPackage(deps buildtoolmodel.Dependencies, product *product) { log.Infof("building %s for %s/%s", product.Pkg, runtime.GOOS, runtime.GOARCH) - argv := runtimex.Try1(shellx.NewArgv(golangBinary(), "build")) + argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) if deps.PsiphonFilesExist() { argv.Append("-tags", "ooni_psiphon_config") } @@ -74,7 +74,7 @@ func genericBuildLibrary(deps buildtoolmodel.Dependencies, product *product) { // packages paths are separated by forward slashes! library := runtimex.Try1(generateLibrary(path.Base(product.Pkg), os)) - argv := runtimex.Try1(shellx.NewArgv(golangBinary(), "build")) + argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) argv.Append("-buildmode", "c-shared") argv.Append("-o", library) argv.Append(product.Pkg) diff --git a/internal/cmd/buildtool/golang.go b/internal/cmd/buildtool/golang.go index 1e8c1cfd11..fab9b50839 100644 --- a/internal/cmd/buildtool/golang.go +++ b/internal/cmd/buildtool/golang.go @@ -34,11 +34,11 @@ func golangInstall(filename string) string { // read the version of Go we would like to use expected := string(must.FirstLineBytes(must.ReadFile(filename))) - // install the downloaded script + // install the wrapper command packageName := fmt.Sprintf("golang.org/dl/go%s@latest", expected) must.Run(log.Log, "go", "install", "-v", packageName) - // run the downloader script + // run the wrapper to download the distribution gobinary := filepath.Join( string(must.FirstLineBytes(must.RunOutput(log.Log, "go", "env", "GOPATH"))), "bin", @@ -47,6 +47,7 @@ func golangInstall(filename string) string { must.Run(log.Log, gobinary, "download") // if all is good, then we have the right gobinary + // along with the distribution return gobinary } diff --git a/internal/cmd/buildtool/golang_test.go b/internal/cmd/buildtool/golang_test.go index 566358b7ab..17ecb9ba94 100644 --- a/internal/cmd/buildtool/golang_test.go +++ b/internal/cmd/buildtool/golang_test.go @@ -1,13 +1,18 @@ package main import ( + "os" "testing" "github.com/ooni/probe-cli/v3/internal/must" + "github.com/ooni/probe-cli/v3/internal/runtimex" ) func TestGolangBinary(t *testing.T) { // make sure the code does not panic when it runs and returns a valid binary + oldDirectory := runtimex.Try1(os.Getwd()) + runtimex.Try0(os.Chdir("../../..")) value := golangBinary() must.RunQuiet(value, "version") + runtimex.Try0(os.Chdir(oldDirectory)) } diff --git a/internal/cmd/buildtool/ios_test.go b/internal/cmd/buildtool/ios_test.go index 931f44c40e..7c2dcb3ab8 100644 --- a/internal/cmd/buildtool/ios_test.go +++ b/internal/cmd/buildtool/ios_test.go @@ -107,7 +107,7 @@ func TestIOSBuildGomobile(t *testing.T) { expectCalls := map[string]int{ buildtooltest.TagGOPATH: 1, - buildtooltest.TagGolangBinary: 1, + buildtooltest.TagGolangBinary: 3, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 1, } diff --git a/internal/cmd/buildtool/linuxstatic_test.go b/internal/cmd/buildtool/linuxstatic_test.go index 0b18194ff2..baf8760875 100644 --- a/internal/cmd/buildtool/linuxstatic_test.go +++ b/internal/cmd/buildtool/linuxstatic_test.go @@ -198,7 +198,7 @@ func TestLinuxStaticBuildAll(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangBinary: 1, + buildtooltest.TagGolangBinary: 2, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 2, } diff --git a/internal/cmd/buildtool/windows_test.go b/internal/cmd/buildtool/windows_test.go index fb40ac3be1..43e23878e1 100644 --- a/internal/cmd/buildtool/windows_test.go +++ b/internal/cmd/buildtool/windows_test.go @@ -138,7 +138,7 @@ func TestWindowsBuildAll(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangBinary: 1, + buildtooltest.TagGolangBinary: 4, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 4, buildtooltest.TagWindowsMingwCheck: 1, From 50118ed66a68ecfc9a3bdc326275cba0882081fb Mon Sep 17 00:00:00 2001 From: Simone Basso Date: Thu, 1 Feb 2024 23:10:25 +0100 Subject: [PATCH 5/6] x --- .github/workflows/goversion.yml | 30 ------------------- internal/cmd/buildtool/android.go | 4 ++- internal/cmd/buildtool/android_test.go | 4 +-- internal/cmd/buildtool/builddeps.go | 6 ++-- internal/cmd/buildtool/darwin.go | 3 +- internal/cmd/buildtool/darwin_test.go | 2 +- internal/cmd/buildtool/generic.go | 6 ++-- internal/cmd/buildtool/generic_test.go | 6 ++-- internal/cmd/buildtool/golang.go | 5 ---- internal/cmd/buildtool/golang_test.go | 5 +--- internal/cmd/buildtool/gomobile.go | 6 ++-- .../internal/buildtoolmodel/buildtoolmodel.go | 5 ++-- .../internal/buildtooltest/buildtooltest.go | 7 ++--- .../buildtooltest/buildtooltest_test.go | 7 ++--- internal/cmd/buildtool/ios.go | 1 + internal/cmd/buildtool/ios_test.go | 2 +- internal/cmd/buildtool/linuxstatic.go | 3 +- internal/cmd/buildtool/linuxstatic_test.go | 2 +- internal/cmd/buildtool/oohelperd.go | 4 ++- internal/cmd/buildtool/oohelperd_test.go | 2 +- internal/cmd/buildtool/windows.go | 3 +- internal/cmd/buildtool/windows_test.go | 2 +- 22 files changed, 42 insertions(+), 73 deletions(-) delete mode 100644 .github/workflows/goversion.yml diff --git a/.github/workflows/goversion.yml b/.github/workflows/goversion.yml deleted file mode 100644 index 5786cab949..0000000000 --- a/.github/workflows/goversion.yml +++ /dev/null @@ -1,30 +0,0 @@ -# Ensures that ./internal/cmd/buildtool works with different go versions - -name: goversion -on: - push: - branches: - - "release/**" - - "fullbuild" - - "master" - tags: - - "v*" - pull_request: - schedule: - - cron: "17 7 * * *" - -jobs: - build_with_unexpected_go_version: - strategy: - matrix: - goversion: ["1.18", "1.19", "1.20", "1.21"] - system: [ubuntu-latest, macos-latest] - runs-on: "${{ matrix.system }}" - steps: - - uses: actions/checkout@v3 - - - uses: actions/setup-go@v4 - with: - go-version: "${{ matrix.goversion }}" - - - run: go run ./internal/cmd/buildtool generic miniooni diff --git a/internal/cmd/buildtool/android.go b/internal/cmd/buildtool/android.go index d0b9cb4d74..174aa6d7a4 100644 --- a/internal/cmd/buildtool/android.go +++ b/internal/cmd/buildtool/android.go @@ -78,6 +78,7 @@ func androidSubcommand() *cobra.Command { // androidBuildGomobile invokes the gomobile build. func androidBuildGomobile(deps buildtoolmodel.Dependencies) { deps.PsiphonMaybeCopyConfigFiles() + deps.GolangCheck() androidHome := deps.AndroidSDKCheck() ndkDir := deps.AndroidNDKCheck(androidHome) @@ -145,6 +146,7 @@ func androidNDKCheck(androidHome string) string { // androidBuildCLIAll builds all products in CLI mode for Android func androidBuildCLIAll(deps buildtoolmodel.Dependencies) { deps.PsiphonMaybeCopyConfigFiles() + deps.GolangCheck() androidHome := deps.AndroidSDKCheck() ndkDir := deps.AndroidNDKCheck(androidHome) @@ -175,7 +177,7 @@ func androidBuildCLIProductArch( log.Infof("building %s for android/%s", product.Pkg, ooniArch) - argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) + argv := runtimex.Try1(shellx.NewArgv("go", "build")) if deps.PsiphonFilesExist() { argv.Append("-tags", "ooni_psiphon_config,ooni_libtor") } else { diff --git a/internal/cmd/buildtool/android_test.go b/internal/cmd/buildtool/android_test.go index 330573fd06..a053bf3d8f 100644 --- a/internal/cmd/buildtool/android_test.go +++ b/internal/cmd/buildtool/android_test.go @@ -121,7 +121,7 @@ func TestAndroidBuildGomobile(t *testing.T) { buildtooltest.TagGOPATH: 2, buildtooltest.TagAndroidNDKCheck: 1, buildtooltest.TagAndroidSDKCheck: 1, - buildtooltest.TagGolangBinary: 3, + buildtooltest.TagGolangCheck: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 1, } @@ -406,7 +406,7 @@ func TestAndroidBuildCLIAll(t *testing.T) { expectCalls := map[string]int{ buildtooltest.TagAndroidNDKCheck: 1, buildtooltest.TagAndroidSDKCheck: 1, - buildtooltest.TagGolangBinary: 8, + buildtooltest.TagGolangCheck: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 8, } diff --git a/internal/cmd/buildtool/builddeps.go b/internal/cmd/buildtool/builddeps.go index f7dfb4a9cd..cc4bececfb 100644 --- a/internal/cmd/buildtool/builddeps.go +++ b/internal/cmd/buildtool/builddeps.go @@ -38,9 +38,9 @@ func (*buildDeps) GOPATH() string { return golangGOPATH() } -// GolangBinary implements buildtoolmodel.Dependencies -func (*buildDeps) GolangBinary() string { - return golangBinary() +// GolangCheck implements buildtoolmodel.Dependencies +func (*buildDeps) GolangCheck() { + golangCheck("GOVERSION") } // LinuxReadGOVERSION implements buildtoolmodel.Dependencies diff --git a/internal/cmd/buildtool/darwin.go b/internal/cmd/buildtool/darwin.go index fa8af860bb..e9dfd4a4a3 100644 --- a/internal/cmd/buildtool/darwin.go +++ b/internal/cmd/buildtool/darwin.go @@ -27,6 +27,7 @@ func darwinSubcommand() *cobra.Command { // darwinBuildAll builds all the packages for darwin. func darwinBuildAll(deps buildtoolmodel.Dependencies) { deps.PsiphonMaybeCopyConfigFiles() + deps.GolangCheck() archs := []string{"amd64", "arm64"} products := []*product{productMiniooni, productOoniprobe} for _, arch := range archs { @@ -40,7 +41,7 @@ func darwinBuildAll(deps buildtoolmodel.Dependencies) { func darwinBuildPackage(deps buildtoolmodel.Dependencies, goarch string, product *product) { log.Infof("building %s for darwin/%s", product.Pkg, goarch) - argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) + argv := runtimex.Try1(shellx.NewArgv("go", "build")) if deps.PsiphonFilesExist() { argv.Append("-tags", "ooni_psiphon_config") } diff --git a/internal/cmd/buildtool/darwin_test.go b/internal/cmd/buildtool/darwin_test.go index d6f88349a2..3c7dc42fa4 100644 --- a/internal/cmd/buildtool/darwin_test.go +++ b/internal/cmd/buildtool/darwin_test.go @@ -130,7 +130,7 @@ func TestDarwinBuildAll(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangBinary: 4, + buildtooltest.TagGolangCheck: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 4, } diff --git a/internal/cmd/buildtool/generic.go b/internal/cmd/buildtool/generic.go index 6c8fa08ac1..081fa69be1 100644 --- a/internal/cmd/buildtool/generic.go +++ b/internal/cmd/buildtool/generic.go @@ -51,10 +51,11 @@ func genericSubcommand() *cobra.Command { // genericBuildPackage is the generic function for building a package. func genericBuildPackage(deps buildtoolmodel.Dependencies, product *product) { deps.PsiphonMaybeCopyConfigFiles() + deps.GolangCheck() log.Infof("building %s for %s/%s", product.Pkg, runtime.GOOS, runtime.GOARCH) - argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) + argv := runtimex.Try1(shellx.NewArgv("go", "build")) if deps.PsiphonFilesExist() { argv.Append("-tags", "ooni_psiphon_config") } @@ -66,6 +67,7 @@ func genericBuildPackage(deps buildtoolmodel.Dependencies, product *product) { // genericBuildLibrary is the generic function for building a library. func genericBuildLibrary(deps buildtoolmodel.Dependencies, product *product) { + deps.GolangCheck() os := deps.GOOS() log.Infof("building %s for %s/%s", product.Pkg, os, runtime.GOARCH) @@ -74,7 +76,7 @@ func genericBuildLibrary(deps buildtoolmodel.Dependencies, product *product) { // packages paths are separated by forward slashes! library := runtimex.Try1(generateLibrary(path.Base(product.Pkg), os)) - argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) + argv := runtimex.Try1(shellx.NewArgv("go", "build")) argv.Append("-buildmode", "c-shared") argv.Append("-o", library) argv.Append(product.Pkg) diff --git a/internal/cmd/buildtool/generic_test.go b/internal/cmd/buildtool/generic_test.go index f689718ce6..f41ff7bd63 100644 --- a/internal/cmd/buildtool/generic_test.go +++ b/internal/cmd/buildtool/generic_test.go @@ -83,7 +83,7 @@ func TestGenericBuildPackage(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangBinary: 1, + buildtooltest.TagGolangCheck: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 1, } @@ -164,8 +164,8 @@ func TestCheckGenericBuildLibrary(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangBinary: 1, - buildtooltest.TagGOOS: 1, + buildtooltest.TagGolangCheck: 1, + buildtooltest.TagGOOS: 1, } if diff := cmp.Diff(expectCalls, deps.Counter); diff != "" { diff --git a/internal/cmd/buildtool/golang.go b/internal/cmd/buildtool/golang.go index 90aa17bb1b..7365395f04 100644 --- a/internal/cmd/buildtool/golang.go +++ b/internal/cmd/buildtool/golang.go @@ -5,10 +5,7 @@ package main // import ( - "fmt" - "path/filepath" "strings" - "sync" "github.com/apex/log" "github.com/ooni/probe-cli/v3/internal/must" @@ -18,8 +15,6 @@ import ( // golangCorrectVersionCheckP returns whether we're using the correct golang version. func golangCorrectVersionCheckP(filename string) bool { expected := string(must.FirstLineBytes(must.ReadFile(filename))) - - // read the version of go that we're using firstline := string(must.FirstLineBytes(must.RunOutput(log.Log, "go", "version"))) vec := strings.Split(firstline, " ") runtimex.Assert(len(vec) == 4, "expected four tokens") diff --git a/internal/cmd/buildtool/golang_test.go b/internal/cmd/buildtool/golang_test.go index e4fd475159..90cf6c6be0 100644 --- a/internal/cmd/buildtool/golang_test.go +++ b/internal/cmd/buildtool/golang_test.go @@ -1,11 +1,8 @@ package main import ( - "os" + "path/filepath" "testing" - - "github.com/ooni/probe-cli/v3/internal/must" - "github.com/ooni/probe-cli/v3/internal/runtimex" ) func TestGolangCheck(t *testing.T) { diff --git a/internal/cmd/buildtool/gomobile.go b/internal/cmd/buildtool/gomobile.go index 61354e25d1..f868c7fad4 100644 --- a/internal/cmd/buildtool/gomobile.go +++ b/internal/cmd/buildtool/gomobile.go @@ -35,16 +35,16 @@ type gomobileConfig struct { // gomobileBuild runs a build based on gomobile. func gomobileBuild(config *gomobileConfig) { // Undoes the effects of go-getting golang.org/x/mobile/cmd/gomobile - defer must.Run(log.Log, config.deps.GolangBinary(), "mod", "tidy") + defer must.Run(log.Log, "go", "mod", "tidy") - must.Run(log.Log, config.deps.GolangBinary(), "install", "golang.org/x/mobile/cmd/gomobile@latest") + must.Run(log.Log, "go", "install", "golang.org/x/mobile/cmd/gomobile@latest") gopath := config.deps.GOPATH() gomobile := filepath.Join(gopath, "bin", "gomobile") must.Run(log.Log, gomobile, "init") // Adding gomobile to go.mod as documented by golang.org/wiki/Mobile - must.Run(log.Log, config.deps.GolangBinary(), "get", "-d", "golang.org/x/mobile/cmd/gomobile") + must.Run(log.Log, "go", "get", "-d", "golang.org/x/mobile/cmd/gomobile") argv := runtimex.Try1(shellx.NewArgv(gomobile, "bind")) argv.Append("-target", config.target) diff --git a/internal/cmd/buildtool/internal/buildtoolmodel/buildtoolmodel.go b/internal/cmd/buildtool/internal/buildtoolmodel/buildtoolmodel.go index 137a397c1b..bac8c6856a 100644 --- a/internal/cmd/buildtool/internal/buildtoolmodel/buildtoolmodel.go +++ b/internal/cmd/buildtool/internal/buildtoolmodel/buildtoolmodel.go @@ -24,8 +24,9 @@ type Dependencies interface { // GOPATH returns the current GOPATH. GOPATH() string - // GolangBinary returns the golang binary to use. - GolangBinary() string + // GolangCheck ensures we have the correct + // version of golang as the "go" binary. + GolangCheck() // LinuxWriteDockerfile writes the dockerfile for linux. LinuxWriteDockerfile(filename string, content []byte, mode fs.FileMode) diff --git a/internal/cmd/buildtool/internal/buildtooltest/buildtooltest.go b/internal/cmd/buildtool/internal/buildtooltest/buildtooltest.go index d5c492aa0a..e9081489f4 100644 --- a/internal/cmd/buildtool/internal/buildtooltest/buildtooltest.go +++ b/internal/cmd/buildtool/internal/buildtooltest/buildtooltest.go @@ -139,7 +139,7 @@ const ( TagAndroidNDKCheck = "androidNDK" TagAndroidSDKCheck = "androidSDK" TagGOPATH = "GOPATH" - TagGolangBinary = "golangBinary" + TagGolangCheck = "golangCheck" TagLinuxReadGOVERSION = "linuxReadGOVERSION" TagLinuxWriteDockerfile = "linuxWriteDockerfile" TagMustChdir = "mustChdir" @@ -188,9 +188,8 @@ func (cc *DependenciesCallCounter) GOPATH() string { } // golangCheck implements buildtoolmodel.Dependencies -func (cc *DependenciesCallCounter) GolangBinary() string { - cc.increment(TagGolangBinary) - return "go" +func (cc *DependenciesCallCounter) GolangCheck() { + cc.increment(TagGolangCheck) } // linuxReadGOVERSION implements buildtoolmodel.Dependencies diff --git a/internal/cmd/buildtool/internal/buildtooltest/buildtooltest_test.go b/internal/cmd/buildtool/internal/buildtooltest/buildtooltest_test.go index 866a85e9d4..fd8dfb90a4 100644 --- a/internal/cmd/buildtool/internal/buildtooltest/buildtooltest_test.go +++ b/internal/cmd/buildtool/internal/buildtooltest/buildtooltest_test.go @@ -203,13 +203,10 @@ func TestDependenciesCallCounter(t *testing.T) { t.Run("GolangCheck", func(t *testing.T) { cc := &DependenciesCallCounter{} - value := cc.GolangBinary() - if cc.Counter[TagGolangBinary] != 1 { + cc.GolangCheck() + if cc.Counter[TagGolangCheck] != 1 { t.Fatal("did not increment") } - if value != "go" { - t.Fatal("expected 'go', got", value) - } }) t.Run("LinuxReadGOVERSION", func(t *testing.T) { diff --git a/internal/cmd/buildtool/ios.go b/internal/cmd/buildtool/ios.go index e725e1c36a..49cb8cbb54 100644 --- a/internal/cmd/buildtool/ios.go +++ b/internal/cmd/buildtool/ios.go @@ -53,6 +53,7 @@ func iosSubcommand() *cobra.Command { // iosBuildGomobile invokes the gomobile build. func iosBuildGomobile(deps buildtoolmodel.Dependencies) { deps.PsiphonMaybeCopyConfigFiles() + deps.GolangCheck() config := &gomobileConfig{ deps: deps, diff --git a/internal/cmd/buildtool/ios_test.go b/internal/cmd/buildtool/ios_test.go index 7c2dcb3ab8..1377704d09 100644 --- a/internal/cmd/buildtool/ios_test.go +++ b/internal/cmd/buildtool/ios_test.go @@ -107,7 +107,7 @@ func TestIOSBuildGomobile(t *testing.T) { expectCalls := map[string]int{ buildtooltest.TagGOPATH: 1, - buildtooltest.TagGolangBinary: 3, + buildtooltest.TagGolangCheck: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 1, } diff --git a/internal/cmd/buildtool/linuxstatic.go b/internal/cmd/buildtool/linuxstatic.go index c98f0b5e8d..d04cfe99f1 100644 --- a/internal/cmd/buildtool/linuxstatic.go +++ b/internal/cmd/buildtool/linuxstatic.go @@ -47,6 +47,7 @@ func (b *linuxStaticBuilder) main(*cobra.Command, []string) { // linuxStaticBuildAll builds all the packages on a linux-static environment. func linuxStaticBuilAll(deps buildtoolmodel.Dependencies, goarch string, goarm int64) { deps.PsiphonMaybeCopyConfigFiles() + deps.GolangCheck() // TODO(bassosimone): I am running the container with the right userID but // apparently this is not enough to make git happy--why? @@ -72,7 +73,7 @@ func linuxStaticBuildPackage( ooniArch := linuxStaticBuildOONIArch(goarch, goarm) - argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) + argv := runtimex.Try1(shellx.NewArgv("go", "build")) if deps.PsiphonFilesExist() { argv.Append("-tags", "ooni_psiphon_config") } diff --git a/internal/cmd/buildtool/linuxstatic_test.go b/internal/cmd/buildtool/linuxstatic_test.go index baf8760875..58bfbc2d08 100644 --- a/internal/cmd/buildtool/linuxstatic_test.go +++ b/internal/cmd/buildtool/linuxstatic_test.go @@ -198,7 +198,7 @@ func TestLinuxStaticBuildAll(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangBinary: 2, + buildtooltest.TagGolangCheck: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 2, } diff --git a/internal/cmd/buildtool/oohelperd.go b/internal/cmd/buildtool/oohelperd.go index d6384f71b2..12d9110e85 100644 --- a/internal/cmd/buildtool/oohelperd.go +++ b/internal/cmd/buildtool/oohelperd.go @@ -42,6 +42,8 @@ func oohelperdSubcommand() *cobra.Command { // oohelperdBuildAndMaybeDeploy builds oohelperd for linux/amd64 and // possibly deploys the build to the 0.th.ooni.org server. func oohelperdBuildAndMaybeDeploy(deps buildtoolmodel.Dependencies, deploy bool) { + deps.GolangCheck() + log.Info("building oohelperd for linux/amd64") oohelperdBinary := filepath.Join("CLI", "oohelperd-linux-amd64") @@ -50,7 +52,7 @@ func oohelperdBuildAndMaybeDeploy(deps buildtoolmodel.Dependencies, deploy bool) envp.Append("GOOS", "linux") envp.Append("GOARCH", "amd64") - argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) + argv := runtimex.Try1(shellx.NewArgv("go", "build")) argv.Append("-o", oohelperdBinary) argv.Append("-tags", "netgo") argv.Append("-ldflags", "-s -w -extldflags -static") diff --git a/internal/cmd/buildtool/oohelperd_test.go b/internal/cmd/buildtool/oohelperd_test.go index 5c89fafa10..900d51d2ee 100644 --- a/internal/cmd/buildtool/oohelperd_test.go +++ b/internal/cmd/buildtool/oohelperd_test.go @@ -79,7 +79,7 @@ func TestOohelperdBuildAndMaybeDeploy(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangBinary: 1, + buildtooltest.TagGolangCheck: 1, } if diff := cmp.Diff(expectCalls, deps.Counter); diff != "" { diff --git a/internal/cmd/buildtool/windows.go b/internal/cmd/buildtool/windows.go index 2550fb2eae..db6f0bca59 100644 --- a/internal/cmd/buildtool/windows.go +++ b/internal/cmd/buildtool/windows.go @@ -32,6 +32,7 @@ func windowsSubcommand() *cobra.Command { // windowsBuildAll is the main function of the windows subcommand. func windowsBuildAll(deps buildtoolmodel.Dependencies) { deps.PsiphonMaybeCopyConfigFiles() + deps.GolangCheck() deps.WindowsMingwCheck() archs := []string{"386", "amd64"} products := []*product{productMiniooni, productOoniprobe} @@ -47,7 +48,7 @@ func windowsBuildAll(deps buildtoolmodel.Dependencies) { func windowsBuildPackage(deps buildtoolmodel.Dependencies, goarch string, product *product) { log.Infof("building %s for windows/%s", product.Pkg, goarch) - argv := runtimex.Try1(shellx.NewArgv(deps.GolangBinary(), "build")) + argv := runtimex.Try1(shellx.NewArgv("go", "build")) if deps.PsiphonFilesExist() { argv.Append("-tags", "ooni_psiphon_config") } diff --git a/internal/cmd/buildtool/windows_test.go b/internal/cmd/buildtool/windows_test.go index 43e23878e1..f11e6ac45d 100644 --- a/internal/cmd/buildtool/windows_test.go +++ b/internal/cmd/buildtool/windows_test.go @@ -138,7 +138,7 @@ func TestWindowsBuildAll(t *testing.T) { }) expectCalls := map[string]int{ - buildtooltest.TagGolangBinary: 4, + buildtooltest.TagGolangCheck: 1, buildtooltest.TagPsiphonMaybeCopyConfigFiles: 1, buildtooltest.TagPsiphonFilesExist: 4, buildtooltest.TagWindowsMingwCheck: 1, From 688924fb3b87549f1511d74065e1f401678b12b4 Mon Sep 17 00:00:00 2001 From: Simone Basso Date: Thu, 1 Feb 2024 23:11:04 +0100 Subject: [PATCH 6/6] x --- Makefile | 28 ++++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/Makefile b/Makefile index 026a7adc8e..85ce2b33ae 100644 --- a/Makefile +++ b/Makefile @@ -26,80 +26,80 @@ help: #help: command line clients for darwin/amd64 and darwin/arm64. .PHONY: CLI/darwin CLI/darwin: - go run ./internal/cmd/buildtool darwin + ./script/go.bash run ./internal/cmd/buildtool darwin #help: #help: The `make CLI/linux-static-386` command builds and statically links the #help: ooniprobe and miniooni binaries for linux/386. .PHONY: CLI/linux-static-386 CLI/linux-static-386: - go run ./internal/cmd/buildtool linux docker 386 + ./script/go.bash run ./internal/cmd/buildtool linux docker 386 #help: #help: The `make CLI/linux-static-amd64` command builds and statically links the #help: ooniprobe and miniooni binaries for linux/amd64. .PHONY: CLI/linux-static-amd64 CLI/linux-static-amd64: - go run ./internal/cmd/buildtool linux docker amd64 + ./script/go.bash run ./internal/cmd/buildtool linux docker amd64 #help: #help: The `make CLI/linux-static-armv6` command builds and statically links the #help: ooniprobe and miniooni binaries for linux/arm/v6. .PHONY: CLI/linux-static-armv6 CLI/linux-static-armv6: - go run ./internal/cmd/buildtool linux docker armv6 + ./script/go.bash run ./internal/cmd/buildtool linux docker armv6 #help: #help: The `make CLI/linux-static-armv7` command builds and statically links the #help: ooniprobe and miniooni binaries for linux/arm/v7. .PHONY: CLI/linux-static-armv7 CLI/linux-static-armv7: - go run ./internal/cmd/buildtool linux docker armv7 + ./script/go.bash run ./internal/cmd/buildtool linux docker armv7 #help: #help: The `make CLI/linux-static-arm64` command builds and statically links the #help: ooniprobe and miniooni binaries for linux/arm64. .PHONY: CLI/linux-static-arm64 CLI/linux-static-arm64: - go run ./internal/cmd/buildtool linux docker arm64 + ./script/go.bash run ./internal/cmd/buildtool linux docker arm64 #help: #help: The `make CLI/miniooni` command creates a build of miniooni, for the current #help: system, putting the binary in the top-level directory. .PHONY: CLI/miniooni CLI/miniooni: - go run ./internal/cmd/buildtool generic miniooni + ./script/go.bash run ./internal/cmd/buildtool generic miniooni #help: #help: The `make CLI/ooniprobe` command creates a build of ooniprobe, for the current #help: system, putting the binary in the top-level directory. .PHONY: CLI/ooniprobe CLI/ooniprobe: - go run ./internal/cmd/buildtool generic ooniprobe + ./script/go.bash run ./internal/cmd/buildtool generic ooniprobe #help: #help: The `make CLI/windows` command builds the ooniprobe and miniooni #help: command line clients for windows/386 and windows/amd64. .PHONY: CLI/windows CLI/windows: - go run ./internal/cmd/buildtool windows + ./script/go.bash run ./internal/cmd/buildtool windows #help: #help: The `make android` command builds the oonimkall library for Android #help: and compiles miniooni and ooniprobe for android CLI usage. .PHONY: android android: search/for/java - go run ./internal/cmd/buildtool android cdeps zlib openssl libevent tor - go run ./internal/cmd/buildtool android cli - go run ./internal/cmd/buildtool android gomobile + ./script/go.bash run ./internal/cmd/buildtool android cdeps zlib openssl libevent tor + ./script/go.bash run ./internal/cmd/buildtool android cli + ./script/go.bash run ./internal/cmd/buildtool android gomobile ./MOBILE/android/createpom #help: #help: The `make ios` command builds the oonimkall library for iOS. .PHONY: ios ios: search/for/zip search/for/xcode - go run ./internal/cmd/buildtool ios cdeps zlib openssl libevent tor - go run ./internal/cmd/buildtool ios gomobile + ./script/go.bash run ./internal/cmd/buildtool ios cdeps zlib openssl libevent tor + ./script/go.bash run ./internal/cmd/buildtool ios gomobile ./MOBILE/ios/make-extra-frameworks ./MOBILE/ios/zipframeworks ./MOBILE/ios/createpodspecs