commit 61881b9c76ff821d2f42b05a950524c7a087f8a2 Author: Karsten Loesing karsten.loesing@gmx.net Date: Mon Aug 20 11:01:28 2018 +0200
Simplify bridge descriptor tests. --- .../bridgedescs/SanitizedBridgesWriterTest.java | 84 +++++++++++----------- .../bridgedescs/TestDescriptorBuilder.java | 11 ++- 2 files changed, 46 insertions(+), 49 deletions(-)
diff --git a/src/test/java/org/torproject/metrics/collector/bridgedescs/SanitizedBridgesWriterTest.java b/src/test/java/org/torproject/metrics/collector/bridgedescs/SanitizedBridgesWriterTest.java index 91332a5..b791f88 100644 --- a/src/test/java/org/torproject/metrics/collector/bridgedescs/SanitizedBridgesWriterTest.java +++ b/src/test/java/org/torproject/metrics/collector/bridgedescs/SanitizedBridgesWriterTest.java @@ -224,7 +224,7 @@ public class SanitizedBridgesWriterTest { public void testServerDescriptorAdditionalAnnotation() throws Exception { this.defaultServerTestDescriptorBuilder.insertBeforeLineStartingWith( - "@purpose bridge", Arrays.asList("@source 198.50.200.131")); + "@purpose bridge", "@source 198.50.200.131"); this.runTest(); assertEquals("Expected 3 sanitized descriptors.", 3, this.parsedFiles.size()); @@ -237,7 +237,7 @@ public class SanitizedBridgesWriterTest { this.configuration.setProperty(Key.BridgeDescriptorMappingsLimit.name(), "30000"); this.defaultServerTestDescriptorBuilder.insertBeforeLineStartingWith( - "platform ", Arrays.asList("or-address [2:5:2:5:2:5:2:5]:25")); + "platform ", "or-address [2:5:2:5:2:5:2:5]:25"); Path bridgeIpSecretsFile = Paths.get(statsDirectory, "bridge-ip-secrets"); BufferedWriter writer = Files.newBufferedWriter(bridgeIpSecretsFile, StandardCharsets.UTF_8); @@ -259,7 +259,7 @@ public class SanitizedBridgesWriterTest { @Test public void testServerDescriptorRouterLineTruncated() throws Exception { this.defaultServerTestDescriptorBuilder.replaceLineStartingWith("router ", - Arrays.asList("router MeekGoogle")); + "router MeekGoogle"); this.runTest(); assertTrue("Sanitized server descriptor with invalid router line.", this.parsedServerDescriptors.isEmpty()); @@ -269,8 +269,8 @@ public class SanitizedBridgesWriterTest { public void testServerDescriptorProtoLine() throws Exception { this.defaultServerTestDescriptorBuilder .replaceLineStartingWith("protocols ", - Arrays.asList("proto Cons=1-2 Desc=1-2 DirCache=1 HSDir=1 HSIntro=3 " - + "HSRend=1-2 Link=1-4 LinkAuth=1 Microdesc=1-2 Relay=1-2")); + "proto Cons=1-2 Desc=1-2 DirCache=1 HSDir=1 HSIntro=3 " + + "HSRend=1-2 Link=1-4 LinkAuth=1 Microdesc=1-2 Relay=1-2"); this.runTest(); assertFalse("Sanitized server descriptor with valid proto line.", this.parsedServerDescriptors.isEmpty()); @@ -279,7 +279,7 @@ public class SanitizedBridgesWriterTest { @Test public void testServerDescriptorFingerprintTruncated() throws Exception { this.defaultServerTestDescriptorBuilder.replaceLineStartingWith( - "fingerprint ", Arrays.asList("fingerprint 4")); + "fingerprint ", "fingerprint 4"); this.runTest(); assertTrue("Sanitized server descriptor with invalid fingerprint " + "line.", this.parsedServerDescriptors.isEmpty()); @@ -289,7 +289,7 @@ public class SanitizedBridgesWriterTest { public void testServerDescriptorFingerprintInvalidHex() throws Exception { this.defaultServerTestDescriptorBuilder.replaceLineStartingWith( - "fingerprint ", Arrays.asList("fingerprint FUN!")); + "fingerprint ", "fingerprint FUN!"); this.runTest(); assertTrue("Sanitized server descriptor with invalid fingerprint " + "line.", this.parsedServerDescriptors.isEmpty()); @@ -299,8 +299,7 @@ public class SanitizedBridgesWriterTest { public void testServerDescriptorFingerprintOpt() throws Exception { this.defaultServerTestDescriptorBuilder .replaceLineStartingWith("fingerprint ", - Arrays.asList("opt fingerprint 46D4 A711 97B8 FA51 5A82 6C6B 017C 522F " - + "E264 655B")); + "opt fingerprint 46D4 A711 97B8 FA51 5A82 6C6B 017C 522F E264 655B"); this.runTest(); this.parsedServerDescriptors.get(0).contains("opt fingerprint 88F7 " + "4584 0F47 CE0C 6A4F E61D 8279 50B0 6F9E 4534"); @@ -310,7 +309,7 @@ public class SanitizedBridgesWriterTest { public void testServerDescriptorExtraInfoDigestInvalidHex() throws Exception { this.defaultServerTestDescriptorBuilder.replaceLineStartingWith( - "extra-info-digest ", Arrays.asList("extra-info-digest 6")); + "extra-info-digest ", "extra-info-digest 6"); this.runTest(); assertTrue("Sanitized server descriptor with invalid extra-info " + "line.", this.parsedServerDescriptors.isEmpty()); @@ -320,9 +319,9 @@ public class SanitizedBridgesWriterTest { public void testServerDescriptorExtraInfoDigestInvalidBase64() throws Exception { this.defaultServerTestDescriptorBuilder.replaceLineStartingWith( - "extra-info-digest ", Arrays.asList("extra-info-digest " + "extra-info-digest ", "extra-info-digest " + "6D03E80568DEFA102968D144CB35FFA6E3355B8A " - + "#*?$%x@nxukmmcT1+UnDg4qh0yKbjVUYKhGL8VksoJA")); + + "#*?$%x@nxukmmcT1+UnDg4qh0yKbjVUYKhGL8VksoJA"); this.runTest(); assertTrue("Invalid base64 in server descriptor accepted.", this.parsedServerDescriptors.isEmpty()); @@ -332,8 +331,8 @@ public class SanitizedBridgesWriterTest { public void testServerDescriptorExtraInfoDigestSha1Only() throws Exception { this.defaultServerTestDescriptorBuilder.replaceLineStartingWith( - "extra-info-digest ", Arrays.asList("extra-info-digest " - + "6D03E80568DEFA102968D144CB35FFA6E3355B8A")); + "extra-info-digest ", "extra-info-digest " + + "6D03E80568DEFA102968D144CB35FFA6E3355B8A"); this.runTest(); assertTrue("Expected different extra-info-digest line.", this.parsedServerDescriptors.get(0).contains( @@ -344,9 +343,9 @@ public class SanitizedBridgesWriterTest { public void testServerDescriptorExtraInfoDigestThirdArgument() throws Exception { this.defaultServerTestDescriptorBuilder.replaceLineStartingWith( - "extra-info-digest ", Arrays.asList("extra-info-digest " + "extra-info-digest ", "extra-info-digest " + "6D03E80568DEFA102968D144CB35FFA6E3355B8A " - + "cy/LwP7nxukmmcT1+UnDg4qh0yKbjVUYKhGL8VksoJA 00")); + + "cy/LwP7nxukmmcT1+UnDg4qh0yKbjVUYKhGL8VksoJA 00"); this.runTest(); assertTrue("Third argument to extra-info-digest line should not be " + "dropped silently.", this.parsedServerDescriptors.isEmpty()); @@ -355,9 +354,9 @@ public class SanitizedBridgesWriterTest { @Test public void testServerDescriptorExtraInfoDigestOpt() throws Exception { this.defaultServerTestDescriptorBuilder.replaceLineStartingWith( - "extra-info-digest ", Arrays.asList("opt extra-info-digest " + "extra-info-digest ", "opt extra-info-digest " + "6D03E80568DEFA102968D144CB35FFA6E3355B8A " - + "cy/LwP7nxukmmcT1+UnDg4qh0yKbjVUYKhGL8VksoJA")); + + "cy/LwP7nxukmmcT1+UnDg4qh0yKbjVUYKhGL8VksoJA"); this.runTest(); this.parsedServerDescriptors.get(0).contains("opt extra-info-digest " + "B026CF0F81712D94BBF1362294882688DF247887 " @@ -367,7 +366,7 @@ public class SanitizedBridgesWriterTest { @Test public void testServerDescriptorRejectOwnAddress() throws Exception { this.defaultServerTestDescriptorBuilder.insertBeforeLineStartingWith( - "reject *:*", Arrays.asList("reject 198.50.200.131:*", "accept *:80")); + "reject *:*", "reject 198.50.200.131:*", "accept *:80"); this.runTest(); List<String> parsedLines = this.parsedServerDescriptors.get(0); for (int i = 0; i < parsedLines.size(); i++) { @@ -387,8 +386,8 @@ public class SanitizedBridgesWriterTest { public void testServerDescriptorEd25519IdentityMasterKeyMismatch() throws Exception { this.defaultServerTestDescriptorBuilder.replaceLineStartingWith( - "master-key-ed25519 ", Arrays.asList("master-key-ed25519 " - + "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA")); + "master-key-ed25519 ", "master-key-ed25519 " + + "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"); this.runTest(); assertTrue("Mismatch between Ed25519 identity and master key.", this.parsedServerDescriptors.isEmpty()); @@ -397,12 +396,12 @@ public class SanitizedBridgesWriterTest { @Test public void testServerDescriptorEd25519IdentityA() throws Exception { this.defaultServerTestDescriptorBuilder.replaceLineStartingWith( - "identity-ed25519", Arrays.asList("identity-ed25519", + "identity-ed25519", "identity-ed25519", "-----BEGIN ED25519 CERT-----", "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA", "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA", "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=", - "-----END ED25519 CERT-----")); + "-----END ED25519 CERT-----"); this.runTest(); assertTrue("Ed25519 identity all A's conflicts with master key?", this.parsedServerDescriptors.isEmpty()); @@ -414,7 +413,7 @@ public class SanitizedBridgesWriterTest { "ZEXE7RkiEJ1l5Ij9hc9TJOpM7/9XSPZnF/PbMfE0u3n3JbOO3s82GN6BPuA0v2Cs"; this.defaultServerTestDescriptorBuilder .replaceLineStartingWith(change9sTo6s, - Arrays.asList(change9sTo6s.replaceAll("9", "6"))); + change9sTo6s.replaceAll("9", "6")); this.runTest(); assertTrue("Mismatch between identity and master key.", this.parsedServerDescriptors.isEmpty()); @@ -423,12 +422,12 @@ public class SanitizedBridgesWriterTest { @Test public void testServerDescriptorEd25519IdentitySlash() throws Exception { this.defaultServerTestDescriptorBuilder.replaceLineStartingWith( - "identity-ed25519", Arrays.asList("identity-ed25519", + "identity-ed25519", "identity-ed25519", "-----BEGIN ED25519 CERT-----", "////////////////////////////////////////////////////////////////", "////////////////////////////////////////////////////////////////", "///////////////////////////////////////////////////////////=", - "-----END ED25519 CERT-----")); + "-----END ED25519 CERT-----"); this.runTest(); assertTrue("Ed25519 identity all slashes conflicts with master key.", this.parsedServerDescriptors.isEmpty()); @@ -438,7 +437,7 @@ public class SanitizedBridgesWriterTest { public void testServerDescriptorFamilyInvalidFingerprint() throws Exception { this.defaultServerTestDescriptorBuilder.insertBeforeLineStartingWith( - "hidden-service-dir", Arrays.asList("family $0")); + "hidden-service-dir", "family $0"); this.runTest(); assertTrue("Sanitized server descriptor with invalid fingerprint in " + "family line.", this.parsedServerDescriptors.isEmpty()); @@ -453,7 +452,7 @@ public class SanitizedBridgesWriterTest { "fingerprint 46D4 A711 97B8 FA51 5A82 6C6B 017C 522F E264 655B"; this.defaultServerTestDescriptorBuilder.removeLine(fingerprintLine); this.defaultServerTestDescriptorBuilder.insertBeforeLineStartingWith( - "published ", Arrays.asList(fingerprintLine)); + "published ", fingerprintLine); this.runTest(); assertFalse(this.parsedServerDescriptors.isEmpty()); } @@ -499,7 +498,7 @@ public class SanitizedBridgesWriterTest { public void testExtraInfoDescriptorExtraInfoLineTruncated() throws Exception { this.defaultExtraInfoTestDescriptorBuilder.replaceLineStartingWith( - "extra-info ", Arrays.asList("extra-info ")); + "extra-info ", "extra-info "); this.runTest(); }
@@ -507,7 +506,7 @@ public class SanitizedBridgesWriterTest { public void testExtraInfoDescriptorExtraInfoInvalidHex() throws Exception { this.defaultExtraInfoTestDescriptorBuilder.replaceLineStartingWith( - "extra-info ", Arrays.asList("extra-info MeekGoogle 4")); + "extra-info ", "extra-info MeekGoogle 4"); this.runTest(); assertTrue("Sanitized extra-info descriptor with invalid extra-info " + "line.", this.parsedExtraInfoDescriptors.isEmpty()); @@ -516,7 +515,7 @@ public class SanitizedBridgesWriterTest { @Test public void testExtraInfoDescriptorTransportSpace() throws Exception { this.defaultExtraInfoTestDescriptorBuilder.replaceLineStartingWith( - "transport ", Arrays.asList("transport ")); + "transport ", "transport "); this.runTest(); assertTrue("Sanitized extra-info descriptor with invalid transport " + "line.", this.parsedExtraInfoDescriptors.isEmpty()); @@ -525,7 +524,7 @@ public class SanitizedBridgesWriterTest { @Test public void testExtraInfoDescriptorTransportInfoRemoved() throws Exception { this.defaultExtraInfoTestDescriptorBuilder.insertBeforeLineStartingWith( - "bridge-stats-end ", Arrays.asList("transport-info secretkey")); + "bridge-stats-end ", "transport-info secretkey"); this.runTest(); for (String line : this.parsedExtraInfoDescriptors.get(0)) { assertFalse("transport-info line should not have been retained.", @@ -536,11 +535,10 @@ public class SanitizedBridgesWriterTest { @Test public void testExtraInfoDescriptorHidservRetained() throws Exception { this.defaultExtraInfoTestDescriptorBuilder.insertBeforeLineStartingWith( - "transport ", - Arrays.asList("hidserv-stats-end 2016-11-23 14:48:05 (86400 s)", + "transport ", "hidserv-stats-end 2016-11-23 14:48:05 (86400 s)", "hidserv-rend-relayed-cells 27653088 delta_f=2048 epsilon=0.30 " + "bin_size=1024", - "hidserv-dir-onions-seen 204 delta_f=8 epsilon=0.30 bin_size=8")); + "hidserv-dir-onions-seen 204 delta_f=8 epsilon=0.30 bin_size=8"); this.runTest(); int foundHidservLines = 0; if (!this.parsedExtraInfoDescriptors.isEmpty()) { @@ -558,12 +556,12 @@ public class SanitizedBridgesWriterTest { public void testExtraInfoDescriptorPaddingCountsRetained() throws Exception { this.defaultExtraInfoTestDescriptorBuilder.insertBeforeLineStartingWith( "transport ", - Arrays.asList("padding-counts 2017-05-10 01:48:43 (86400 s) " + "padding-counts 2017-05-10 01:48:43 (86400 s) " + "bin-size=10000 write-drop=10000 write-pad=10000 " + "write-total=10000 read-drop=10000 read-pad=10000 " + "read-total=70000 enabled-read-pad=0 enabled-read-total=0 " + "enabled-write-pad=0 enabled-write-total=0 " - + "max-chanpad-timers=0")); + + "max-chanpad-timers=0"); this.runTest(); int foundPaddingCountsLines = 0; if (!this.parsedExtraInfoDescriptors.isEmpty()) { @@ -581,7 +579,7 @@ public class SanitizedBridgesWriterTest { public void testExtraInfoDescriptorRouterSignatureLineSpace() throws Exception { this.defaultExtraInfoTestDescriptorBuilder.replaceLineStartingWith( - "router-signature", Arrays.asList("router-signature ")); + "router-signature", "router-signature "); this.runTest(); assertTrue("Sanitized extra-info descriptor with invalid " + "router-signature line.", @@ -639,16 +637,16 @@ public class SanitizedBridgesWriterTest { @Test public void testNetworkStatusRlineTruncated() throws Exception { this.defaultNetworkStatusTestDescriptorBuilder.replaceLineStartingWith("r ", - Arrays.asList("r MeekGoogle")); + "r MeekGoogle"); this.runTest(); }
@Test public void testNetworkStatusRlineInvalidBase64() throws Exception { this.defaultNetworkStatusTestDescriptorBuilder.replaceLineStartingWith("r ", - Arrays.asList("r MeekGoogle R#SnE*e4+lFag:xr_XxSL+J;ZVs " + "r MeekGoogle R#SnE*e4+lFag:xr_XxSL+J;ZVs " + "g+M7'w+lG$mv6NW9&RmvzLO(R0Y 2016-06-30 21:43:52 " - + "198.50.200.131 8008 0")); + + "198.50.200.131 8008 0"); this.runTest(); assertTrue("Should not have accepted invalid base64.", this.parsedNetworkStatuses.isEmpty()); @@ -659,7 +657,7 @@ public class SanitizedBridgesWriterTest { this.configuration.setProperty(Key.ReplaceIpAddressesWithHashes.name(), "true"); this.defaultNetworkStatusTestDescriptorBuilder - .insertBeforeLineStartingWith("s ", Arrays.asList("a 198.50.200.132")); + .insertBeforeLineStartingWith("s ", "a 198.50.200.132"); this.runTest(); for (String line : this.parsedNetworkStatuses.get(0)) { if (line.startsWith("a ")) { @@ -671,7 +669,7 @@ public class SanitizedBridgesWriterTest { @Test public void testNetworkStatusVLineUnknown() throws Exception { this.defaultNetworkStatusTestDescriptorBuilder - .insertBeforeLineStartingWith("w ", Arrays.asList("v Tor 0.2.7.6")); + .insertBeforeLineStartingWith("w ", "v Tor 0.2.7.6"); this.runTest(); assertTrue("Should not have sanitized status with v line which is unknown " + "in this descriptor type.", this.parsedNetworkStatuses.isEmpty()); diff --git a/src/test/java/org/torproject/metrics/collector/bridgedescs/TestDescriptorBuilder.java b/src/test/java/org/torproject/metrics/collector/bridgedescs/TestDescriptorBuilder.java index 2fad06a..81df984 100644 --- a/src/test/java/org/torproject/metrics/collector/bridgedescs/TestDescriptorBuilder.java +++ b/src/test/java/org/torproject/metrics/collector/bridgedescs/TestDescriptorBuilder.java @@ -10,7 +10,6 @@ import java.io.IOException; import java.io.OutputStream; import java.util.ArrayList; import java.util.Arrays; -import java.util.List;
/** Builds a descriptor by concatenating the given lines with newlines and * writing the output to the given output stream. */ @@ -33,10 +32,10 @@ abstract class TestDescriptorBuilder extends ArrayList<String> { * given lines before it, or fails if no line can be found with that line * start. */ void insertBeforeLineStartingWith(String lineStart, - List<String> linesToInsert) { + String ... linesToInsert) { for (int i = 0; i < this.size(); i++) { if (this.get(i).startsWith(lineStart)) { - this.addAll(i, linesToInsert); + this.addAll(i, Arrays.asList(linesToInsert)); return; } } @@ -46,13 +45,13 @@ abstract class TestDescriptorBuilder extends ArrayList<String> { /** Finds the first line that starts with the given line start and replaces * that line and possibly subsequent lines, or fails if no line can be found * with that line start or there are not enough lines left to replace. */ - void replaceLineStartingWith(String lineStart, List<String> linesToReplace) { + void replaceLineStartingWith(String lineStart, String ... linesToReplace) { for (int i = 0; i < this.size(); i++) { if (this.get(i).startsWith(lineStart)) { - for (int j = 0; j < linesToReplace.size(); j++) { + for (int j = 0; j < linesToReplace.length; j++) { assertTrue("Not enough lines left to replace.", this.size() > i + j); - this.set(i + j, linesToReplace.get(j)); + this.set(i + j, linesToReplace[j]); } return; }