From 208ffa253bac272b36c9441b4c38bcc1bb5de8f0 Mon Sep 17 00:00:00 2001 From: Simone Basso Date: Mon, 22 Aug 2022 11:50:58 +0200 Subject: [PATCH] fix: disable psiphon when building with go1.19 (#871) Part of https://github.com/ooni/probe/issues/2211. See also https://github.com/ooni/probe/issues/2222, which describes the issue we have with psiphon and go1.19. --- .github/workflows/alltests.yml | 2 +- .github/workflows/android.yml | 2 +- .github/workflows/generate.yml | 2 +- .github/workflows/go1.19.yml | 27 +++++++++++++++++++ .github/workflows/gosec.yml | 2 +- .github/workflows/ios.yml | 2 +- .github/workflows/jafar.yml | 2 +- .github/workflows/macos.yml | 2 +- .github/workflows/miniooni.yml | 2 +- .github/workflows/oohelperd.yml | 2 +- .github/workflows/qafbmessenger.yml | 2 +- .github/workflows/qahhfm.yml | 2 +- .github/workflows/qahirl.yml | 2 +- .github/workflows/qatelegram.yml | 2 +- .github/workflows/qawebconnectivity.yml | 2 +- .github/workflows/qawhatsapp.yml | 2 +- .github/workflows/tarball.yml | 2 +- .github/workflows/windows.yml | 2 +- Readme.md | 5 ++++ .../urlgetter/getter_integration_test.go | 4 +++ internal/tunnel/config.go | 15 ----------- internal/tunnel/psiphon.go | 17 +++++++++++- internal/tunnel/psiphon_go119.go | 19 +++++++++++++ internal/tunnel/psiphon_integration_test.go | 6 +++++ internal/tunnel/psiphon_test.go | 18 ++++++++++--- internal/tunnel/tunnel_test.go | 5 ++++ 26 files changed, 113 insertions(+), 37 deletions(-) create mode 100644 .github/workflows/go1.19.yml create mode 100644 internal/tunnel/psiphon_go119.go diff --git a/.github/workflows/alltests.yml b/.github/workflows/alltests.yml index a4fcf52..069c791 100644 --- a/.github/workflows/alltests.yml +++ b/.github/workflows/alltests.yml @@ -15,7 +15,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/android.yml b/.github/workflows/android.yml index 5815946..75aa02d 100644 --- a/.github/workflows/android.yml +++ b/.github/workflows/android.yml @@ -22,7 +22,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/generate.yml b/.github/workflows/generate.yml index 6572ee6..7ebcd0b 100644 --- a/.github/workflows/generate.yml +++ b/.github/workflows/generate.yml @@ -15,7 +15,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/go1.19.yml b/.github/workflows/go1.19.yml new file mode 100644 index 0000000..0e6e6c8 --- /dev/null +++ b/.github/workflows/go1.19.yml @@ -0,0 +1,27 @@ +# Interim build script checking for go1.19 +# +# Psiphon not working with go1.19: TODO(https://github.com/ooni/probe/issues/2222) +# +name: go1.19 +on: + pull_request: + push: + branches: + - "master" + - "release/**" + +jobs: + build_and_test: + runs-on: ubuntu-20.04 + + steps: + - uses: actions/checkout@v2 + + - run: go install golang.org/dl/go1.19@latest + + - run: $(go env GOPATH)/bin/go1.19 download + + - run: $(go env GOPATH)/bin/go1.19 build -v ./... + + - run: $(go env GOPATH)/bin/go1.19 test -short -race -tags shaping ./... + diff --git a/.github/workflows/gosec.yml b/.github/workflows/gosec.yml index 4b588dc..1c442ea 100644 --- a/.github/workflows/gosec.yml +++ b/.github/workflows/gosec.yml @@ -19,7 +19,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/ios.yml b/.github/workflows/ios.yml index 55dccab..4da0a2f 100644 --- a/.github/workflows/ios.yml +++ b/.github/workflows/ios.yml @@ -22,7 +22,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/jafar.yml b/.github/workflows/jafar.yml index c048b91..66225ee 100644 --- a/.github/workflows/jafar.yml +++ b/.github/workflows/jafar.yml @@ -15,7 +15,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/macos.yml b/.github/workflows/macos.yml index 339dcca..542d925 100644 --- a/.github/workflows/macos.yml +++ b/.github/workflows/macos.yml @@ -22,7 +22,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/miniooni.yml b/.github/workflows/miniooni.yml index d1a1638..b6e4f1c 100644 --- a/.github/workflows/miniooni.yml +++ b/.github/workflows/miniooni.yml @@ -27,7 +27,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/oohelperd.yml b/.github/workflows/oohelperd.yml index 0ea5d7b..b6135b6 100644 --- a/.github/workflows/oohelperd.yml +++ b/.github/workflows/oohelperd.yml @@ -19,7 +19,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/qafbmessenger.yml b/.github/workflows/qafbmessenger.yml index dbeda34..0e8d499 100644 --- a/.github/workflows/qafbmessenger.yml +++ b/.github/workflows/qafbmessenger.yml @@ -15,7 +15,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/qahhfm.yml b/.github/workflows/qahhfm.yml index 3f41cc8..477fd61 100644 --- a/.github/workflows/qahhfm.yml +++ b/.github/workflows/qahhfm.yml @@ -15,7 +15,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/qahirl.yml b/.github/workflows/qahirl.yml index 8d1c90b..b3eb70f 100644 --- a/.github/workflows/qahirl.yml +++ b/.github/workflows/qahirl.yml @@ -15,7 +15,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/qatelegram.yml b/.github/workflows/qatelegram.yml index 951a5b5..22a73c1 100644 --- a/.github/workflows/qatelegram.yml +++ b/.github/workflows/qatelegram.yml @@ -15,7 +15,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/qawebconnectivity.yml b/.github/workflows/qawebconnectivity.yml index 808884f..57266ab 100644 --- a/.github/workflows/qawebconnectivity.yml +++ b/.github/workflows/qawebconnectivity.yml @@ -15,7 +15,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/qawhatsapp.yml b/.github/workflows/qawhatsapp.yml index db88e32..fc17cda 100644 --- a/.github/workflows/qawhatsapp.yml +++ b/.github/workflows/qawhatsapp.yml @@ -15,7 +15,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/tarball.yml b/.github/workflows/tarball.yml index 48118ea..895fb27 100644 --- a/.github/workflows/tarball.yml +++ b/.github/workflows/tarball.yml @@ -21,7 +21,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/.github/workflows/windows.yml b/.github/workflows/windows.yml index a9b1024..c3f8b3b 100644 --- a/.github/workflows/windows.yml +++ b/.github/workflows/windows.yml @@ -19,7 +19,7 @@ jobs: id: goversion run: echo ::set-output name=version::$(cat GOVERSION) - - uses: actions/setup-go@v1 + - uses: actions/setup-go@v3 with: go-version: "${{ steps.goversion.outputs.version }}" diff --git a/Readme.md b/Readme.md index e484a68..3fb8305 100644 --- a/Readme.md +++ b/Readme.md @@ -57,6 +57,11 @@ Be sure you have: 2. a C compiler (Mingw-w64 for Windows). +### Caveats + +As of 2022-08-22, building with go1.19 will not include [Psiphon](https://psiphon.ca/) as +a dependency. Fixing this issue is TODO(https://github.com/ooni/probe/issues/2222). + ### ooniprobe Ooniprobe is the official CLI client. Compile using: diff --git a/internal/engine/experiment/urlgetter/getter_integration_test.go b/internal/engine/experiment/urlgetter/getter_integration_test.go index 2998635..b58258c 100644 --- a/internal/engine/experiment/urlgetter/getter_integration_test.go +++ b/internal/engine/experiment/urlgetter/getter_integration_test.go @@ -4,6 +4,7 @@ import ( "context" "errors" "net/http" + "runtime" "strings" "testing" @@ -275,6 +276,9 @@ func TestGetterWithCancelledContextNoFollowRedirects(t *testing.T) { } func TestGetterWithCancelledContextCannotStartTunnel(t *testing.T) { + if strings.HasPrefix(runtime.Version(), "go1.19") { + t.Skip("TODO(https://github.com/ooni/probe/issues/2222)") + } ctx, cancel := context.WithCancel(context.Background()) cancel() // fail immediately g := urlgetter.Getter{ diff --git a/internal/tunnel/config.go b/internal/tunnel/config.go index 75bfc65..7b1cf11 100644 --- a/internal/tunnel/config.go +++ b/internal/tunnel/config.go @@ -10,7 +10,6 @@ import ( "github.com/cretz/bine/control" "github.com/cretz/bine/tor" "github.com/ooni/probe-cli/v3/internal/model" - "github.com/ooni/psiphon/tunnel-core/ClientLibrary/clientlib" "golang.org/x/sys/execabs" ) @@ -60,10 +59,6 @@ type Config struct { // testSocks5New allows us to mock socks5.New in testing code. testSocks5New func(conf *socks5.Config) (*socks5.Server, error) - // testStartPsiphon allows us to mock psiphon's clientlib.StartTunnel. - testStartPsiphon func(ctx context.Context, config []byte, - workdir string) (*clientlib.PsiphonTunnel, error) - // testTorStart allows us to mock tor.Start. testTorStart func(ctx context.Context, conf *tor.StartConf) (*tor.Tor, error) @@ -119,16 +114,6 @@ func (c *Config) socks5New(conf *socks5.Config) (*socks5.Server, error) { return socks5.New(conf) } -// startPsiphon calls either testStartPsiphon or psiphon's clientlib.StartTunnel. -func (c *Config) startPsiphon(ctx context.Context, config []byte, - workdir string) (*clientlib.PsiphonTunnel, error) { - if c.testStartPsiphon != nil { - return c.testStartPsiphon(ctx, config, workdir) - } - return clientlib.StartTunnel(ctx, config, "", clientlib.Parameters{ - DataRootDirectory: &workdir}, nil, nil) -} - // ooniTorBinaryEnv is the name of the environment variable // we're using to get the path to the tor binary when we are // being run by the ooni/probe-desktop application. diff --git a/internal/tunnel/psiphon.go b/internal/tunnel/psiphon.go index 13b4ea9..2c37dc7 100644 --- a/internal/tunnel/psiphon.go +++ b/internal/tunnel/psiphon.go @@ -1,5 +1,13 @@ +//go:build !go1.19 + package tunnel +// +// Psiphon not working with go1.19 +// +// TODO(https://github.com/ooni/probe/issues/2222) +// + import ( "context" "fmt" @@ -11,6 +19,13 @@ import ( "github.com/ooni/psiphon/tunnel-core/ClientLibrary/clientlib" ) +// mockableStartPsiphon allows us to test for psiphon startup failures. +var mockableStartPsiphon = func( + ctx context.Context, config []byte, workdir string) (*clientlib.PsiphonTunnel, error) { + return clientlib.StartTunnel(ctx, config, "", clientlib.Parameters{ + DataRootDirectory: &workdir}, nil, nil) +} + // psiphonTunnel is a psiphon tunnel type psiphonTunnel struct { // bootstrapTime is the bootstrapTime of the bootstrap @@ -53,7 +68,7 @@ func psiphonStart(ctx context.Context, config *Config) (Tunnel, DebugInfo, error return nil, debugInfo, err } start := time.Now() - tunnel, err := config.startPsiphon(ctx, configJSON, workdir) + tunnel, err := mockableStartPsiphon(ctx, configJSON, workdir) if err != nil { return nil, debugInfo, err } diff --git a/internal/tunnel/psiphon_go119.go b/internal/tunnel/psiphon_go119.go new file mode 100644 index 0000000..c90d537 --- /dev/null +++ b/internal/tunnel/psiphon_go119.go @@ -0,0 +1,19 @@ +//go:build go1.19 + +package tunnel + +// +// Psiphon not working with go1.19: TODO(https://github.com/ooni/probe/issues/2222) +// + +import ( + "context" + "errors" +) + +// psiphonStart starts the psiphon tunnel. +func psiphonStart(ctx context.Context, config *Config) (Tunnel, DebugInfo, error) { + return nil, DebugInfo{}, errors.New( + "psiphon is disabled when building with go1.19: see https://github.com/ooni/probe/issues/2222 for more information", + ) +} diff --git a/internal/tunnel/psiphon_integration_test.go b/internal/tunnel/psiphon_integration_test.go index 40e680c..4c58431 100644 --- a/internal/tunnel/psiphon_integration_test.go +++ b/internal/tunnel/psiphon_integration_test.go @@ -1,5 +1,11 @@ +//go:build !go1.19 + package tunnel_test +// +// Psiphon not working with go1.19: TODO(https://github.com/ooni/probe/issues/2222) +// + import ( "context" "io/ioutil" diff --git a/internal/tunnel/psiphon_test.go b/internal/tunnel/psiphon_test.go index 63e1521..451356e 100644 --- a/internal/tunnel/psiphon_test.go +++ b/internal/tunnel/psiphon_test.go @@ -1,5 +1,11 @@ +//go:build !go1.19 + package tunnel +// +// Psiphon not working with go1.19: TODO(https://github.com/ooni/probe/issues/2222) +// + import ( "context" "errors" @@ -82,13 +88,17 @@ func TestPsiphonStartFailure(t *testing.T) { sess := &MockableSession{ Result: []byte(`{}`), } + oldStartPsiphon := mockableStartPsiphon + defer func() { + mockableStartPsiphon = oldStartPsiphon + }() + mockableStartPsiphon = func(ctx context.Context, config []byte, + workdir string) (*clientlib.PsiphonTunnel, error) { + return nil, expected + } tunnel, _, err := psiphonStart(context.Background(), &Config{ Session: sess, TunnelDir: "testdata", - testStartPsiphon: func(ctx context.Context, config []byte, - workdir string) (*clientlib.PsiphonTunnel, error) { - return nil, expected - }, }) if !errors.Is(err, expected) { t.Fatal("not the error we expected") diff --git a/internal/tunnel/tunnel_test.go b/internal/tunnel/tunnel_test.go index 4122ca4..1736cdd 100644 --- a/internal/tunnel/tunnel_test.go +++ b/internal/tunnel/tunnel_test.go @@ -3,6 +3,8 @@ package tunnel_test import ( "context" "errors" + "runtime" + "strings" "testing" "github.com/ooni/probe-cli/v3/internal/tunnel" @@ -23,6 +25,9 @@ func TestStartNoTunnel(t *testing.T) { } func TestStartPsiphonWithCancelledContext(t *testing.T) { + if strings.HasPrefix(runtime.Version(), "go1.19") { + t.Skip("TODO(https://github.com/ooni/probe/issues/2222)") + } ctx, cancel := context.WithCancel(context.Background()) cancel() // fail immediately tun, _, err := tunnel.Start(ctx, &tunnel.Config{