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:
parent
535be51cd1
commit
7df25795c0
|
@ -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}"
|
||||||
|
|
|
@ -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,
|
||||||
)
|
)
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
|
@ -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"}),
|
||||||
|
|
|
@ -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}
|
||||||
|
|
|
@ -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{
|
||||||
|
|
|
@ -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",
|
||||||
|
|
|
@ -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",
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user