fix(webconnectivity@v0.5): status code always match with equal codes (#951)

See https://github.com/ooni/probe/issues/2287
This commit is contained in:
Simone Basso 2022-09-11 22:48:28 +02:00 committed by GitHub
parent 5e75512396
commit 2dd4e75945
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 21 additions and 4 deletions

View File

@ -112,10 +112,27 @@ func (tk *TestKeys) httpDiffStatusCodeMatch(
if measurement <= 0 { if measurement <= 0 {
return // no real status code return // no real status code
} }
if control/100 != 2 {
return // avoid comparison if it seems the TH failed
}
good := control == measurement good := control == measurement
if !good && control/100 != 2 {
// Avoid comparison if it seems the TH failed _and_ the two
// status codes are not equal. Originally, this algorithm was
// https://github.com/measurement-kit/measurement-kit/blob/b55fbecb205be62c736249b689df0c45ae342804/src/libmeasurement_kit/ooni/web_connectivity.cpp#L60
// and excluded the case where the TH failed with 5xx.
//
// Then, we discovered when implementing websteps a bunch
// of control failure modes that suggested to be more
// cautious. See https://github.com/bassosimone/websteps-illustrated/blob/632f27443ab9d94fb05efcf5e0b0c1ce190221e2/internal/engine/experiment/websteps/analysisweb.go#L137.
//
// However, it seems a bit retarded to avoid comparison
// when both the TH and the probe failed equallty. See
// https://github.com/ooni/probe/issues/2287, which refers
// to a measurement where both the probe and the TH fail
// with 404, but we fail to say "status_code_match = true".
//
// See https://explorer.ooni.org/measurement/20220911T203447Z_webconnectivity_IT_30722_n1_YDZQZOHAziEJk6o9?input=http%3A%2F%2Fwww.webbox.com%2Findex.php
// for a measurement where this was fixed.
return
}
tk.StatusCodeMatch = &good tk.StatusCodeMatch = &good
} }

View File

@ -36,7 +36,7 @@ func (m *Measurer) ExperimentName() string {
// ExperimentVersion implements model.ExperimentMeasurer. // ExperimentVersion implements model.ExperimentMeasurer.
func (m *Measurer) ExperimentVersion() string { func (m *Measurer) ExperimentVersion() string {
return "0.5.8" return "0.5.9"
} }
// Run implements model.ExperimentMeasurer. // Run implements model.ExperimentMeasurer.