From b4d03b59d8f98d9734594f5fd07559d1458b2577 Mon Sep 17 00:00:00 2001 From: Simone Basso Date: Fri, 1 Dec 2023 01:52:15 +0100 Subject: [PATCH] feat: make sure LTE and v0.4 emit the same test keys (#1392) This diff switches LTE to use the classic "engine", removes restrictions regarding comparing test keys, and ensures with the existing test suite that LTE and v0.4 produce the same top-level test keys under the same conditions. While there, let's also bump LTE's version number, lest we forget. See https://github.com/ooni/probe/issues/2634 --- .../webconnectivitylte/analysisclassic.go | 50 +++++++++++++++++-- .../webconnectivitylte/analysiscore.go | 2 +- .../webconnectivitylte/analysishttpcore.go | 5 +- .../experiment/webconnectivitylte/measurer.go | 2 +- .../experiment/webconnectivitylte/testkeys.go | 8 ++- .../experiment/webconnectivityqa/badssl.go | 8 +-- .../experiment/webconnectivityqa/control.go | 4 +- .../webconnectivityqa/dnsblocking.go | 5 +- .../webconnectivityqa/dnshijacking.go | 4 +- .../experiment/webconnectivityqa/httpdiff.go | 6 +-- .../experiment/webconnectivityqa/redirect.go | 12 ++--- .../experiment/webconnectivityqa/run_test.go | 13 +++-- .../experiment/webconnectivityqa/success.go | 2 +- .../webconnectivityqa/tcpblocking.go | 2 +- .../experiment/webconnectivityqa/testkeys.go | 9 ++-- .../webconnectivityqa/websitedown.go | 4 +- 16 files changed, 91 insertions(+), 45 deletions(-) diff --git a/internal/experiment/webconnectivitylte/analysisclassic.go b/internal/experiment/webconnectivitylte/analysisclassic.go index 937054e153..ca0e8594fd 100644 --- a/internal/experiment/webconnectivitylte/analysisclassic.go +++ b/internal/experiment/webconnectivitylte/analysisclassic.go @@ -41,10 +41,16 @@ func (tk *TestKeys) analysisClassic(logger model.Logger) { // 4. determine the DNS consistency tk.DNSConsistency = analysisClassicDNSConsistency(woa) - // 5. compute the HTTPDiff values + // 5. set DNSExperimentFailure + if !woa.DNSExperimentFailure.IsNone() && woa.DNSExperimentFailure.Unwrap() != "" { + value := woa.DNSExperimentFailure.Unwrap() + tk.DNSExperimentFailure = &value + } + + // 6. compute the HTTPDiff values tk.setHTTPDiffValues(woa) - // 6. compute blocking & accessible + // 7. compute blocking & accessible analysisClassicComputeBlockingAccessible(woa, tk) } @@ -68,7 +74,8 @@ func analysisClassicDNSConsistency(woa *minipipeline.WebAnalysis) optional.Value func (tk *TestKeys) setHTTPDiffValues(woa *minipipeline.WebAnalysis) { const bodyProportionFactor = 0.7 if !woa.HTTPFinalResponseDiffBodyProportionFactor.IsNone() { - value := woa.HTTPFinalResponseDiffBodyProportionFactor.Unwrap() > bodyProportionFactor + tk.BodyProportion = woa.HTTPFinalResponseDiffBodyProportionFactor.Unwrap() + value := tk.BodyProportion > bodyProportionFactor tk.BodyLengthMatch = &value } @@ -89,6 +96,9 @@ func (tk *TestKeys) setHTTPDiffValues(woa *minipipeline.WebAnalysis) { } type analysisClassicTestKeysProxy interface { + // httpDiff returns true if there's an http-diff. + httpDiff() bool + // setBlockingString sets blocking to a string. setBlockingString(value string) @@ -98,8 +108,8 @@ type analysisClassicTestKeysProxy interface { // setBlockingFalse sets Blocking to false. setBlockingFalse() - // httpDiff returns true if there's an http-diff. - httpDiff() bool + // setHTTPExperimentFailure sets the HTTPExperimentFailure field. + setHTTPExperimentFailure(value optional.Value[string]) } var _ analysisClassicTestKeysProxy = &TestKeys{} @@ -148,6 +158,11 @@ func (tk *TestKeys) setBlockingString(value string) { tk.Accessible = false } +// setHTTPExperimentFailure implements analysisClassicTestKeysProxy. +func (tk *TestKeys) setHTTPExperimentFailure(value optional.Value[string]) { + tk.HTTPExperimentFailure = value +} + func analysisClassicComputeBlockingAccessible(woa *minipipeline.WebAnalysis, tk analysisClassicTestKeysProxy) { // minipipeline.NewLinearWebAnalysis produces a woa.Linear sorted // @@ -217,6 +232,7 @@ func analysisClassicComputeBlockingAccessible(woa *minipipeline.WebAnalysis, tk // the control server is unreachable or blocked. if entry.ControlHTTPFailure.IsNone() { tk.setBlockingNil() + tk.setHTTPExperimentFailure(entry.Failure) return } @@ -226,11 +242,13 @@ func analysisClassicComputeBlockingAccessible(woa *minipipeline.WebAnalysis, tk // should also set Accessible to false. However, v0.4 // does this and we should play along for the A/B testing. tk.setBlockingFalse() + tk.setHTTPExperimentFailure(entry.Failure) return } // 2.3. Handle the case where just the probe failed. tk.setBlockingString("http-failure") + tk.setHTTPExperimentFailure(entry.Failure) return } @@ -248,11 +266,13 @@ func analysisClassicComputeBlockingAccessible(woa *minipipeline.WebAnalysis, tk // the control accessing the website and telling us. if entry.ControlHTTPFailure.IsNone() { tk.setBlockingNil() + tk.setHTTPExperimentFailure(entry.Failure) return } // 3.1.2. Otherwise, if the control worked, that's blocking. tk.setBlockingString("http-failure") + tk.setHTTPExperimentFailure(entry.Failure) return } @@ -262,11 +282,13 @@ func analysisClassicComputeBlockingAccessible(woa *minipipeline.WebAnalysis, tk // should set Accessible and Blocking to false. However, v0.4 // does this and we should play along for the A/B testing. tk.setBlockingNil() + tk.setHTTPExperimentFailure(entry.Failure) return } // 3.3. Handle the case where just the probe failed. tk.setBlockingString("http-failure") + tk.setHTTPExperimentFailure(entry.Failure) return } @@ -281,11 +303,13 @@ func analysisClassicComputeBlockingAccessible(woa *minipipeline.WebAnalysis, tk // accessing the website should lead to. if entry.ControlHTTPFailure.IsNone() { tk.setBlockingNil() + tk.setHTTPExperimentFailure(entry.Failure) return } // 4.1.2. Otherwise, if the control worked, that's blocking. tk.setBlockingString("http-failure") + tk.setHTTPExperimentFailure(entry.Failure) return } @@ -295,11 +319,13 @@ func analysisClassicComputeBlockingAccessible(woa *minipipeline.WebAnalysis, tk // should set Accessible and Blocking to false. However, v0.4 // does this and we should play along for the A/B testing. tk.setBlockingFalse() + tk.setHTTPExperimentFailure(entry.Failure) return } // 4.3. Handle the case where just the probe failed. tk.setBlockingString("tcp_ip") + tk.setHTTPExperimentFailure(entry.Failure) return } @@ -314,11 +340,13 @@ func analysisClassicComputeBlockingAccessible(woa *minipipeline.WebAnalysis, tk // accessing the website should lead to. if entry.ControlHTTPFailure.IsNone() { tk.setBlockingFalse() + analysisClassicSetHTTPExperimentFailureDNS(tk, entry) return } // 5.1.2. Otherwise, if the control worked, that's blocking. tk.setBlockingString("dns") + analysisClassicSetHTTPExperimentFailureDNS(tk, entry) return } @@ -328,12 +356,24 @@ func analysisClassicComputeBlockingAccessible(woa *minipipeline.WebAnalysis, tk // should set Accessible and Blocking to false. However, v0.4 // does this and we should play along for the A/B testing. tk.setBlockingFalse() + analysisClassicSetHTTPExperimentFailureDNS(tk, entry) return } // 5.3. Handle the case where just the probe failed. tk.setBlockingString("dns") + analysisClassicSetHTTPExperimentFailureDNS(tk, entry) return } } } + +// analysisClassicSetHTTPExperimentFailureDNS sets the HTTPExperimentFailure if and +// only if the entry's TagDepth is >= 1. We have a v0.4 bug where we do not properly +// set this value for the first HTTP request . +func analysisClassicSetHTTPExperimentFailureDNS(tk analysisClassicTestKeysProxy, entry *minipipeline.WebObservation) { + if entry.TagDepth.UnwrapOr(0) <= 0 { + return + } + tk.setHTTPExperimentFailure(entry.Failure) +} diff --git a/internal/experiment/webconnectivitylte/analysiscore.go b/internal/experiment/webconnectivitylte/analysiscore.go index cc399ddb87..bba798798e 100644 --- a/internal/experiment/webconnectivitylte/analysiscore.go +++ b/internal/experiment/webconnectivitylte/analysiscore.go @@ -38,7 +38,7 @@ const ( // AnalysisEngineFn is the function that runs the analysis engine for // processing and scoring measurements collected by LTE. -var AnalysisEngineFn func(tk *TestKeys, logger model.Logger) = AnalysisEngineOrig +var AnalysisEngineFn func(tk *TestKeys, logger model.Logger) = AnalysisEngineClassic // analysisToplevel is the toplevel function that analyses the results // of the experiment once all network tasks have completed. diff --git a/internal/experiment/webconnectivitylte/analysishttpcore.go b/internal/experiment/webconnectivitylte/analysishttpcore.go index 8d7d34c9e2..e465ef047f 100644 --- a/internal/experiment/webconnectivitylte/analysishttpcore.go +++ b/internal/experiment/webconnectivitylte/analysishttpcore.go @@ -7,6 +7,7 @@ package webconnectivitylte import ( "github.com/ooni/probe-cli/v3/internal/model" "github.com/ooni/probe-cli/v3/internal/netxlite" + "github.com/ooni/probe-cli/v3/internal/optional" ) // analysisHTTPToplevel is the toplevel analysis function for HTTP results. @@ -31,7 +32,9 @@ func (tk *TestKeys) analysisHTTPToplevel(logger model.Logger) { return } finalRequest := tk.Requests[0] - tk.HTTPExperimentFailure = finalRequest.Failure + if finalRequest.Failure != nil { + tk.HTTPExperimentFailure = optional.Some(*finalRequest.Failure) + } // don't perform any futher analysis without TH data if tk.Control == nil || tk.ControlRequest == nil { diff --git a/internal/experiment/webconnectivitylte/measurer.go b/internal/experiment/webconnectivitylte/measurer.go index 7750cd7741..8ef38b8b04 100644 --- a/internal/experiment/webconnectivitylte/measurer.go +++ b/internal/experiment/webconnectivitylte/measurer.go @@ -37,7 +37,7 @@ func (m *Measurer) ExperimentName() string { // ExperimentVersion implements model.ExperimentMeasurer. func (m *Measurer) ExperimentVersion() string { - return "0.5.26" + return "0.5.27" } // Run implements model.ExperimentMeasurer. diff --git a/internal/experiment/webconnectivitylte/testkeys.go b/internal/experiment/webconnectivitylte/testkeys.go index 03e14f5740..bf854714c3 100644 --- a/internal/experiment/webconnectivitylte/testkeys.go +++ b/internal/experiment/webconnectivitylte/testkeys.go @@ -86,7 +86,7 @@ type TestKeys struct { // HTTPExperimentFailure indicates whether there was a failure in // the final HTTP request that we recorded. - HTTPExperimentFailure *string `json:"http_experiment_failure"` + HTTPExperimentFailure optional.Value[string] `json:"http_experiment_failure"` // BlockingFlags explains why we think that the website is blocked. BlockingFlags int64 `json:"x_blocking_flags"` @@ -95,6 +95,9 @@ type TestKeys struct { // blocking = null, accessible = null measurements did NullNullFlags int64 `json:"x_null_null_flags"` + // BodyProportion is the value used to compute BodyLength. + BodyProportion float64 `json:"body_proportion"` + // BodyLength match tells us whether the body length matches. BodyLengthMatch *bool `json:"body_length_match"` @@ -356,9 +359,10 @@ func NewTestKeys() *TestKeys { DNSFlags: 0, DNSExperimentFailure: nil, DNSConsistency: optional.None[string](), - HTTPExperimentFailure: nil, + HTTPExperimentFailure: optional.None[string](), BlockingFlags: 0, NullNullFlags: 0, + BodyProportion: 0, BodyLengthMatch: nil, HeadersMatch: nil, StatusCodeMatch: nil, diff --git a/internal/experiment/webconnectivityqa/badssl.go b/internal/experiment/webconnectivityqa/badssl.go index 573cec49ca..2e2eb1ca6d 100644 --- a/internal/experiment/webconnectivityqa/badssl.go +++ b/internal/experiment/webconnectivityqa/badssl.go @@ -10,7 +10,7 @@ import ( func badSSLWithExpiredCertificate() *TestCase { return &TestCase{ Name: "badSSLWithExpiredCertificate", - Flags: TestCaseFlagNoLTE, // LTE flags it correctly but let's focus on v0.4 for now + Flags: 0, Input: "https://expired.badssl.com/", Configure: func(env *netemx.QAEnv) { // nothing @@ -32,7 +32,7 @@ func badSSLWithExpiredCertificate() *TestCase { func badSSLWithWrongServerName() *TestCase { return &TestCase{ Name: "badSSLWithWrongServerName", - Flags: TestCaseFlagNoLTE, // LTE flags it correctly but let's focus on v0.4 for now + Flags: 0, Input: "https://wrong.host.badssl.com/", Configure: func(env *netemx.QAEnv) { // nothing @@ -53,7 +53,7 @@ func badSSLWithWrongServerName() *TestCase { func badSSLWithUnknownAuthorityWithConsistentDNS() *TestCase { return &TestCase{ Name: "badSSLWithUnknownAuthorityWithConsistentDNS", - Flags: TestCaseFlagNoLTE, // LTE flags it correctly but let's focus on v0.4 for now + Flags: 0, Input: "https://untrusted-root.badssl.com/", Configure: func(env *netemx.QAEnv) { // nothing @@ -79,7 +79,7 @@ func badSSLWithUnknownAuthorityWithInconsistentDNS() *TestCase { Configure: func(env *netemx.QAEnv) { // add DPI rule to force all the cleartext DNS queries to - // point the client to used the ISPProxyAddress + // point the client to use the ISPProxyAddress env.DPIEngine().AddRule(&netem.DPISpoofDNSResponse{ Addresses: []string{netemx.AddressBadSSLCom}, Logger: env.Logger(), diff --git a/internal/experiment/webconnectivityqa/control.go b/internal/experiment/webconnectivityqa/control.go index a831bc156a..c68e52bdf1 100644 --- a/internal/experiment/webconnectivityqa/control.go +++ b/internal/experiment/webconnectivityqa/control.go @@ -11,7 +11,7 @@ import ( func controlFailureWithSuccessfulHTTPWebsite() *TestCase { return &TestCase{ Name: "controlFailureWithSuccessfulHTTPWebsite", - Flags: TestCaseFlagNoLTE, // BUG: has "consistent" DNS but still blocking=null and accessible=null + Flags: 0, Input: "http://www.example.org/", Configure: func(env *netemx.QAEnv) { @@ -56,7 +56,7 @@ func controlFailureWithSuccessfulHTTPWebsite() *TestCase { func controlFailureWithSuccessfulHTTPSWebsite() *TestCase { return &TestCase{ Name: "controlFailureWithSuccessfulHTTPSWebsite", - Flags: TestCaseFlagNoLTE, // because it (correctly!) sets the DNS as consistent thanks to TLS + Flags: 0, Input: "https://www.example.org/", Configure: func(env *netemx.QAEnv) { diff --git a/internal/experiment/webconnectivityqa/dnsblocking.go b/internal/experiment/webconnectivityqa/dnsblocking.go index e2bbbf1719..3335a40cb1 100644 --- a/internal/experiment/webconnectivityqa/dnsblocking.go +++ b/internal/experiment/webconnectivityqa/dnsblocking.go @@ -47,8 +47,7 @@ func dnsBlockingNXDOMAIN() *TestCase { Flags: 0, Input: "https://www.example.com/", Configure: func(env *netemx.QAEnv) { - // remove the record so that the DNS query returns NXDOMAIN, which is then - // converted into android_dns_cache_no_data by the emulation layer + // remove the record so that the DNS query returns NXDOMAIN env.ISPResolverConfig().RemoveRecord("www.example.com") }, ExpectErr: false, @@ -68,7 +67,7 @@ func dnsBlockingNXDOMAIN() *TestCase { func dnsBlockingBOGON() *TestCase { return &TestCase{ Name: "dnsBlockingBOGON", - Flags: TestCaseFlagNoLTE, // We're not ready yet + Flags: 0, Input: "https://www.example.com/", Configure: func(env *netemx.QAEnv) { env.ISPResolverConfig().RemoveRecord("www.example.com") diff --git a/internal/experiment/webconnectivityqa/dnshijacking.go b/internal/experiment/webconnectivityqa/dnshijacking.go index 75a0cbf66d..fa67d3f488 100644 --- a/internal/experiment/webconnectivityqa/dnshijacking.go +++ b/internal/experiment/webconnectivityqa/dnshijacking.go @@ -12,7 +12,7 @@ func dnsHijackingToProxyWithHTTPURL() *TestCase { // transparent TLS proxy really makes our analysis a bit more complex return &TestCase{ Name: "dnsHijackingToProxyWithHTTPURL", - Flags: TestCaseFlagNoLTE, // BUG: LTE thinks the DNS is consistent + Flags: 0, Input: "http://www.example.com/", Configure: func(env *netemx.QAEnv) { @@ -49,7 +49,7 @@ func dnsHijackingToProxyWithHTTPSURL() *TestCase { // transparent TLS proxy really makes our analysis a bit more complex return &TestCase{ Name: "dnsHijackingToProxyWithHTTPSURL", - Flags: TestCaseFlagNoLTE, // BUG: LTE thinks the DNS is consistent + Flags: 0, Input: "https://www.example.com/", Configure: func(env *netemx.QAEnv) { diff --git a/internal/experiment/webconnectivityqa/httpdiff.go b/internal/experiment/webconnectivityqa/httpdiff.go index 2a619337f1..159e212b07 100644 --- a/internal/experiment/webconnectivityqa/httpdiff.go +++ b/internal/experiment/webconnectivityqa/httpdiff.go @@ -11,7 +11,7 @@ import ( func httpDiffWithConsistentDNS() *TestCase { return &TestCase{ Name: "httpDiffWithConsistentDNS", - Flags: TestCaseFlagNoLTE, // BUG: LTE does not set whether the headers match + Flags: 0, Input: "http://www.example.com/", Configure: func(env *netemx.QAEnv) { @@ -49,12 +49,12 @@ func httpDiffWithConsistentDNS() *TestCase { func httpDiffWithInconsistentDNS() *TestCase { return &TestCase{ Name: "httpDiffWithInconsistentDNS", - Flags: TestCaseFlagNoLTE, // BUG: LTE does not detect any HTTP diff here + Flags: 0, Input: "http://www.example.com/", Configure: func(env *netemx.QAEnv) { // add DPI rule to force all the cleartext DNS queries to - // point the client to used the ISPProxyAddress + // point the client to use the ISPProxyAddress env.DPIEngine().AddRule(&netem.DPISpoofDNSResponse{ Addresses: []string{netemx.ISPProxyAddress}, Logger: env.Logger(), diff --git a/internal/experiment/webconnectivityqa/redirect.go b/internal/experiment/webconnectivityqa/redirect.go index 0f265090fd..c93edaf32e 100644 --- a/internal/experiment/webconnectivityqa/redirect.go +++ b/internal/experiment/webconnectivityqa/redirect.go @@ -11,7 +11,7 @@ import ( func redirectWithConsistentDNSAndThenConnectionRefusedForHTTP() *TestCase { return &TestCase{ Name: "redirectWithConsistentDNSAndThenConnectionRefusedForHTTP", - Flags: TestCaseFlagNoLTE, // BUG: LTE thinks this website is accessible (WTF?!) + Flags: 0, Input: "https://bit.ly/32447", Configure: func(env *netemx.QAEnv) { @@ -49,7 +49,7 @@ func redirectWithConsistentDNSAndThenConnectionRefusedForHTTP() *TestCase { func redirectWithConsistentDNSAndThenConnectionRefusedForHTTPS() *TestCase { return &TestCase{ Name: "redirectWithConsistentDNSAndThenConnectionRefusedForHTTPS", - Flags: TestCaseFlagNoLTE, // BUG: LTE thinks this website is accessible (WTF?!) + Flags: 0, Input: "https://bit.ly/21645", Configure: func(env *netemx.QAEnv) { @@ -125,7 +125,7 @@ func redirectWithConsistentDNSAndThenConnectionResetForHTTP() *TestCase { func redirectWithConsistentDNSAndThenConnectionResetForHTTPS() *TestCase { return &TestCase{ Name: "redirectWithConsistentDNSAndThenConnectionResetForHTTPS", - Flags: TestCaseFlagNoLTE, // BUG: LTE thinks this website is accessible (WTF?!) + Flags: 0, Input: "https://bit.ly/21645", Configure: func(env *netemx.QAEnv) { @@ -163,7 +163,7 @@ func redirectWithConsistentDNSAndThenConnectionResetForHTTPS() *TestCase { func redirectWithConsistentDNSAndThenNXDOMAIN() *TestCase { return &TestCase{ Name: "redirectWithConsistentDNSAndThenNXDOMAIN", - Flags: TestCaseFlagNoLTE, // BUG: LTE thinks this website is accessible (WTF?!) + Flags: 0, Input: "https://bit.ly/21645", Configure: func(env *netemx.QAEnv) { @@ -232,7 +232,7 @@ func redirectWithConsistentDNSAndThenEOFForHTTP() *TestCase { func redirectWithConsistentDNSAndThenEOFForHTTPS() *TestCase { return &TestCase{ Name: "redirectWithConsistentDNSAndThenEOFForHTTPS", - Flags: TestCaseFlagNoLTE, // BUG: LTE thinks this website is accessible (WTF?!) + Flags: 0, Input: "https://bit.ly/21645", Configure: func(env *netemx.QAEnv) { @@ -309,7 +309,7 @@ func redirectWithConsistentDNSAndThenTimeoutForHTTP() *TestCase { func redirectWithConsistentDNSAndThenTimeoutForHTTPS() *TestCase { return &TestCase{ Name: "redirectWithConsistentDNSAndThenTimeoutForHTTPS", - Flags: TestCaseFlagNoLTE, // BUG: LTE thinks this website is accessible (WTF?!) + Flags: 0, Input: "https://bit.ly/21645", LongTest: true, Configure: func(env *netemx.QAEnv) { diff --git a/internal/experiment/webconnectivityqa/run_test.go b/internal/experiment/webconnectivityqa/run_test.go index d0ae7433cb..b0e93e7efa 100644 --- a/internal/experiment/webconnectivityqa/run_test.go +++ b/internal/experiment/webconnectivityqa/run_test.go @@ -191,6 +191,7 @@ func TestRunTestCase(t *testing.T) { }) t.Run("we compare XDNSFlags for WebConnectivity v0.5", func(t *testing.T) { + t.Skip("TODO(https://github.com/ooni/probe/issues/2640)") tc := &TestCase{ Name: "", Input: "", @@ -207,7 +208,7 @@ func TestRunTestCase(t *testing.T) { return "web_connectivity" }, MockExperimentVersion: func() string { - return "0.5.26" + return "0.5.27" }, MockRun: func(ctx context.Context, args *model.ExperimentArgs) error { args.Measurement.TestKeys = &testKeys{ @@ -225,6 +226,7 @@ func TestRunTestCase(t *testing.T) { }) t.Run("we compare XBlockingFlags for WebConnectivity v0.5", func(t *testing.T) { + t.Skip("TODO(https://github.com/ooni/probe/issues/2640)") tc := &TestCase{ Name: "", Input: "", @@ -242,7 +244,7 @@ func TestRunTestCase(t *testing.T) { return "web_connectivity" }, MockExperimentVersion: func() string { - return "0.5.26" + return "0.5.27" }, MockRun: func(ctx context.Context, args *model.ExperimentArgs) error { args.Measurement.TestKeys = &testKeys{ @@ -261,6 +263,7 @@ func TestRunTestCase(t *testing.T) { }) t.Run("we compare XNullNullFlags for WebConnectivity v0.5", func(t *testing.T) { + t.Skip("TODO(https://github.com/ooni/probe/issues/2640)") tc := &TestCase{ Name: "", Input: "", @@ -279,7 +282,7 @@ func TestRunTestCase(t *testing.T) { return "web_connectivity" }, MockExperimentVersion: func() string { - return "0.5.26" + return "0.5.27" }, MockRun: func(ctx context.Context, args *model.ExperimentArgs) error { args.Measurement.TestKeys = &testKeys{ @@ -317,7 +320,7 @@ func TestRunTestCase(t *testing.T) { return "web_connectivity" }, MockExperimentVersion: func() string { - return "0.5.26" + return "0.5.27" }, MockRun: func(ctx context.Context, args *model.ExperimentArgs) error { args.Measurement.TestKeys = &testKeys{ @@ -387,7 +390,7 @@ func TestRunTestCase(t *testing.T) { return "web_connectivity" }, MockExperimentVersion: func() string { - return "0.5.26" + return "0.5.27" }, MockRun: func(ctx context.Context, args *model.ExperimentArgs) error { args.Measurement.TestKeys = &testKeys{ diff --git a/internal/experiment/webconnectivityqa/success.go b/internal/experiment/webconnectivityqa/success.go index 1bd25bbaa4..25906d0df2 100644 --- a/internal/experiment/webconnectivityqa/success.go +++ b/internal/experiment/webconnectivityqa/success.go @@ -27,7 +27,7 @@ func successWithHTTP() *TestCase { func successWithHTTPS() *TestCase { return &TestCase{ Name: "successWithHTTPS", - Flags: TestCaseFlagNoLTE, // it does not set any HTTP comparison value with HTTPS + Flags: 0, Input: "https://www.example.com/", Configure: nil, ExpectErr: false, diff --git a/internal/experiment/webconnectivityqa/tcpblocking.go b/internal/experiment/webconnectivityqa/tcpblocking.go index dc568f9d10..f459d53995 100644 --- a/internal/experiment/webconnectivityqa/tcpblocking.go +++ b/internal/experiment/webconnectivityqa/tcpblocking.go @@ -40,7 +40,7 @@ func tcpBlockingConnectTimeout() *TestCase { func tcpBlockingConnectionRefusedWithInconsistentDNS() *TestCase { return &TestCase{ Name: "tcpBlockingConnectionRefusedWithInconsistentDNS", - Flags: TestCaseFlagNoLTE, // with LTE we can bypass the blocking + Flags: 0, Input: "http://www.example.org/", Configure: func(env *netemx.QAEnv) { diff --git a/internal/experiment/webconnectivityqa/testkeys.go b/internal/experiment/webconnectivityqa/testkeys.go index f33e8c040c..008c893d6a 100644 --- a/internal/experiment/webconnectivityqa/testkeys.go +++ b/internal/experiment/webconnectivityqa/testkeys.go @@ -73,15 +73,12 @@ func compareTestKeys(expected, got *testKeys) error { // ignore the fields that are specific to LTE options = append(options, cmpopts.IgnoreFields(testKeys{}, "XDNSFlags", "XBlockingFlags", "XNullNullFlags")) - case "0.5.26": + case "0.5.27": // ignore the fields that are specific to v0.4 options = append(options, cmpopts.IgnoreFields(testKeys{}, "XStatus")) - // BUG: LTE does not set http_experiment_failure - options = append(options, cmpopts.IgnoreFields(testKeys{}, "HTTPExperimentFailure")) - - // BUG: LTE does not set body_proportion - options = append(options, cmpopts.IgnoreFields(testKeys{}, "BodyProportion")) + // TODO(bassosimone): these flags are specific of the "orig" analysis engine + options = append(options, cmpopts.IgnoreFields(testKeys{}, "XDNSFlags", "XBlockingFlags", "XNullNullFlags")) default: return fmt.Errorf("unknown experiment version: %s", got.XExperimentVersion) diff --git a/internal/experiment/webconnectivityqa/websitedown.go b/internal/experiment/webconnectivityqa/websitedown.go index 2918559b99..aee748d52e 100644 --- a/internal/experiment/webconnectivityqa/websitedown.go +++ b/internal/experiment/webconnectivityqa/websitedown.go @@ -21,7 +21,7 @@ func websiteDownNXDOMAIN() *TestCase { */ return &TestCase{ Name: "websiteDownNXDOMAIN", - Flags: TestCaseFlagNoV04, // see above + Flags: 0, // see above Input: "http://www.example.xyz/", // domain not defined in the simulation Configure: nil, ExpectErr: false, @@ -31,7 +31,7 @@ func websiteDownNXDOMAIN() *TestCase { XStatus: 2052, // StatusExperimentDNS | StatusSuccessNXDOMAIN XBlockingFlags: 0, XNullNullFlags: 1, // analysisFlagNullNullNoAddrs - Accessible: false, + Accessible: true, Blocking: false, }, }