[tbb-bugs] #33746 [Applications/Tor Browser]: Show users a bandwidth graph or activity spinner during slow loads

Tor Bug Tracker & Wiki blackhole at torproject.org
Fri Mar 27 06:11:02 UTC 2020


#33746: Show users a bandwidth graph or activity spinner during slow loads
------------------------------------------+----------------------
     Reporter:  arma                      |      Owner:  tbb-team
         Type:  enhancement               |     Status:  new
     Priority:  Medium                    |  Milestone:
    Component:  Applications/Tor Browser  |    Version:
     Severity:  Normal                    |   Keywords:  ux-team
Actual Points:                            |  Parent ID:
       Points:                            |   Reviewer:
      Sponsor:                            |
------------------------------------------+----------------------
 I've been testing the Turbo Tunnel Quic Snowflake builds of Tor Browser,
 and every so often (anecdotally, 5-10% of the time) I end up with a
 snowflake that is super slow, like 5-10 kilobytes per second. So pages
 load but they take a minute or three.

 This is probably pretty similar to the behavior that normal Tor Browser
 users get on low-bandwidth crappy internet connections around the world.
 So I bet I am not alone in this situation, and whatever fixes we develop
 here could benefit our next billion users.

 I've been attaching a nyx to my Tor Browser ({{{nyx -i 9151}}} plus
 patching my about:config snowflake bridge line for #33693 so the BW
 controller events will work) in order to watch nyx's bandwidth graphs.
 That way I know whether the browser is slowly loading its page, or just
 pretending that it's loading while actually no bytes are being
 transferred.

 We should consider making a tiny bandwidth graph inside the Tor Browser
 interface, so normal users can discover whether their Tor is "working but
 slow" or "not working at all". I imagine a lot of users give up after the
 first minute of waiting for the page to load (bad for user retention), but
 also I've heard from folks in Kenya about waiting 30 minutes for a page to
 load before giving up (and if they had browser feedback that no bytes were
 coming through at all, they could do something else with that time).

 It doesn't need to be a bandwidth graph. In fact maybe that's not the best
 plan, because I'd want to know the scale on the graph and then suddenly it
 can't be super tiny anymore. I think that I want to learn two things: how
 much bandwidth came through in the last second or so, and how much
 bandwidth came through 'pretty recently'. So I could imagine other
 visualizations, like a spinner that spins rapidly if I got bandwidth this
 past second, and spins slowly if I got bandwidth in the last ten seconds,
 and spins not at all if it's been longer than that.

 From the Tor interaction side this is super easy: tor emits a BW
 controller event every second, with two numbers, one for 'in' bytes and
 the other for 'out' bytes. Tor Browser could listen for these events and
 then it would know the numbers.

 Probably users trying to debug their situation will have situations where
 they want to know about both directions (and distinguish between them).
 For example, "my Tor Browser keeps sending requests but it never gets any
 responses" is a useful level of detail to be able to learn.

 Two further thoughts in hopes they're useful: (a) modern Western browsers
 (designed for Americans on cablemodems) might not consider this problem,
 but maybe some other browsers for other types of users do encounter it and
 have come up with solutions? and (b) whatever we design for Tor Browser
 desktop might not be what we'll want for Tor Browser Android.

--
Ticket URL: <https://trac.torproject.org/projects/tor/ticket/33746>
Tor Bug Tracker & Wiki <https://trac.torproject.org/>
The Tor Project: anonymity online


More information about the tbb-bugs mailing list