feat: start adding torsf to desktop and mobile (#671)

This commit message is the same across probe-cli, probe-desktop,
and probe-android. With the changes contained in the enclosed
diff, I'm starting to add support for torsf for android and for
desktop.

When smoke testing that torsf was WAI, I also noticed that its
progress messages in output are too frequent. We may want to do
better in a future version when we'll be able to read `tor`'s
output. In the meanwhile, make the progress messages less
frequent and indicated the maximum runtime inside of the messages
themselves. This improved message, albeit not so nice from the
UX PoV, should at least provide a clue that we're not stuck.

Reference issue: https://github.com/ooni/probe/issues/1917
This commit is contained in:
Simone Basso 2022-01-24 12:39:27 +01:00 committed by GitHub
parent a01f901e13
commit d92c1641ac
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -6,6 +6,7 @@ package torsf
import ( import (
"context" "context"
"fmt"
"path" "path"
"time" "time"
@ -80,7 +81,7 @@ func (m *Measurer) Run(
ctx, cancel := context.WithTimeout(ctx, maxRuntime) ctx, cancel := context.WithTimeout(ctx, maxRuntime)
defer cancel() defer cancel()
errch := make(chan error) errch := make(chan error)
ticker := time.NewTicker(250 * time.Millisecond) ticker := time.NewTicker(2 * time.Second)
defer ticker.Stop() defer ticker.Stop()
go m.run(ctx, sess, testkeys, errch) go m.run(ctx, sess, testkeys, errch)
for { for {
@ -90,8 +91,11 @@ func (m *Measurer) Run(
return err return err
case <-ticker.C: case <-ticker.C:
if !m.config.DisableProgress { if !m.config.DisableProgress {
progress := time.Since(start).Seconds() / maxRuntime.Seconds() elapsedTime := time.Since(start)
callbacks.OnProgress(progress, "torsf experiment is running") progress := elapsedTime.Seconds() / maxRuntime.Seconds()
callbacks.OnProgress(progress, fmt.Sprintf(
"torsf: elapsedTime: %.0f s; maxRuntime: %.0f s",
elapsedTime.Seconds(), maxRuntime.Seconds()))
} }
} }
} }