[tor-bugs] #21095 [Metrics/Onionoo]: Accept more values for the "order" parameter

Tor Bug Tracker & Wiki blackhole at torproject.org
Thu Jan 5 14:14:29 UTC 2017


#21095: Accept more values for the "order" parameter
-----------------------------+------------------------------
 Reporter:  lukechilds       |          Owner:  metrics-team
     Type:  enhancement      |         Status:  needs_review
 Priority:  Medium           |      Milestone:
Component:  Metrics/Onionoo  |        Version:
 Severity:  Normal           |     Resolution:
 Keywords:  metrics-help     |  Actual Points:
Parent ID:                   |         Points:
 Reviewer:                   |        Sponsor:
-----------------------------+------------------------------

Comment (by karsten):

 Replying to [comment:13 iwakeh]:
 > All fine and good to see all those tests :-)

 Great, thanks for looking!

 > (Although they only test summary docs, but that's not really part of
 this ticket.)

 Right, though I wouldn't expect much better coverage from including other
 document types.  Details documents with the `fields` parameter maybe.  But
 all in all there are lower-hanging fruit for increasing actual test
 coverage.

 > Maybe, add a test or change test data to accommodate testing the
 different order of order parameters. Currently `-first_seen` causes the
 same ordering of the test data as `consensus_weight`.

 Done in a new commit in the same branch.

 > The protocol
 [https://gitweb.torproject.org/user/karsten/onionoo.git/tree/src/main/resources/web/protocol.html?h=task-21095&id=f22b6626239a14f566d49081f55c5894fc5459a5#n476
 states] `Results are first ordered by the first list element, then by the
 second, and so on.`, but more than four order fields will cause the
 invalid request response `400`, which is tested for in
 `testOrderConsensusWeightFiveTimes` but not mentioned in the protocol.

 Right, I put that in to protect against potentially expensive queries
 asking us to sort results over and over.  What we could also do is specify
 that each parameter can only be used once.  Is that better?

 By the way, is there a valid use case for ordering by the same parameter
 more than once?  After all, the second (and subsequent) order parameters
 are only applied when two entries have the exact same value with respect
 to the first order parameter.

 Does the above become clear from the specification, or how would we
 explain that more clearly?  And is it what people would expect?

 Example:

 {{{
 [ {"a": 1, "b": 2, "c": 3},
   {"a": 1, "b": 1, "c": 4} ]

 ordered by a, b:
 [ {"a": 1, "b": 1, "c": 4},
   {"a": 1, "b": 2, "c": 3} ]

 ordered by b, a:
 [ {"a": 1, "b": 1, "c": 3},
   {"a": 1, "b": 2, "c": 4} ]
 }}}

 > How is the impact on memory when this new list is added?

 I didn't check, but in theory we're keeping another list in memory that
 contains 12k fingerprints times 40 bytes = 480 kB, plus some overhead for
 the list.  Not really an issue, I think.

 > Unrelated: Should
 [https://gitweb.torproject.org/user/karsten/onionoo.git/tree/src/main/java/org/torproject/onionoo/server/NodeIndexer.java?h=task-21095&id=f22b6626239a14f566d49081f55c5894fc5459a5#n192
 this]:
 >
 > {{{
 >     /* This variable can go away once all Onionoo services had their
 >      * hourly updater write effective families to summary documents at
 >      * least once.  Remove this code after September 8, 2015. */
 > }}}
 >
 > be done now with an additional commit?

 Yes, let's do that in an additional commit, unrelated to this ticket.
 There maybe other parts in the code that we can take out.  But let's move
 that to another ticket.

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


More information about the tor-bugs mailing list