fix(probeservices): use api.ooni.io (#926)

See https://github.com/ooni/probe/issues/2147.

Note that this PR also tries to reduce usage of legacy names inside unit/integration tests.
This commit is contained in:
Simone Basso 2022-09-02 16:48:14 +02:00 committed by GitHub
parent 535be51cd1
commit 7df25795c0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
12 changed files with 35 additions and 76 deletions

View File

@ -6,7 +6,7 @@
# #
set -e set -e
backends=() backends=()
backends+=( "https://ps1.ooni.io" ) backends+=( "https://api.ooni.io" )
backends+=( "https://dvp6h0xblpcqp.cloudfront.net" ) backends+=( "https://dvp6h0xblpcqp.cloudfront.net" )
backends+=( "https://ams-pg-test.ooni.org" ) backends+=( "https://ams-pg-test.ooni.org" )
miniooni="${1:-./miniooni}" miniooni="${1:-./miniooni}"

View File

@ -50,8 +50,6 @@ def assert_status_flags_are(ooni_exe, tk, desired):
def webconnectivity_https_ok_with_control_failure(ooni_exe, outfile): def webconnectivity_https_ok_with_control_failure(ooni_exe, outfile):
"""Successful HTTPS measurement but control failure.""" """Successful HTTPS measurement but control failure."""
args = [ args = [
"-iptables-reset-keyword",
"wcth.ooni.io",
"-iptables-reset-keyword", "-iptables-reset-keyword",
"th.ooni.org", "th.ooni.org",
] ]
@ -83,8 +81,6 @@ def webconnectivity_https_ok_with_control_failure(ooni_exe, outfile):
def webconnectivity_http_ok_with_control_failure(ooni_exe, outfile): def webconnectivity_http_ok_with_control_failure(ooni_exe, outfile):
"""Successful HTTP measurement but control failure.""" """Successful HTTP measurement but control failure."""
args = [ args = [
"-iptables-reset-keyword",
"wcth.ooni.io",
"-iptables-reset-keyword", "-iptables-reset-keyword",
"th.ooni.org", "th.ooni.org",
] ]
@ -194,8 +190,6 @@ def webconnectivity_control_unreachable_and_using_http(ooni_exe, outfile):
plaintext HTTP protocol rather than HTTPS""" plaintext HTTP protocol rather than HTTPS"""
args = [] args = []
args.append("-iptables-reset-keyword") args.append("-iptables-reset-keyword")
args.append("wcth.ooni.io")
args.append("-iptables-reset-keyword")
args.append("th.ooni.org") args.append("th.ooni.org")
tk = execute_jafar_and_return_validated_test_keys( tk = execute_jafar_and_return_validated_test_keys(
ooni_exe, ooni_exe,
@ -224,7 +218,7 @@ def webconnectivity_nonexistent_domain(ooni_exe, outfile):
tk = execute_jafar_and_return_validated_test_keys( tk = execute_jafar_and_return_validated_test_keys(
ooni_exe, ooni_exe,
outfile, outfile,
"-i http://antani.ooni.io web_connectivity", "-i http://www.ooni.nonexistent web_connectivity",
"webconnectivity_nonexistent_domain", "webconnectivity_nonexistent_domain",
args, args,
) )

View File

@ -29,7 +29,7 @@ func newclient() probeservices.Client {
ua := fmt.Sprintf("apitool/%s ooniprobe-engine/%s", version.Version, version.Version) ua := fmt.Sprintf("apitool/%s ooniprobe-engine/%s", version.Version, version.Version)
return probeservices.Client{ return probeservices.Client{
APIClientTemplate: httpx.APIClientTemplate{ APIClientTemplate: httpx.APIClientTemplate{
BaseURL: "https://ams-pg.ooni.org/", BaseURL: "https://api.ooni.io/",
HTTPClient: &http.Client{Transport: txp}, HTTPClient: &http.Client{Transport: txp},
Logger: log.Log, Logger: log.Log,
UserAgent: ua, UserAgent: ua,

View File

@ -25,7 +25,7 @@ func TestBlock(t *testing.T) {
// Here we're filtering any domain containing ooni.io, so we // Here we're filtering any domain containing ooni.io, so we
// expect the proxy to send 451 without actually proxing, thus // expect the proxy to send 451 without actually proxing, thus
// there should not be any Via header in the output. // there should not be any Via header in the output.
checkrequest(t, addr.String(), "mia-ps.ooni.io", 451, false) checkrequest(t, addr.String(), "api.ooni.io", 451, false)
killproxy(t, server) killproxy(t, server)
} }

View File

@ -21,7 +21,7 @@ func TestPass(t *testing.T) {
func TestBlock(t *testing.T) { func TestBlock(t *testing.T) {
listener := newproxy(t, "ooni.io") listener := newproxy(t, "ooni.io")
checkdialtls(t, listener.Addr().String(), false, &tls.Config{ checkdialtls(t, listener.Addr().String(), false, &tls.Config{
ServerName: "mia-ps.ooni.io", ServerName: "api.ooni.io",
}) })
killproxy(t, listener) killproxy(t, listener)
} }

View File

@ -86,7 +86,7 @@ func TestOOClientDoWithEmptyServerURL(t *testing.T) {
func TestOOClientDoWithInvalidTargetURL(t *testing.T) { func TestOOClientDoWithInvalidTargetURL(t *testing.T) {
ctx := context.Background() ctx := context.Background()
config := internal.OOConfig{TargetURL: "\t", ServerURL: "https://wcth.ooni.io"} config := internal.OOConfig{TargetURL: "\t", ServerURL: "https://0.th.ooni.org"}
clnt := internal.OOClient{} clnt := internal.OOClient{}
cresp, err := clnt.Do(ctx, config) cresp, err := clnt.Do(ctx, config)
if !errors.Is(err, internal.ErrInvalidURL) { if !errors.Is(err, internal.ErrInvalidURL) {
@ -104,7 +104,7 @@ func TestOOClientDoWithResolverFailure(t *testing.T) {
ctx := context.Background() ctx := context.Background()
config := internal.OOConfig{ config := internal.OOConfig{
TargetURL: "http://www.example.com", TargetURL: "http://www.example.com",
ServerURL: "https://wcth.ooni.io", ServerURL: "https://0.th.ooni.org",
} }
clnt := internal.OOClient{ clnt := internal.OOClient{
HTTPClient: http.DefaultClient, HTTPClient: http.DefaultClient,
@ -114,10 +114,12 @@ func TestOOClientDoWithResolverFailure(t *testing.T) {
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
} }
if len(cresp.TCPConnect) > 0 { if len(cresp.TCPConnect) <= 0 {
// The current implementation of the test helper (the legacy codebase) // The legacy implementation of the test helper (the legacy codebase)
// only follows the IP addresses returned by the client. // only follows the IP addresses returned by the client. However, since
t.Fatal("expected empty TCPConnect here") // https://github.com/ooni/probe-cli/pull/890, the TH is following the
// IP addresses from the probe as well as its own addresses.
t.Fatal("expected non-empty TCPConnect here")
} }
if cresp.HTTPRequest.StatusCode != 200 { if cresp.HTTPRequest.StatusCode != 200 {
t.Fatal("expected 200 status code here") t.Fatal("expected 200 status code here")
@ -131,7 +133,7 @@ func TestOOClientDoWithUnsupportedExplicitPort(t *testing.T) {
ctx := context.Background() ctx := context.Background()
config := internal.OOConfig{ config := internal.OOConfig{
TargetURL: "http://www.example.com:8080", TargetURL: "http://www.example.com:8080",
ServerURL: "https://wcth.ooni.io", ServerURL: "https://0.th.ooni.org",
} }
clnt := internal.OOClient{ clnt := internal.OOClient{
Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}), Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}),
@ -168,7 +170,7 @@ func TestOOClientDoWithRoundTripError(t *testing.T) {
ctx := context.Background() ctx := context.Background()
config := internal.OOConfig{ config := internal.OOConfig{
TargetURL: "http://www.example.com", TargetURL: "http://www.example.com",
ServerURL: "https://wcth.ooni.io", ServerURL: "https://0.th.ooni.org",
} }
clnt := internal.OOClient{ clnt := internal.OOClient{
Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}), Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}),
@ -189,7 +191,7 @@ func TestOOClientDoWithInvalidStatusCode(t *testing.T) {
ctx := context.Background() ctx := context.Background()
config := internal.OOConfig{ config := internal.OOConfig{
TargetURL: "http://www.example.com", TargetURL: "http://www.example.com",
ServerURL: "https://wcth.ooni.io", ServerURL: "https://0.th.ooni.org",
} }
clnt := internal.OOClient{ clnt := internal.OOClient{
Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}), Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}),
@ -214,7 +216,7 @@ func TestOOClientDoWithBodyReadError(t *testing.T) {
ctx := context.Background() ctx := context.Background()
config := internal.OOConfig{ config := internal.OOConfig{
TargetURL: "http://www.example.com", TargetURL: "http://www.example.com",
ServerURL: "https://wcth.ooni.io", ServerURL: "https://0.th.ooni.org",
} }
clnt := internal.OOClient{ clnt := internal.OOClient{
Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}), Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}),
@ -240,7 +242,7 @@ func TestOOClientDoWithInvalidJSON(t *testing.T) {
ctx := context.Background() ctx := context.Background()
config := internal.OOConfig{ config := internal.OOConfig{
TargetURL: "http://www.example.com", TargetURL: "http://www.example.com",
ServerURL: "https://wcth.ooni.io", ServerURL: "https://0.th.ooni.org",
} }
clnt := internal.OOClient{ clnt := internal.OOClient{
Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}), Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}),
@ -290,7 +292,7 @@ func TestOOClientDoWithParseableJSON(t *testing.T) {
ctx := context.Background() ctx := context.Background()
config := internal.OOConfig{ config := internal.OOConfig{
TargetURL: "http://www.example.com", TargetURL: "http://www.example.com",
ServerURL: "https://wcth.ooni.io", ServerURL: "https://0.th.ooni.org",
} }
clnt := internal.OOClient{ clnt := internal.OOClient{
Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}), Resolver: internal.NewFakeResolverWithResult([]string{"1.1.1.1"}),

View File

@ -49,7 +49,7 @@ func main() {
func wcth() interface{} { func wcth() interface{} {
serverURL := *server serverURL := *server
if serverURL == "" { if serverURL == "" {
serverURL = "https://wcth.ooni.io/" serverURL = "https://0.th.ooni.org/"
} }
clnt := internal.OOClient{HTTPClient: httpClient, Resolver: resolver} clnt := internal.OOClient{HTTPClient: httpClient, Resolver: resolver}
config := internal.OOConfig{TargetURL: *target, ServerURL: serverURL} config := internal.OOConfig{TargetURL: *target, ServerURL: serverURL}

View File

@ -67,7 +67,7 @@ func TestDNSDo(t *testing.T) {
t.Run("returns non-nil addresses list on nxdomin", func(t *testing.T) { t.Run("returns non-nil addresses list on nxdomin", func(t *testing.T) {
ctx := context.Background() ctx := context.Background()
config := &dnsConfig{ config := &dnsConfig{
Domain: "antani.ooni.org", Domain: "www.ooni.nonexistent",
Logger: model.DiscardLogger, Logger: model.DiscardLogger,
NewResolver: func(model.Logger) model.Resolver { NewResolver: func(model.Logger) model.Resolver {
return &mocks.Resolver{ return &mocks.Resolver{

View File

@ -10,10 +10,7 @@ import (
// Default returns the default probe services // Default returns the default probe services
func Default() []model.OOAPIService { func Default() []model.OOAPIService {
return []model.OOAPIService{{ return []model.OOAPIService{{
Address: "https://ps1.ooni.io", Address: "https://api.ooni.io",
Type: "https",
}, {
Address: "https://ps2.ooni.io",
Type: "https", Type: "https",
}, { }, {
Front: "dkyhjv0wpi2dk.cloudfront.net", Front: "dkyhjv0wpi2dk.cloudfront.net",

View File

@ -5,7 +5,6 @@ import (
"errors" "errors"
"io" "io"
"net/http" "net/http"
"regexp"
"strings" "strings"
"testing" "testing"
"time" "time"
@ -399,31 +398,24 @@ func TestTryAllIntegrationWeRaceForFastestHTTPS(t *testing.T) {
if testing.Short() { if testing.Short() {
t.Skip("skip test in short mode") t.Skip("skip test in short mode")
} }
const pattern = "^https://ps[1-4].ooni.io$"
// put onion first so we also verify that we sort the endpoints // put onion first so we also verify that we sort the endpoints
in := []model.OOAPIService{{ in := []model.OOAPIService{{
Type: "onion", Type: "onion",
Address: "httpo://jehhrikjjqrlpufu.onion", Address: "httpo://jehhrikjjqrlpufu.onion",
}, { }, {
Type: "https", Type: "https",
Address: "https://ps1.ooni.io", Address: "https://api.ooni.io",
}, {
Type: "https",
Address: "https://ps2.ooni.io",
}, { }, {
Front: "dkyhjv0wpi2dk.cloudfront.net", Front: "dkyhjv0wpi2dk.cloudfront.net",
Type: "cloudfront", Type: "cloudfront",
Address: "https://dkyhjv0wpi2dk.cloudfront.net", Address: "https://dkyhjv0wpi2dk.cloudfront.net",
}, {
Type: "https",
Address: "https://ps3.ooni.io",
}} }}
sess := &mockable.Session{ sess := &mockable.Session{
MockableHTTPClient: http.DefaultClient, MockableHTTPClient: http.DefaultClient,
MockableLogger: log.Log, MockableLogger: log.Log,
} }
out := probeservices.TryAll(context.Background(), sess, in) out := probeservices.TryAll(context.Background(), sess, in)
if len(out) != 3 { if len(out) != 1 {
t.Fatal("invalid number of entries") t.Fatal("invalid number of entries")
} }
// //
@ -436,34 +428,8 @@ func TestTryAllIntegrationWeRaceForFastestHTTPS(t *testing.T) {
if out[0].Endpoint.Type != "https" { if out[0].Endpoint.Type != "https" {
t.Fatal("invalid endpoint type") t.Fatal("invalid endpoint type")
} }
if ok, _ := regexp.MatchString(pattern, out[0].Endpoint.Address); !ok { if out[0].Endpoint.Address != "https://api.ooni.io" {
t.Fatal("invalid endpoint type") t.Fatal("invalid endpoint address")
}
//
if out[1].Duration <= 0 {
t.Fatal("invalid duration")
}
if out[1].Err != nil {
t.Fatal("invalid error")
}
if out[1].Endpoint.Type != "https" {
t.Fatal("invalid endpoint type")
}
if ok, _ := regexp.MatchString(pattern, out[1].Endpoint.Address); !ok {
t.Fatal("invalid endpoint type")
}
//
if out[2].Duration <= 0 {
t.Fatal("invalid duration")
}
if out[2].Err != nil {
t.Fatal("invalid error")
}
if out[2].Endpoint.Type != "https" {
t.Fatal("invalid endpoint type")
}
if ok, _ := regexp.MatchString(pattern, out[2].Endpoint.Address); !ok {
t.Fatal("invalid endpoint type")
} }
} }
@ -574,32 +540,32 @@ func TestSelectBestSelectsTheFastest(t *testing.T) {
in := []*probeservices.Candidate{{ in := []*probeservices.Candidate{{
Duration: 10 * time.Millisecond, Duration: 10 * time.Millisecond,
Endpoint: model.OOAPIService{ Endpoint: model.OOAPIService{
Address: "https://ps1.ooni.io", Address: "https://ps1.ooni.nonexistent",
Type: "https", Type: "https",
}, },
}, { }, {
Duration: 4 * time.Millisecond, Duration: 4 * time.Millisecond,
Endpoint: model.OOAPIService{ Endpoint: model.OOAPIService{
Address: "https://ps2.ooni.io", Address: "https://ps2.ooni.nonexistent",
Type: "https", Type: "https",
}, },
}, { }, {
Duration: 7 * time.Millisecond, Duration: 7 * time.Millisecond,
Endpoint: model.OOAPIService{ Endpoint: model.OOAPIService{
Address: "https://ps3.ooni.io", Address: "https://ps3.ooni.nonexistent",
Type: "https", Type: "https",
}, },
}, { }, {
Duration: 11 * time.Millisecond, Duration: 11 * time.Millisecond,
Endpoint: model.OOAPIService{ Endpoint: model.OOAPIService{
Address: "https://ps4.ooni.io", Address: "https://ps4.ooni.nonexistent",
Type: "https", Type: "https",
}, },
}} }}
expected := &probeservices.Candidate{ expected := &probeservices.Candidate{
Duration: 4 * time.Millisecond, Duration: 4 * time.Millisecond,
Endpoint: model.OOAPIService{ Endpoint: model.OOAPIService{
Address: "https://ps2.ooni.io", Address: "https://ps2.ooni.nonexistent",
Type: "https", Type: "https",
}, },
} }

View File

@ -133,7 +133,7 @@ func TestLittleLLookupHostWithSuccess(t *testing.T) {
}, },
} }
ctx := context.Background() ctx := context.Background()
ri := &resolverinfo{URL: "dot://dns-nonexistent.ooni.org", Score: 0.1} ri := &resolverinfo{URL: "dot://www.ooni.nonexistent", Score: 0.1}
addrs, err := reso.lookupHost(ctx, ri, "dns.google") addrs, err := reso.lookupHost(ctx, ri, "dns.google")
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
@ -159,7 +159,7 @@ func TestLittleLLookupHostWithFailure(t *testing.T) {
}, },
} }
ctx := context.Background() ctx := context.Background()
ri := &resolverinfo{URL: "dot://dns-nonexistent.ooni.org", Score: 0.95} ri := &resolverinfo{URL: "dot://www.ooni.nonexistent", Score: 0.95}
addrs, err := reso.lookupHost(ctx, ri, "dns.google") addrs, err := reso.lookupHost(ctx, ri, "dns.google")
if !errors.Is(err, errMocked) { if !errors.Is(err, errMocked) {
t.Fatal("not the error we expected", err) t.Fatal("not the error we expected", err)

View File

@ -57,7 +57,7 @@ func TestMeasureWithSystemResolver(t *testing.T) {
r := netxlite.NewStdlibResolver(log.Log) r := netxlite.NewStdlibResolver(log.Log)
defer r.CloseIdleConnections() defer r.CloseIdleConnections()
ctx := context.Background() ctx := context.Background()
addrs, err := r.LookupHost(ctx, "antani.ooni.org") addrs, err := r.LookupHost(ctx, "www.ooni.nonexistent")
if err == nil || err.Error() != netxlite.FailureDNSNXDOMAINError { if err == nil || err.Error() != netxlite.FailureDNSNXDOMAINError {
t.Fatal("not the error we expected", err) t.Fatal("not the error we expected", err)
} }
@ -75,7 +75,7 @@ func TestMeasureWithSystemResolver(t *testing.T) {
// Implementation note: Windows' resolver has caching so back to back tests // Implementation note: Windows' resolver has caching so back to back tests
// will fail unless we query for something that could bypass the cache itself // will fail unless we query for something that could bypass the cache itself
// e.g. a domain containing a few random letters // e.g. a domain containing a few random letters
addrs, err := r.LookupHost(ctx, randx.Letters(7)+".ooni.org") addrs, err := r.LookupHost(ctx, randx.Letters(7)+".ooni.nonexistent")
if err == nil || err.Error() != netxlite.FailureGenericTimeoutError { if err == nil || err.Error() != netxlite.FailureGenericTimeoutError {
t.Fatal("not the error we expected", err) t.Fatal("not the error we expected", err)
} }