mirror of
https://github.com/pgpainless/pgpainless.git
synced 2024-11-26 06:12:06 +01:00
Rename command tests and add generate-key test for encrypted keys
This commit is contained in:
parent
a3b2070e76
commit
7074ff5f2f
8 changed files with 120 additions and 59 deletions
|
@ -25,7 +25,7 @@ import org.junit.jupiter.api.Test;
|
||||||
import org.pgpainless.PGPainless;
|
import org.pgpainless.PGPainless;
|
||||||
import org.pgpainless.cli.PGPainlessCLI;
|
import org.pgpainless.cli.PGPainlessCLI;
|
||||||
|
|
||||||
public class ArmorTest {
|
public class ArmorCmdTest {
|
||||||
|
|
||||||
private static PrintStream originalSout;
|
private static PrintStream originalSout;
|
||||||
|
|
|
@ -25,7 +25,7 @@ import org.junit.jupiter.api.Test;
|
||||||
import org.pgpainless.PGPainless;
|
import org.pgpainless.PGPainless;
|
||||||
import org.pgpainless.cli.PGPainlessCLI;
|
import org.pgpainless.cli.PGPainlessCLI;
|
||||||
|
|
||||||
public class DearmorTest {
|
public class DearmorCmdTest {
|
||||||
|
|
||||||
private PrintStream originalSout;
|
private PrintStream originalSout;
|
||||||
|
|
|
@ -23,7 +23,7 @@ import org.pgpainless.PGPainless;
|
||||||
import org.pgpainless.cli.PGPainlessCLI;
|
import org.pgpainless.cli.PGPainlessCLI;
|
||||||
import org.pgpainless.key.info.KeyRingInfo;
|
import org.pgpainless.key.info.KeyRingInfo;
|
||||||
|
|
||||||
public class ExtractCertTest {
|
public class ExtractCertCmdTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@FailOnSystemExit
|
@FailOnSystemExit
|
|
@ -0,0 +1,114 @@
|
||||||
|
// SPDX-FileCopyrightText: 2021 Paul Schaub <vanitasvitae@fsfe.org>
|
||||||
|
//
|
||||||
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
package org.pgpainless.cli.commands;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertArrayEquals;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertFalse;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
import static org.pgpainless.cli.TestUtils.ARMOR_PRIVATE_KEY_HEADER_BYTES;
|
||||||
|
|
||||||
|
import java.io.ByteArrayOutputStream;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.PrintStream;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.nio.file.Files;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
import com.ginsberg.junit.exit.FailOnSystemExit;
|
||||||
|
import org.bouncycastle.openpgp.PGPException;
|
||||||
|
import org.bouncycastle.openpgp.PGPSecretKey;
|
||||||
|
import org.bouncycastle.openpgp.PGPSecretKeyRing;
|
||||||
|
import org.bouncycastle.openpgp.operator.PBESecretKeyDecryptor;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import org.pgpainless.PGPainless;
|
||||||
|
import org.pgpainless.cli.PGPainlessCLI;
|
||||||
|
import org.pgpainless.key.info.KeyInfo;
|
||||||
|
import org.pgpainless.key.info.KeyRingInfo;
|
||||||
|
import org.pgpainless.key.protection.UnlockSecretKey;
|
||||||
|
import org.pgpainless.util.Passphrase;
|
||||||
|
|
||||||
|
public class GenerateCertCmdTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@FailOnSystemExit
|
||||||
|
public void testKeyGeneration() throws IOException, PGPException {
|
||||||
|
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
||||||
|
System.setOut(new PrintStream(out));
|
||||||
|
PGPainlessCLI.execute("generate-key", "--armor", "Juliet Capulet <juliet@capulet.lit>");
|
||||||
|
|
||||||
|
PGPSecretKeyRing secretKeys = PGPainless.readKeyRing().secretKeyRing(out.toByteArray());
|
||||||
|
KeyRingInfo info = PGPainless.inspectKeyRing(secretKeys);
|
||||||
|
assertTrue(info.isFullyDecrypted());
|
||||||
|
assertTrue(info.isUserIdValid("Juliet Capulet <juliet@capulet.lit>"));
|
||||||
|
|
||||||
|
for (PGPSecretKey key : secretKeys) {
|
||||||
|
assertTrue(testPassphrase(key, null));
|
||||||
|
}
|
||||||
|
|
||||||
|
byte[] outBegin = new byte[37];
|
||||||
|
System.arraycopy(out.toByteArray(), 0, outBegin, 0, 37);
|
||||||
|
assertArrayEquals(outBegin, ARMOR_PRIVATE_KEY_HEADER_BYTES);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@FailOnSystemExit
|
||||||
|
public void testGenerateKeyWithPassword() throws IOException, PGPException {
|
||||||
|
PrintStream orig = System.out;
|
||||||
|
try {
|
||||||
|
// Write password to file
|
||||||
|
Path tempDir = Files.createTempDirectory("genkey");
|
||||||
|
File passwordFile = new File(tempDir.toFile(), "password");
|
||||||
|
passwordFile.createNewFile();
|
||||||
|
passwordFile.deleteOnExit();
|
||||||
|
FileOutputStream fileOut = new FileOutputStream(passwordFile);
|
||||||
|
fileOut.write("sw0rdf1sh".getBytes(StandardCharsets.UTF_8));
|
||||||
|
fileOut.flush();
|
||||||
|
fileOut.close();
|
||||||
|
|
||||||
|
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
||||||
|
System.setOut(new PrintStream(out));
|
||||||
|
PGPainlessCLI.execute("generate-key", "Juliet Capulet <juliet@capulet.lit>",
|
||||||
|
"--with-key-password", passwordFile.getAbsolutePath());
|
||||||
|
|
||||||
|
PGPSecretKeyRing secretKeys = PGPainless.readKeyRing().secretKeyRing(out.toByteArray());
|
||||||
|
KeyRingInfo info = PGPainless.inspectKeyRing(secretKeys);
|
||||||
|
assertFalse(info.isFullyDecrypted());
|
||||||
|
assertTrue(info.isFullyEncrypted());
|
||||||
|
|
||||||
|
for (PGPSecretKey key : secretKeys) {
|
||||||
|
assertTrue(testPassphrase(key, "sw0rdf1sh"));
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
System.setOut(orig);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean testPassphrase(PGPSecretKey key, String passphrase) throws PGPException {
|
||||||
|
if (KeyInfo.isEncrypted(key)) {
|
||||||
|
UnlockSecretKey.unlockSecretKey(key, Passphrase.fromPassword(passphrase));
|
||||||
|
} else {
|
||||||
|
if (passphrase != null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
UnlockSecretKey.unlockSecretKey(key, (PBESecretKeyDecryptor) null);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@FailOnSystemExit
|
||||||
|
public void testNoArmor() {
|
||||||
|
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
||||||
|
System.setOut(new PrintStream(out));
|
||||||
|
PGPainlessCLI.execute("generate-key", "--no-armor", "Test <test@test.test>");
|
||||||
|
|
||||||
|
byte[] outBegin = new byte[37];
|
||||||
|
System.arraycopy(out.toByteArray(), 0, outBegin, 0, 37);
|
||||||
|
assertFalse(Arrays.equals(outBegin, ARMOR_PRIVATE_KEY_HEADER_BYTES));
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,53 +0,0 @@
|
||||||
// SPDX-FileCopyrightText: 2021 Paul Schaub <vanitasvitae@fsfe.org>
|
|
||||||
//
|
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
package org.pgpainless.cli.commands;
|
|
||||||
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertArrayEquals;
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertFalse;
|
|
||||||
import static org.junit.jupiter.api.Assertions.assertTrue;
|
|
||||||
import static org.pgpainless.cli.TestUtils.ARMOR_PRIVATE_KEY_HEADER_BYTES;
|
|
||||||
|
|
||||||
import java.io.ByteArrayOutputStream;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.PrintStream;
|
|
||||||
import java.util.Arrays;
|
|
||||||
|
|
||||||
import com.ginsberg.junit.exit.FailOnSystemExit;
|
|
||||||
import org.bouncycastle.openpgp.PGPSecretKeyRing;
|
|
||||||
import org.junit.jupiter.api.Test;
|
|
||||||
import org.pgpainless.PGPainless;
|
|
||||||
import org.pgpainless.cli.PGPainlessCLI;
|
|
||||||
import org.pgpainless.key.info.KeyRingInfo;
|
|
||||||
|
|
||||||
public class GenerateCertTest {
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@FailOnSystemExit
|
|
||||||
public void testKeyGeneration() throws IOException {
|
|
||||||
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
|
||||||
System.setOut(new PrintStream(out));
|
|
||||||
PGPainlessCLI.execute("generate-key", "--armor", "Juliet Capulet <juliet@capulet.lit>");
|
|
||||||
|
|
||||||
PGPSecretKeyRing secretKeys = PGPainless.readKeyRing().secretKeyRing(out.toByteArray());
|
|
||||||
KeyRingInfo info = PGPainless.inspectKeyRing(secretKeys);
|
|
||||||
assertTrue(info.isUserIdValid("Juliet Capulet <juliet@capulet.lit>"));
|
|
||||||
|
|
||||||
byte[] outBegin = new byte[37];
|
|
||||||
System.arraycopy(out.toByteArray(), 0, outBegin, 0, 37);
|
|
||||||
assertArrayEquals(outBegin, ARMOR_PRIVATE_KEY_HEADER_BYTES);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
@FailOnSystemExit
|
|
||||||
public void testNoArmor() {
|
|
||||||
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
|
||||||
System.setOut(new PrintStream(out));
|
|
||||||
PGPainlessCLI.execute("generate-key", "--no-armor", "Test <test@test.test>");
|
|
||||||
|
|
||||||
byte[] outBegin = new byte[37];
|
|
||||||
System.arraycopy(out.toByteArray(), 0, outBegin, 0, 37);
|
|
||||||
assertFalse(Arrays.equals(outBegin, ARMOR_PRIVATE_KEY_HEADER_BYTES));
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -28,7 +28,7 @@ import org.pgpainless.cli.PGPainlessCLI;
|
||||||
import org.pgpainless.cli.TestUtils;
|
import org.pgpainless.cli.TestUtils;
|
||||||
import sop.exception.SOPGPException;
|
import sop.exception.SOPGPException;
|
||||||
|
|
||||||
public class InlineDetachTest {
|
public class InlineDetachCmdTest {
|
||||||
|
|
||||||
private PrintStream originalSout;
|
private PrintStream originalSout;
|
||||||
private static File tempDir;
|
private static File tempDir;
|
|
@ -24,7 +24,7 @@ import org.junit.jupiter.api.Test;
|
||||||
import org.pgpainless.cli.PGPainlessCLI;
|
import org.pgpainless.cli.PGPainlessCLI;
|
||||||
import org.pgpainless.cli.TestUtils;
|
import org.pgpainless.cli.TestUtils;
|
||||||
|
|
||||||
public class EncryptDecryptTest {
|
public class RoundTripEncryptDecryptCmdTest {
|
||||||
|
|
||||||
private static File tempDir;
|
private static File tempDir;
|
||||||
private static PrintStream originalSout;
|
private static PrintStream originalSout;
|
|
@ -39,7 +39,7 @@ import org.pgpainless.key.OpenPgpV4Fingerprint;
|
||||||
import org.pgpainless.key.info.KeyRingInfo;
|
import org.pgpainless.key.info.KeyRingInfo;
|
||||||
import org.pgpainless.key.util.KeyRingUtils;
|
import org.pgpainless.key.util.KeyRingUtils;
|
||||||
|
|
||||||
public class SignVerifyTest {
|
public class RoundTripSignVerifyCmdTest {
|
||||||
|
|
||||||
private static File tempDir;
|
private static File tempDir;
|
||||||
private static PrintStream originalSout;
|
private static PrintStream originalSout;
|
Loading…
Reference in a new issue