da95fa9365
* refactor: signal et al. are now experimental nettests We move signal into the experimental nettests group. While there, also start adding dnscheck and stunreachability as well. It seems there's more work to be done to correctly represent the results of dnscheck, but this is fine! The experimental section is here exactly for this reason! In terms of UI, the new command is `ooniprobe run experimental`. We will most likely move signal out of experimental soon, since it's already working quite well. We need to keep it here for one more cycle because the desktop app is not ready for it. See the following issues: 1. https://github.com/ooni/probe/issues/1378 2. https://github.com/ooni/probe/issues/1262 * fix(dnscheck): spell check * fix: improve documentation
61 lines
1.8 KiB
Go
61 lines
1.8 KiB
Go
package nettests
|
|
|
|
import (
|
|
"encoding/json"
|
|
|
|
"github.com/ooni/probe-cli/v3/internal/engine/experiment/dnscheck"
|
|
"github.com/ooni/probe-cli/v3/internal/engine/experiment/run"
|
|
"github.com/ooni/probe-cli/v3/internal/engine/runtimex"
|
|
)
|
|
|
|
// DNSCheck nettest implementation.
|
|
type DNSCheck struct{}
|
|
|
|
var dnsCheckDefaultInput []string
|
|
|
|
func dnsCheckMustMakeInput(input *run.StructuredInput) string {
|
|
data, err := json.Marshal(input)
|
|
runtimex.PanicOnError(err, "json.Marshal failed")
|
|
return string(data)
|
|
}
|
|
|
|
func init() {
|
|
// The following code just adds a minimal set of URLs to
|
|
// test using DNSCheck, so we start exposing it.
|
|
//
|
|
// TODO(bassosimone):
|
|
//
|
|
// 1. we should be getting input from the backend instead of
|
|
// having an hardcoded list of inputs here.
|
|
//
|
|
// 2. we should modify dnscheck to accept http3://... as a
|
|
// shortcut for https://... with h3. If we don't do that, we
|
|
// are stuck with the h3 results hiding h2 results in OONI
|
|
// Explorer because they use the same URL.
|
|
//
|
|
// 3. it seems we have the problem that dnscheck results
|
|
// appear as the `run` nettest in `ooniprobe list <ID>` because
|
|
// dnscheck is run using the `run` functionality.
|
|
dnsCheckDefaultInput = append(dnsCheckDefaultInput, dnsCheckMustMakeInput(
|
|
&run.StructuredInput{
|
|
DNSCheck: dnscheck.Config{},
|
|
Name: "dnscheck",
|
|
Input: "https://dns.google/dns-query",
|
|
}))
|
|
dnsCheckDefaultInput = append(dnsCheckDefaultInput, dnsCheckMustMakeInput(
|
|
&run.StructuredInput{
|
|
DNSCheck: dnscheck.Config{},
|
|
Name: "dnscheck",
|
|
Input: "https://cloudflare-dns.com/dns-query",
|
|
}))
|
|
}
|
|
|
|
// Run starts the nettest.
|
|
func (n DNSCheck) Run(ctl *Controller) error {
|
|
builder, err := ctl.Session.NewExperimentBuilder("run")
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return ctl.Run(builder, dnsCheckDefaultInput)
|
|
}
|