[tor-commits] [onionoo/master] Fix possible NPE and make tests pass again.

karsten at torproject.org karsten at torproject.org
Thu Aug 31 14:57:09 UTC 2017


commit b2b1bf1d0b2bce7748386b3ecdafec7391890fe6
Author: iwakeh <iwakeh at torproject.org>
Date:   Wed Aug 30 20:37:37 2017 +0000

    Fix possible NPE and make tests pass again.
    
    Also, added error logging for indexing process.
---
 .../org/torproject/onionoo/server/NodeIndexer.java | 30 +++++++++++++---------
 1 file changed, 18 insertions(+), 12 deletions(-)

diff --git a/src/main/java/org/torproject/onionoo/server/NodeIndexer.java b/src/main/java/org/torproject/onionoo/server/NodeIndexer.java
index db13ed9..5411d0e 100644
--- a/src/main/java/org/torproject/onionoo/server/NodeIndexer.java
+++ b/src/main/java/org/torproject/onionoo/server/NodeIndexer.java
@@ -91,7 +91,7 @@ public class NodeIndexer implements ServletContextListener, Runnable {
    * background thread. */
   public synchronized void startIndexing() {
     if (this.nodeIndexerThread == null) {
-      this.nodeIndexerThread = new Thread(this);
+      this.nodeIndexerThread = new Thread(this, "Onionoo-Node-Indexer");
       this.nodeIndexerThread.setDaemon(true);
       this.nodeIndexerThread.start();
     }
@@ -103,14 +103,18 @@ public class NodeIndexer implements ServletContextListener, Runnable {
 
   @Override
   public void run() {
-    while (this.nodeIndexerThread != null) {
-      this.indexNodeStatuses();
-      try {
-        Thread.sleep(ONE_MINUTE);
-      } catch (InterruptedException e) {
-        /* Nothing that we could handle, just check if there's new data
-         * to index now. */
+    try {
+      while (this.nodeIndexerThread != null) {
+        this.indexNodeStatuses();
+        try {
+          Thread.sleep(ONE_MINUTE);
+        } catch (InterruptedException e) {
+          /* Nothing that we could handle, just check if there's new data
+           * to index now. */
+        }
       }
+    } catch (Throwable th) { // catch all and log
+      log.error("Indexing failed: {}", th.getMessage(), th);
     }
   }
 
@@ -247,11 +251,13 @@ public class NodeIndexer implements ServletContextListener, Runnable {
       newRelaysByContact.get(contact).add(fingerprint);
       newRelaysByContact.get(contact).add(hashedFingerprint);
       String version = entry.getVersion();
-      if (!newRelaysByVersion.containsKey(version)) {
-        newRelaysByVersion.put(version, new HashSet<String>());
+      if (null != version) {
+        if (!newRelaysByVersion.containsKey(version)) {
+          newRelaysByVersion.put(version, new HashSet<String>());
+        }
+        newRelaysByVersion.get(version).add(fingerprint);
+        newRelaysByVersion.get(version).add(hashedFingerprint);
       }
-      newRelaysByVersion.get(version).add(fingerprint);
-      newRelaysByVersion.get(version).add(hashedFingerprint);
     }
     /* This loop can go away once all Onionoo services had their hourly
      * updater write effective families to summary documents at least





More information about the tor-commits mailing list