aboutsummaryrefslogtreecommitdiff
path: root/standalone/src/test/java
diff options
context:
space:
mode:
authorJ08nY2024-08-07 13:31:39 +0200
committerJ08nY2024-08-07 13:31:39 +0200
commit6e399ce3dec913be7728c2892301dd3eceb2cd83 (patch)
treea7e70b800512ac53acd70f455b0a2c97699af330 /standalone/src/test/java
parentb8054933b3d07ef8bfc3bec56b2bb795c1d01e5e (diff)
downloadECTester-6e399ce3dec913be7728c2892301dd3eceb2cd83.tar.gz
ECTester-6e399ce3dec913be7728c2892301dd3eceb2cd83.tar.zst
ECTester-6e399ce3dec913be7728c2892301dd3eceb2cd83.zip
Diffstat (limited to 'standalone/src/test/java')
-rw-r--r--standalone/src/test/java/cz/crcs/ectester/standalone/AppTests.java39
1 files changed, 39 insertions, 0 deletions
diff --git a/standalone/src/test/java/cz/crcs/ectester/standalone/AppTests.java b/standalone/src/test/java/cz/crcs/ectester/standalone/AppTests.java
index d401e58..6072e68 100644
--- a/standalone/src/test/java/cz/crcs/ectester/standalone/AppTests.java
+++ b/standalone/src/test/java/cz/crcs/ectester/standalone/AppTests.java
@@ -10,9 +10,11 @@ import org.junitpioneer.jupiter.StdOut;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.PrintStream;
+import java.util.Arrays;
import java.util.Collections;
import java.util.LinkedList;
import java.util.List;
+import java.util.stream.Collectors;
import java.util.stream.Stream;
import static org.junit.jupiter.api.Assertions.*;
@@ -89,6 +91,43 @@ public class AppTests {
@ParameterizedTest
@MethodSource("libs")
@StdIo()
+ public void deterministicGenerate(String libName, StdOut out) {
+ String[] args = new String[]{"generate", "-ps", "123412341234123412341234123412341234123412341234123412341234123412341234123412341234123412341234", "-n", "10", "-nc", "secg/secp256r1", libName};
+ switch (libName) {
+ case "Botan":
+ case "Crypto++":
+ args = new String[]{"generate", "-ps", "123412341234123412341234123412341234123412341234123412341234123412341234123412341234123412341234", "-n", "10", "-nc", "secg/secp256r1", "-t", "ECDH", libName};
+ break;
+ case "Nettle":
+ case "libgcrypt":
+ case "wolfCrypt":
+ args = new String[]{"generate", "-ps", "123412341234123412341234123412341234123412341234123412341234123412341234123412341234123412341234", "-n", "10", "-cn", "secp256r1", libName};
+ break;
+ case "BoringSSL":
+ args = new String[]{"generate", "-ps", "123412341234123412341234123412341234123412341234123412341234123412341234123412341234123412341234", "-n", "10", "-cn", "prime256v1", libName};
+ break;
+ }
+ ECTesterStandalone.main(args);
+ String out1 = out.capturedString();
+ ECTesterStandalone.main(args);
+ String out2 = out.capturedString().substring(out1.length());
+ if (!out1.contains(";"))
+ return;
+ List<String> lines1 = out1.lines().collect(Collectors.toList());
+ List<String> lines2 = out2.lines().collect(Collectors.toList());
+ assertEquals(lines1.size(), lines2.size());
+ for (int i = 0; i < lines1.size(); ++i) {
+ String[] parts1 = lines1.get(i).split(";");
+ String[] parts2 = lines2.get(i).split(";");
+ assertEquals(parts1[2], parts2[2]);
+ assertEquals(parts1[3], parts2[3]);
+ }
+ }
+
+ @SuppressWarnings("JUnitMalformedDeclaration")
+ @ParameterizedTest
+ @MethodSource("libs")
+ @StdIo()
public void defaultSuite(String libName, StdOut out) {
String[] args = buildCLIArgs(libName, "default");
if (libName.equals("Botan") || libName.equals("Crypto++")) {