feat(webconnectivity): collect timing information (#537)

Work related to https://github.com/ooni/probe/issues/1797
This commit is contained in:
Simone Basso 2021-10-05 12:52:19 +02:00 committed by GitHub
parent 3f511d100b
commit a6318d6de9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 22 additions and 2 deletions

View File

@ -19,7 +19,7 @@ import (
const ( const (
testName = "web_connectivity" testName = "web_connectivity"
testVersion = "0.4.0" testVersion = "0.4.1"
) )
// Config contains the experiment config. // Config contains the experiment config.
@ -63,6 +63,18 @@ type TestKeys struct {
// Top-level analysis // Top-level analysis
Summary Summary
// DNSRuntime is the time to run all DNS checks.
DNSRuntime time.Duration `json:"x_dns_runtime"`
// THRuntime is the total time to invoke all test helpers.
THRuntime time.Duration `json:"x_th_runtime"`
// TCPTLSRuntime is the total time to perform TCP/TLS "connects".
TCPTLSRuntime time.Duration `json:"x_tcptls_runtime"`
// HTTPRuntime is the total time to perform the HTTP GET.
HTTPRuntime time.Duration `json:"x_http_runtime"`
} }
// Measurer performs the measurement. // Measurer performs the measurement.
@ -151,14 +163,17 @@ func (m Measurer) Run(
"backend": testhelper, "backend": testhelper,
} }
// 2. perform the DNS lookup step // 2. perform the DNS lookup step
dnsBegin := time.Now()
dnsResult := DNSLookup(ctx, DNSLookupConfig{ dnsResult := DNSLookup(ctx, DNSLookupConfig{
Begin: measurement.MeasurementStartTimeSaved, Begin: measurement.MeasurementStartTimeSaved,
Session: sess, URL: URL}) Session: sess, URL: URL})
tk.DNSRuntime = time.Since(dnsBegin)
tk.Queries = append(tk.Queries, dnsResult.TestKeys.Queries...) tk.Queries = append(tk.Queries, dnsResult.TestKeys.Queries...)
tk.DNSExperimentFailure = dnsResult.Failure tk.DNSExperimentFailure = dnsResult.Failure
epnts := NewEndpoints(URL, dnsResult.Addresses()) epnts := NewEndpoints(URL, dnsResult.Addresses())
sess.Logger().Infof("using control: %s", testhelper.Address) sess.Logger().Infof("using control: %s", testhelper.Address)
// 3. perform the control measurement // 3. perform the control measurement
thBegin := time.Now()
tk.Control, err = Control(ctx, sess, testhelper.Address, ControlRequest{ tk.Control, err = Control(ctx, sess, testhelper.Address, ControlRequest{
HTTPRequest: URL.String(), HTTPRequest: URL.String(),
HTTPRequestHeaders: map[string][]string{ HTTPRequestHeaders: map[string][]string{
@ -168,6 +183,7 @@ func (m Measurer) Run(
}, },
TCPConnect: epnts.Endpoints(), TCPConnect: epnts.Endpoints(),
}) })
tk.THRuntime = time.Since(thBegin)
tk.ControlFailure = archival.NewFailure(err) tk.ControlFailure = archival.NewFailure(err)
// 4. analyze DNS results // 4. analyze DNS results
if tk.ControlFailure == nil { if tk.ControlFailure == nil {
@ -181,12 +197,14 @@ func (m Measurer) Run(
// returned by the control experiment. // returned by the control experiment.
// //
// See https://github.com/ooni/probe/issues/1414 // See https://github.com/ooni/probe/issues/1414
tcptlsBegin := time.Now()
connectsResult := Connects(ctx, ConnectsConfig{ connectsResult := Connects(ctx, ConnectsConfig{
Begin: measurement.MeasurementStartTimeSaved, Begin: measurement.MeasurementStartTimeSaved,
Session: sess, Session: sess,
TargetURL: URL, TargetURL: URL,
URLGetterURLs: epnts.URLs(), URLGetterURLs: epnts.URLs(),
}) })
tk.TCPTLSRuntime = time.Since(tcptlsBegin)
sess.Logger().Infof( sess.Logger().Infof(
"TCP/TLS endpoints: %d/%d reachable", connectsResult.Successes, connectsResult.Total) "TCP/TLS endpoints: %d/%d reachable", connectsResult.Successes, connectsResult.Total)
for _, tcpkeys := range connectsResult.AllKeys { for _, tcpkeys := range connectsResult.AllKeys {
@ -206,12 +224,14 @@ func (m Measurer) Run(
tk.TCPConnectAttempts = connectsResult.Total tk.TCPConnectAttempts = connectsResult.Total
tk.TCPConnectSuccesses = connectsResult.Successes tk.TCPConnectSuccesses = connectsResult.Successes
// 6. perform HTTP/HTTPS measurement // 6. perform HTTP/HTTPS measurement
httpBegin := time.Now()
httpResult := HTTPGet(ctx, HTTPGetConfig{ httpResult := HTTPGet(ctx, HTTPGetConfig{
Addresses: dnsResult.Addresses(), Addresses: dnsResult.Addresses(),
Begin: measurement.MeasurementStartTimeSaved, Begin: measurement.MeasurementStartTimeSaved,
Session: sess, Session: sess,
TargetURL: URL, TargetURL: URL,
}) })
tk.HTTPRuntime = time.Since(httpBegin)
tk.HTTPExperimentFailure = httpResult.Failure tk.HTTPExperimentFailure = httpResult.Failure
tk.Requests = append(tk.Requests, httpResult.TestKeys.Requests...) tk.Requests = append(tk.Requests, httpResult.TestKeys.Requests...)
// 7. compare HTTP measurement to control // 7. compare HTTP measurement to control

View File

@ -21,7 +21,7 @@ func TestNewExperimentMeasurer(t *testing.T) {
if measurer.ExperimentName() != "web_connectivity" { if measurer.ExperimentName() != "web_connectivity" {
t.Fatal("unexpected name") t.Fatal("unexpected name")
} }
if measurer.ExperimentVersion() != "0.4.0" { if measurer.ExperimentVersion() != "0.4.1" {
t.Fatal("unexpected version") t.Fatal("unexpected version")
} }
} }