1
0
Fork 0
mirror of https://github.com/pgpainless/pgpainless.git synced 2025-01-08 19:27:57 +01:00

Remove dependency on deprecated com.ginsberg:junit5-system-exit library

This commit is contained in:
Paul Schaub 2024-12-21 11:14:37 +01:00
parent 391549a7d6
commit 3e96af5450
Signed by: vanitasvitae
GPG key ID: 62BEE9264BF17311
5 changed files with 56 additions and 155 deletions

View file

@ -32,8 +32,6 @@ dependencies {
testImplementation "org.junit.jupiter:junit-jupiter-api:$junitVersion" testImplementation "org.junit.jupiter:junit-jupiter-api:$junitVersion"
testRuntimeOnly "org.junit.jupiter:junit-jupiter-engine:$junitVersion" testRuntimeOnly "org.junit.jupiter:junit-jupiter-engine:$junitVersion"
// https://todd.ginsberg.com/post/testing-system-exit/
testImplementation 'com.ginsberg:junit5-system-exit:1.1.2'
// implementation "ch.qos.logback:logback-core:1.2.6" // implementation "ch.qos.logback:logback-core:1.2.6"
// We want logback logging in tests and in the app // We want logback logging in tests and in the app

View file

@ -4,28 +4,35 @@
package org.pgpainless.cli; package org.pgpainless.cli;
import com.ginsberg.junit.exit.ExpectSystemExitWithStatus;
import com.ginsberg.junit.exit.FailOnSystemExit;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.pgpainless.cli.commands.CLITest;
import org.slf4j.LoggerFactory;
import sop.exception.SOPGPException; import sop.exception.SOPGPException;
public class ExitCodeTest { import java.io.IOException;
@Test import static org.junit.jupiter.api.Assertions.assertEquals;
@ExpectSystemExitWithStatus(SOPGPException.UnsupportedSubcommand.EXIT_CODE)
public void testUnknownCommand_69() { public class ExitCodeTest extends CLITest {
PGPainlessCLI.main(new String[] {"generate-kex"});
public ExitCodeTest() {
super(LoggerFactory.getLogger(ExitCodeTest.class));
} }
@Test @Test
@ExpectSystemExitWithStatus(SOPGPException.UnsupportedOption.EXIT_CODE) public void testUnknownCommand_69() throws IOException {
public void testCommandWithUnknownOption_37() { assertEquals(SOPGPException.UnsupportedSubcommand.EXIT_CODE,
PGPainlessCLI.main(new String[] {"generate-key", "-k", "\"k is unknown\""}); executeCommand("unsupported-subcommand"));
} }
@Test @Test
@FailOnSystemExit public void testCommandWithUnknownOption_37() throws IOException {
public void successfulExecutionDoesNotTerminateJVM() { assertEquals(SOPGPException.UnsupportedOption.EXIT_CODE,
PGPainlessCLI.main(new String[] {"version"}); executeCommand("generate-key", "-k", "\"k is unknown\""));
}
@Test
public void successfulExecutionDoesNotTerminateJVM() throws IOException {
assertSuccess(executeCommand("version"));
} }
} }

View file

@ -14,7 +14,6 @@ import java.io.IOException;
import java.security.InvalidAlgorithmParameterException; import java.security.InvalidAlgorithmParameterException;
import java.security.NoSuchAlgorithmException; import java.security.NoSuchAlgorithmException;
import com.ginsberg.junit.exit.FailOnSystemExit;
import org.bouncycastle.openpgp.PGPException; import org.bouncycastle.openpgp.PGPException;
import org.bouncycastle.openpgp.PGPPublicKeyRing; import org.bouncycastle.openpgp.PGPPublicKeyRing;
import org.bouncycastle.openpgp.PGPSecretKeyRing; import org.bouncycastle.openpgp.PGPSecretKeyRing;
@ -83,7 +82,6 @@ public class RoundTripEncryptDecryptCmdTest extends CLITest {
"-----END PGP PUBLIC KEY BLOCK-----"; "-----END PGP PUBLIC KEY BLOCK-----";
@Test @Test
@FailOnSystemExit
public void encryptAndDecryptAMessage() throws IOException { public void encryptAndDecryptAMessage() throws IOException {
// Juliets key and cert // Juliets key and cert
File julietKeyFile = pipeStdoutToFile("juliet.key"); File julietKeyFile = pipeStdoutToFile("juliet.key");

View file

@ -4,104 +4,49 @@
package org.pgpainless.cli.commands; package org.pgpainless.cli.commands;
import static org.junit.jupiter.api.Assertions.assertEquals; import static org.junit.jupiter.api.Assertions.assertFalse;
import static org.junit.jupiter.api.Assertions.assertTrue;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File; import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintStream;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import com.ginsberg.junit.exit.FailOnSystemExit;
import org.junit.jupiter.api.AfterAll;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.pgpainless.cli.PGPainlessCLI; import org.slf4j.LoggerFactory;
import org.pgpainless.cli.TestUtils;
public class RoundTripInlineSignVerifyCmdTest { public class RoundTripInlineSignVerifyCmdTest extends CLITest {
private static File tempDir;
private static PrintStream originalSout;
@BeforeAll public RoundTripInlineSignVerifyCmdTest() {
public static void prepare() throws IOException { super(LoggerFactory.getLogger(RoundTripInlineSignVerifyCmdTest.class));
tempDir = TestUtils.createTempDirectory();
} }
@Test @Test
@FailOnSystemExit
public void encryptAndDecryptAMessage() throws IOException { public void encryptAndDecryptAMessage() throws IOException {
originalSout = System.out;
File sigmundKeyFile = new File(tempDir, "sigmund.key");
assertTrue(sigmundKeyFile.createNewFile());
File sigmundCertFile = new File(tempDir, "sigmund.cert");
assertTrue(sigmundCertFile.createNewFile());
File msgFile = new File(tempDir, "signed.asc");
assertTrue(msgFile.createNewFile());
File passwordFile = new File(tempDir, "password");
assertTrue(passwordFile.createNewFile());
// write password file // write password file
FileOutputStream passwordOut = new FileOutputStream(passwordFile); File password = writeFile("password", "sw0rdf1sh");
passwordOut.write("sw0rdf1sh".getBytes(StandardCharsets.UTF_8));
passwordOut.close();
// generate key // generate key
OutputStream sigmundKeyOut = new FileOutputStream(sigmundKeyFile); File sigmundKey = pipeStdoutToFile("sigmund.key");
System.setOut(new PrintStream(sigmundKeyOut)); assertSuccess(executeCommand("generate-key", "--with-key-password=" + password.getAbsolutePath(),
PGPainlessCLI.execute("generate-key", "Sigmund Freud <sigmund@pgpainless.org>"));
"--with-key-password=" + passwordFile.getAbsolutePath(),
"Sigmund Freud <sigmund@pgpainless.org>");
sigmundKeyOut.close();
// extract cert // extract cert
FileInputStream sigmundKeyIn = new FileInputStream(sigmundKeyFile); File sigmundCert = pipeStdoutToFile("sigmund.cert");
System.setIn(sigmundKeyIn); pipeFileToStdin(sigmundKey);
OutputStream sigmundCertOut = new FileOutputStream(sigmundCertFile); assertSuccess(executeCommand("extract-cert"));
System.setOut(new PrintStream(sigmundCertOut));
PGPainlessCLI.execute("extract-cert");
sigmundKeyIn.close();
sigmundCertOut.close();
// sign message // sign message
String msg = "Hello World!\n"; pipeBytesToStdin("Hello, World!\n".getBytes(StandardCharsets.UTF_8));
ByteArrayInputStream msgIn = new ByteArrayInputStream(msg.getBytes(StandardCharsets.UTF_8)); File signedMsg = pipeStdoutToFile("signed.asc");
System.setIn(msgIn); assertSuccess(executeCommand("inline-sign", "--with-key-password=" + password.getAbsolutePath(),
OutputStream msgAscOut = new FileOutputStream(msgFile); sigmundKey.getAbsolutePath()));
System.setOut(new PrintStream(msgAscOut));
PGPainlessCLI.execute("inline-sign",
"--with-key-password=" + passwordFile.getAbsolutePath(),
sigmundKeyFile.getAbsolutePath());
msgAscOut.close();
File verifyFile = new File(tempDir, "verify.txt"); // verify message
File verifyFile = nonExistentFile("verify.txt");
pipeFileToStdin(signedMsg);
assertSuccess(executeCommand("inline-verify", "--verifications-out", verifyFile.getAbsolutePath(),
sigmundCert.getAbsolutePath()));
FileInputStream msgAscIn = new FileInputStream(msgFile); String verifications = readStringFromFile(verifyFile);
System.setIn(msgAscIn); assertFalse(verifications.trim().isEmpty());
ByteArrayOutputStream out = new ByteArrayOutputStream();
PrintStream pOut = new PrintStream(out);
System.setOut(pOut);
PGPainlessCLI.execute("inline-verify",
"--verifications-out", verifyFile.getAbsolutePath(),
sigmundCertFile.getAbsolutePath());
msgAscIn.close();
assertEquals(msg, out.toString());
}
@AfterAll
public static void after() {
System.setOut(originalSout);
// CHECKSTYLE:OFF
System.out.println(tempDir.getAbsolutePath());
// CHECKSTYLE:ON
} }
} }

View file

@ -4,28 +4,18 @@
package org.pgpainless.cli.misc; package org.pgpainless.cli.misc;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertTrue; import static org.junit.jupiter.api.Assertions.assertTrue;
import java.io.ByteArrayInputStream;
import java.io.File; import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintStream;
import java.nio.charset.StandardCharsets;
import com.ginsberg.junit.exit.ExpectSystemExitWithStatus;
import org.bouncycastle.util.io.Streams;
import org.junit.jupiter.api.AfterAll;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
import org.pgpainless.cli.PGPainlessCLI; import org.pgpainless.cli.commands.CLITest;
import org.pgpainless.cli.TestUtils; import org.slf4j.LoggerFactory;
import sop.exception.SOPGPException; import sop.exception.SOPGPException;
public class SignUsingPublicKeyBehaviorTest { public class SignUsingPublicKeyBehaviorTest extends CLITest {
public static final String KEY_THAT_IS_A_CERT = "" + public static final String KEY_THAT_IS_A_CERT = "" +
"-----BEGIN PGP PUBLIC KEY BLOCK-----\n" + "-----BEGIN PGP PUBLIC KEY BLOCK-----\n" +
@ -89,61 +79,24 @@ public class SignUsingPublicKeyBehaviorTest {
"=oJQ2\n" + "=oJQ2\n" +
"-----END PGP PUBLIC KEY BLOCK-----"; "-----END PGP PUBLIC KEY BLOCK-----";
public SignUsingPublicKeyBehaviorTest() {
private static File tempDir; super(LoggerFactory.getLogger(SignUsingPublicKeyBehaviorTest.class));
private static PrintStream originalSout;
@BeforeAll
public static void prepare() throws IOException {
tempDir = TestUtils.createTempDirectory();
} }
@Test @Test
@ExpectSystemExitWithStatus(SOPGPException.KeyCannotSign.EXIT_CODE)
public void testSignatureCreationAndVerification() throws IOException { public void testSignatureCreationAndVerification() throws IOException {
originalSout = System.out;
InputStream originalIn = System.in;
// Write alice key to disc // Write alice key to disc
File aliceKeyFile = new File(tempDir, "alice.key"); File aliceKeyFile = writeFile("alice.key", KEY_THAT_IS_A_CERT);
assertTrue(aliceKeyFile.createNewFile());
OutputStream aliceKeyOut = new FileOutputStream(aliceKeyFile);
Streams.pipeAll(new ByteArrayInputStream(KEY_THAT_IS_A_CERT.getBytes(StandardCharsets.UTF_8)), aliceKeyOut);
aliceKeyOut.close();
// Write alice pub key to disc
File aliceCertFile = new File(tempDir, "alice.pub");
assertTrue(aliceCertFile.createNewFile());
OutputStream aliceCertOut = new FileOutputStream(aliceCertFile);
Streams.pipeAll(new ByteArrayInputStream(KEY_THAT_IS_A_CERT.getBytes(StandardCharsets.UTF_8)), aliceCertOut);
aliceCertOut.close();
// Write test data to disc // Write test data to disc
String data = "If privacy is outlawed, only outlaws will have privacy.\n"; File dataFile = writeFile("data", "If privacy is outlawed, only outlaws will have privacy.\n");
File dataFile = new File(tempDir, "data");
assertTrue(dataFile.createNewFile());
FileOutputStream dataOut = new FileOutputStream(dataFile);
Streams.pipeAll(new ByteArrayInputStream(data.getBytes(StandardCharsets.UTF_8)), dataOut);
dataOut.close();
// Sign test data // Sign test data
FileInputStream dataIn = new FileInputStream(dataFile); File sigFile = pipeStdoutToFile("sig.asc");
System.setIn(dataIn); pipeFileToStdin(dataFile);
File sigFile = new File(tempDir, "sig.asc"); assertEquals(SOPGPException.KeyCannotSign.EXIT_CODE,
assertTrue(sigFile.createNewFile()); executeCommand("sign", "--armor", aliceKeyFile.getAbsolutePath()));
FileOutputStream sigOut = new FileOutputStream(sigFile);
System.setOut(new PrintStream(sigOut));
PGPainlessCLI.main(new String[] {"sign", "--armor", aliceKeyFile.getAbsolutePath()});
System.setIn(originalIn); assertTrue(readStringFromFile(sigFile).trim().isEmpty());
}
@AfterAll
public static void after() {
System.setOut(originalSout);
// CHECKSTYLE:OFF
System.out.println(tempDir.getAbsolutePath());
// CHECKSTYLE:ON
} }
} }