From 07a26f4c428e980e2efc633b47ea2daef2de8e50 Mon Sep 17 00:00:00 2001 From: Simone Basso Date: Wed, 7 Feb 2024 10:52:39 +0100 Subject: [PATCH] cleanup(all): remove the run experiment (#1492) We used the run experiment for the DoT and DoH blocking paper, i.e., https://censorbib.nymity.ch/#Basso2021a. Beyond that, the run experiment has never been advertised and its functionality duplicates some OONI Run v2 functionality. Therefore, it's safe to remove this experiment, which will make https://github.com/ooni/probe/issues/2667 easier to implement. --- internal/experiment/run/dnscheck.go | 30 ------- internal/experiment/run/doc.go | 4 - internal/experiment/run/run.go | 76 ---------------- internal/experiment/run/run_test.go | 127 --------------------------- internal/experiment/run/table.go | 26 ------ internal/experiment/run/urlgetter.go | 27 ------ internal/registry/run.go | 23 ----- 7 files changed, 313 deletions(-) delete mode 100644 internal/experiment/run/dnscheck.go delete mode 100644 internal/experiment/run/doc.go delete mode 100644 internal/experiment/run/run.go delete mode 100644 internal/experiment/run/run_test.go delete mode 100644 internal/experiment/run/table.go delete mode 100644 internal/experiment/run/urlgetter.go delete mode 100644 internal/registry/run.go diff --git a/internal/experiment/run/dnscheck.go b/internal/experiment/run/dnscheck.go deleted file mode 100644 index c2084c6acc..0000000000 --- a/internal/experiment/run/dnscheck.go +++ /dev/null @@ -1,30 +0,0 @@ -package run - -import ( - "context" - - "github.com/ooni/probe-cli/v3/internal/experiment/dnscheck" - "github.com/ooni/probe-cli/v3/internal/model" -) - -type dnsCheckMain struct { - Endpoints *dnscheck.Endpoints -} - -func (m *dnsCheckMain) do(ctx context.Context, input StructuredInput, - sess model.ExperimentSession, measurement *model.Measurement, - callbacks model.ExperimentCallbacks) error { - exp := dnscheck.Measurer{ - Config: input.DNSCheck, - Endpoints: m.Endpoints, - } - measurement.TestName = exp.ExperimentName() - measurement.TestVersion = exp.ExperimentVersion() - measurement.Input = model.MeasurementTarget(input.Input) - args := &model.ExperimentArgs{ - Callbacks: callbacks, - Measurement: measurement, - Session: sess, - } - return exp.Run(ctx, args) -} diff --git a/internal/experiment/run/doc.go b/internal/experiment/run/doc.go deleted file mode 100644 index bfb076a83f..0000000000 --- a/internal/experiment/run/doc.go +++ /dev/null @@ -1,4 +0,0 @@ -// Package run contains code to run other experiments. -// -// This code is currently alpha. -package run diff --git a/internal/experiment/run/run.go b/internal/experiment/run/run.go deleted file mode 100644 index 63c623e00d..0000000000 --- a/internal/experiment/run/run.go +++ /dev/null @@ -1,76 +0,0 @@ -package run - -import ( - "context" - "encoding/json" - "fmt" - - "github.com/ooni/probe-cli/v3/internal/experiment/dnscheck" - "github.com/ooni/probe-cli/v3/internal/experiment/urlgetter" - "github.com/ooni/probe-cli/v3/internal/model" -) - -// Config contains settings. -type Config struct{} - -// Measurer runs the measurement. -type Measurer struct{} - -// ExperimentName implements ExperimentMeasurer.ExperimentName. -func (Measurer) ExperimentName() string { - return "run" -} - -// ExperimentVersion implements ExperimentMeasurer.ExperimentVersion. -func (Measurer) ExperimentVersion() string { - return "0.2.0" -} - -// StructuredInput contains structured input for this experiment. -type StructuredInput struct { - // Annotations contains extra annotations to add to the - // final measurement. - Annotations map[string]string `json:"annotations"` - - // DNSCheck contains settings for the dnscheck experiment. - DNSCheck dnscheck.Config `json:"dnscheck"` - - // URLGetter contains settings for the urlgetter experiment. - URLGetter urlgetter.Config `json:"urlgetter"` - - // Name is the name of the experiment to run. - Name string `json:"name"` - - // Input is the input for this experiment. - Input string `json:"input"` -} - -// Run implements ExperimentMeasurer.ExperimentVersion. -func (Measurer) Run(ctx context.Context, args *model.ExperimentArgs) error { - callbacks := args.Callbacks - measurement := args.Measurement - sess := args.Session - var input StructuredInput - if err := json.Unmarshal([]byte(measurement.Input), &input); err != nil { - return err - } - exprun, found := table[input.Name] - if !found { - return fmt.Errorf("no such experiment: %s", input.Name) - } - measurement.AddAnnotations(input.Annotations) - return exprun.do(ctx, input, sess, measurement, callbacks) -} - -// GetSummaryKeys implements ExperimentMeasurer.GetSummaryKeys -func (Measurer) GetSummaryKeys(*model.Measurement) (interface{}, error) { - // TODO(bassosimone): we could extend this interface to call the - // specific GetSummaryKeys of the experiment we're running. - return dnscheck.SummaryKeys{IsAnomaly: false}, nil -} - -// NewExperimentMeasurer creates a new model.ExperimentMeasurer -// implementing the run experiment. -func NewExperimentMeasurer(config Config) model.ExperimentMeasurer { - return Measurer{} -} diff --git a/internal/experiment/run/run_test.go b/internal/experiment/run/run_test.go deleted file mode 100644 index 468e21be31..0000000000 --- a/internal/experiment/run/run_test.go +++ /dev/null @@ -1,127 +0,0 @@ -package run_test - -import ( - "context" - "testing" - - "github.com/apex/log" - "github.com/ooni/probe-cli/v3/internal/experiment/dnscheck" - "github.com/ooni/probe-cli/v3/internal/experiment/run" - "github.com/ooni/probe-cli/v3/internal/experiment/urlgetter" - "github.com/ooni/probe-cli/v3/internal/legacy/mockable" - "github.com/ooni/probe-cli/v3/internal/model" -) - -func TestExperimentNameAndVersion(t *testing.T) { - measurer := run.NewExperimentMeasurer(run.Config{}) - if measurer.ExperimentName() != "run" { - t.Error("unexpected experiment name") - } - if measurer.ExperimentVersion() != "0.2.0" { - t.Error("unexpected experiment version") - } -} - -func TestRunDNSCheckWithCancelledContext(t *testing.T) { - measurer := run.NewExperimentMeasurer(run.Config{}) - input := `{"name": "dnscheck", "input": "https://dns.google/dns-query"}` - measurement := new(model.Measurement) - measurement.Input = model.MeasurementTarget(input) - ctx, cancel := context.WithCancel(context.Background()) - cancel() // fail immediately - sess := &mockable.Session{MockableLogger: log.Log} - callbacks := model.NewPrinterCallbacks(log.Log) - args := &model.ExperimentArgs{ - Callbacks: callbacks, - Measurement: measurement, - Session: sess, - } - err := measurer.Run(ctx, args) - // TODO(bassosimone): here we could improve the tests by checking - // whether the result makes sense for a cancelled context. - if err != nil { - t.Fatal(err) - } - if _, ok := measurement.TestKeys.(*dnscheck.TestKeys); !ok { - t.Fatal("invalid type for test keys") - } - sk, err := measurer.GetSummaryKeys(measurement) - if err != nil { - t.Fatal(err) - } - rsk, ok := sk.(dnscheck.SummaryKeys) - if !ok { - t.Fatal("cannot convert summary keys to specific type") - } - if rsk.IsAnomaly != false { - t.Fatal("unexpected IsAnomaly value") - } -} - -func TestRunURLGetterWithCancelledContext(t *testing.T) { - measurer := run.NewExperimentMeasurer(run.Config{}) - input := `{"name": "urlgetter", "input": "https://google.com"}` - measurement := new(model.Measurement) - measurement.Input = model.MeasurementTarget(input) - ctx, cancel := context.WithCancel(context.Background()) - cancel() // fail immediately - sess := &mockable.Session{MockableLogger: log.Log} - callbacks := model.NewPrinterCallbacks(log.Log) - args := &model.ExperimentArgs{ - Callbacks: callbacks, - Measurement: measurement, - Session: sess, - } - err := measurer.Run(ctx, args) - if err != nil { // here we expected nil b/c we want to submit the measurement - t.Fatal(err) - } - if len(measurement.Extensions) != 6 { - t.Fatal("not the expected number of extensions") - } - tk, ok := measurement.TestKeys.(*urlgetter.TestKeys) - if !ok { - t.Fatal("invalid type for test keys") - } - if len(tk.DNSCache) != 0 { - t.Fatal("not the DNSCache value we expected") - } -} - -func TestRunWithInvalidJSON(t *testing.T) { - measurer := run.NewExperimentMeasurer(run.Config{}) - input := `{"name": }` - measurement := new(model.Measurement) - measurement.Input = model.MeasurementTarget(input) - ctx := context.Background() - sess := &mockable.Session{MockableLogger: log.Log} - callbacks := model.NewPrinterCallbacks(log.Log) - args := &model.ExperimentArgs{ - Callbacks: callbacks, - Measurement: measurement, - Session: sess, - } - err := measurer.Run(ctx, args) - if err == nil || err.Error() != "invalid character '}' looking for beginning of value" { - t.Fatalf("not the error we expected: %+v", err) - } -} - -func TestRunWithUnknownExperiment(t *testing.T) { - measurer := run.NewExperimentMeasurer(run.Config{}) - input := `{"name": "antani"}` - measurement := new(model.Measurement) - measurement.Input = model.MeasurementTarget(input) - ctx := context.Background() - sess := &mockable.Session{MockableLogger: log.Log} - callbacks := model.NewPrinterCallbacks(log.Log) - args := &model.ExperimentArgs{ - Callbacks: callbacks, - Measurement: measurement, - Session: sess, - } - err := measurer.Run(ctx, args) - if err == nil || err.Error() != "no such experiment: antani" { - t.Fatalf("not the error we expected: %+v", err) - } -} diff --git a/internal/experiment/run/table.go b/internal/experiment/run/table.go deleted file mode 100644 index 8ac6dbb3c3..0000000000 --- a/internal/experiment/run/table.go +++ /dev/null @@ -1,26 +0,0 @@ -package run - -import ( - "context" - - "github.com/ooni/probe-cli/v3/internal/experiment/dnscheck" - "github.com/ooni/probe-cli/v3/internal/model" -) - -type experimentMain interface { - do(ctx context.Context, input StructuredInput, - sess model.ExperimentSession, measurement *model.Measurement, - callbacks model.ExperimentCallbacks) error -} - -var table = map[string]experimentMain{ - // TODO(bassosimone): before extending run to support more than - // single experiment, we need to handle the case in which we are - // including different experiments into the same report ID. - // Probably, the right way to implement this functionality is to - // use proveservices.Submitter to submit reports. - "dnscheck": &dnsCheckMain{ - Endpoints: &dnscheck.Endpoints{}, - }, - "urlgetter": &urlGetterMain{}, -} diff --git a/internal/experiment/run/urlgetter.go b/internal/experiment/run/urlgetter.go deleted file mode 100644 index 74ee845df0..0000000000 --- a/internal/experiment/run/urlgetter.go +++ /dev/null @@ -1,27 +0,0 @@ -package run - -import ( - "context" - - "github.com/ooni/probe-cli/v3/internal/experiment/urlgetter" - "github.com/ooni/probe-cli/v3/internal/model" -) - -type urlGetterMain struct{} - -func (m *urlGetterMain) do(ctx context.Context, input StructuredInput, - sess model.ExperimentSession, measurement *model.Measurement, - callbacks model.ExperimentCallbacks) error { - exp := urlgetter.Measurer{ - Config: input.URLGetter, - } - measurement.TestName = exp.ExperimentName() - measurement.TestVersion = exp.ExperimentVersion() - measurement.Input = model.MeasurementTarget(input.Input) - args := &model.ExperimentArgs{ - Callbacks: callbacks, - Measurement: measurement, - Session: sess, - } - return exp.Run(ctx, args) -} diff --git a/internal/registry/run.go b/internal/registry/run.go deleted file mode 100644 index 371aac43bb..0000000000 --- a/internal/registry/run.go +++ /dev/null @@ -1,23 +0,0 @@ -package registry - -// -// Registers the `run' experiment. -// - -import ( - "github.com/ooni/probe-cli/v3/internal/experiment/run" - "github.com/ooni/probe-cli/v3/internal/model" -) - -func init() { - AllExperiments["run"] = &Factory{ - build: func(config interface{}) model.ExperimentMeasurer { - return run.NewExperimentMeasurer( - *config.(*run.Config), - ) - }, - config: &run.Config{}, - enabledByDefault: true, - inputPolicy: model.InputStrictlyRequired, - } -}