[tor-commits] [onionoo/master] Fix comparison in writing uptime documents.

karsten at torproject.org karsten at torproject.org
Wed Feb 7 10:19:32 UTC 2018


commit 203d5d885d4155ed719c5168430ba237bad734aa
Author: Karsten Loesing <karsten.loesing at gmx.net>
Date:   Mon Jan 15 11:11:20 2018 +0100

    Fix comparison in writing uptime documents.
    
    In the spec we write: "Contained graph history objects may contain
    null values if less than 20% of network statuses have been processed
    for a given time period."
    
    However, in the code we checked less than or equal. We should fix
    that.
---
 .../onionoo/writer/UptimeDocumentWriter.java       | 12 +++---
 .../onionoo/writer/UptimeDocumentWriterTest.java   | 44 +++++++++++++++++++++-
 2 files changed, 49 insertions(+), 7 deletions(-)

diff --git a/src/main/java/org/torproject/onionoo/writer/UptimeDocumentWriter.java b/src/main/java/org/torproject/onionoo/writer/UptimeDocumentWriter.java
index 96537ef..f739b9e 100644
--- a/src/main/java/org/torproject/onionoo/writer/UptimeDocumentWriter.java
+++ b/src/main/java/org/torproject/onionoo/writer/UptimeDocumentWriter.java
@@ -225,8 +225,8 @@ public class UptimeDocumentWriter implements DocumentWriter {
       }
       while (hist.getStartMillis() >= intervalStartMillis
           + dataPointInterval) {
-        statusDataPoints.add(statusHours * 5 > dataPointIntervalHours
-            ? statusHours : -1);
+        statusDataPoints.add(statusHours * 5 < dataPointIntervalHours
+            ? -1 : statusHours);
         statusHours = -1;
         intervalStartMillis += dataPointInterval;
       }
@@ -238,8 +238,8 @@ public class UptimeDocumentWriter implements DocumentWriter {
             - Math.max(Math.max(hist.getStartMillis(),
             firstStatusStartMillis), intervalStartMillis))
             / DateTimeHelper.ONE_HOUR);
-        statusDataPoints.add(statusHours * 5 > dataPointIntervalHours
-            ? statusHours : -1);
+        statusDataPoints.add(statusHours * 5 < dataPointIntervalHours
+            ? -1 : statusHours);
         statusHours = -1;
         intervalStartMillis += dataPointInterval;
       }
@@ -251,8 +251,8 @@ public class UptimeDocumentWriter implements DocumentWriter {
           intervalStartMillis)) / DateTimeHelper.ONE_HOUR);
     }
     if (statusHours > 0) {
-      statusDataPoints.add(statusHours * 5 > dataPointIntervalHours
-          ? statusHours : -1);
+      statusDataPoints.add(statusHours * 5 < dataPointIntervalHours
+          ? -1 : statusHours);
     }
     List<Double> dataPoints = new ArrayList<>();
     for (int dataPointIndex = 0; dataPointIndex < statusDataPoints.size();
diff --git a/src/test/java/org/torproject/onionoo/writer/UptimeDocumentWriterTest.java b/src/test/java/org/torproject/onionoo/writer/UptimeDocumentWriterTest.java
index 3504509..b1ba2ed 100644
--- a/src/test/java/org/torproject/onionoo/writer/UptimeDocumentWriterTest.java
+++ b/src/test/java/org/torproject/onionoo/writer/UptimeDocumentWriterTest.java
@@ -77,6 +77,12 @@ public class UptimeDocumentWriterTest {
         (int) (FOUR_HOURS / ONE_SECOND), count, values);
   }
 
+  private void assertFiveYearGraph(UptimeDocument document, int graphs,
+      String first, String last, int count, List<Integer> values) {
+    this.assertGraph(document, graphs, "5_years", first, last,
+        (int) (DateTimeHelper.TEN_DAYS / ONE_SECOND), count, values);
+  }
+
   private void assertGraph(UptimeDocument document, int graphs,
       String graphName, String first, String last, int interval,
       int count, List<Integer> values) {
@@ -93,7 +99,7 @@ public class UptimeDocumentWriterTest {
         (int) history.getInterval());
     assertEquals("Factor should be 1.0 / 999.0.", 1.0 / 999.0,
         (double) history.getFactor(), 0.01);
-    assertEquals("There should be one data point per hour.", count,
+    assertEquals("There should be " + count + " data points.", count,
         (int) history.getCount());
     assertEquals("Count should be the same as the number of values.",
         count, history.getValues().size());
@@ -244,5 +250,41 @@ public class UptimeDocumentWriterTest {
         "2014-03-16 14:00:00", 2,
         Arrays.asList(new Integer[] { 499, 249 }));
   }
+
+  @Test
+  public void testFiveYearsLessThan20Percent() {
+    /* This relay was running for exactly 11 days and 23 hours over 2 years ago.
+     * This time period exactly matches 100% of a data point interval of 10 days
+     * plus a tiny bit less than 20% of the next data point interval. */
+    this.addStatusOneWeekSample("r 2012-03-05-00 287\n",
+        "r 2012-03-05-00 287\n");
+    UptimeDocumentWriter writer = new UptimeDocumentWriter();
+    DescriptorSourceFactory.getDescriptorSource().readDescriptors();
+    writer.writeDocuments();
+    assertEquals("Should write exactly one document.", 1,
+        this.documentStore.getPerformedStoreOperations());
+    UptimeDocument document = this.documentStore.getDocument(
+        UptimeDocument.class, GABELMOO_FINGERPRINT);
+    assertEquals("Should not contain any graph.", 0,
+        document.getUptime().size());
+  }
+
+  @Test
+  public void testFiveYearsAtLeast20Percent() {
+    /* This relay was running for exactly 12 days over 2 years ago. This time
+     * period exactly matches 100% of a data point interval of 10 days plus 20%
+     * of the next data point interval. */
+    this.addStatusOneWeekSample("r 2012-03-05-00 288\n",
+        "r 2012-03-05-00 288\n");
+    UptimeDocumentWriter writer = new UptimeDocumentWriter();
+    DescriptorSourceFactory.getDescriptorSource().readDescriptors();
+    writer.writeDocuments();
+    assertEquals("Should write exactly one document.", 1,
+        this.documentStore.getPerformedStoreOperations());
+    UptimeDocument document = this.documentStore.getDocument(
+        UptimeDocument.class, GABELMOO_FINGERPRINT);
+    this.assertFiveYearGraph(document, 1, "2012-03-10 00:00:00",
+        "2012-03-20 00:00:00", 2, Arrays.asList(new Integer[] { 999, 999 }));
+  }
 }
 





More information about the tor-commits mailing list