mirror of
https://github.com/pgpainless/pgpainless.git
synced 2025-01-24 10:56:23 +01:00
Add tests for readKeyRing()
This commit is contained in:
parent
e6b89e2c3b
commit
b9845912ee
1 changed files with 52 additions and 0 deletions
|
@ -4,6 +4,7 @@
|
||||||
|
|
||||||
package org.pgpainless.key.parsing;
|
package org.pgpainless.key.parsing;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertArrayEquals;
|
||||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
import static org.junit.jupiter.api.Assertions.assertThrows;
|
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||||
import static org.junit.jupiter.api.Assertions.assertTrue;
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
@ -23,6 +24,7 @@ import org.bouncycastle.bcpg.ArmoredOutputStream;
|
||||||
import org.bouncycastle.bcpg.BCPGOutputStream;
|
import org.bouncycastle.bcpg.BCPGOutputStream;
|
||||||
import org.bouncycastle.bcpg.MarkerPacket;
|
import org.bouncycastle.bcpg.MarkerPacket;
|
||||||
import org.bouncycastle.openpgp.PGPException;
|
import org.bouncycastle.openpgp.PGPException;
|
||||||
|
import org.bouncycastle.openpgp.PGPKeyRing;
|
||||||
import org.bouncycastle.openpgp.PGPPublicKeyRing;
|
import org.bouncycastle.openpgp.PGPPublicKeyRing;
|
||||||
import org.bouncycastle.openpgp.PGPPublicKeyRingCollection;
|
import org.bouncycastle.openpgp.PGPPublicKeyRingCollection;
|
||||||
import org.bouncycastle.openpgp.PGPSecretKeyRing;
|
import org.bouncycastle.openpgp.PGPSecretKeyRing;
|
||||||
|
@ -562,4 +564,54 @@ class KeyRingReaderTest {
|
||||||
assertThrows(IOException.class, () ->
|
assertThrows(IOException.class, () ->
|
||||||
KeyRingReader.readPublicKeyRingCollection(new ByteArrayInputStream(bytes.toByteArray()), 512));
|
KeyRingReader.readPublicKeyRingCollection(new ByteArrayInputStream(bytes.toByteArray()), 512));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testReadKeyRingWithBinaryPublicKey() throws PGPException, InvalidAlgorithmParameterException, NoSuchAlgorithmException, IOException {
|
||||||
|
PGPSecretKeyRing secretKeys = PGPainless.generateKeyRing().modernKeyRing("Alice <alice@pgpainless.org>");
|
||||||
|
PGPPublicKeyRing publicKeys = PGPainless.extractCertificate(secretKeys);
|
||||||
|
byte[] bytes = publicKeys.getEncoded();
|
||||||
|
|
||||||
|
PGPKeyRing keyRing = PGPainless.readKeyRing()
|
||||||
|
.keyRing(bytes);
|
||||||
|
|
||||||
|
assertTrue(keyRing instanceof PGPPublicKeyRing);
|
||||||
|
assertArrayEquals(keyRing.getEncoded(), publicKeys.getEncoded());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testReadKeyRingWithBinarySecretKey() throws PGPException, InvalidAlgorithmParameterException, NoSuchAlgorithmException, IOException {
|
||||||
|
PGPSecretKeyRing secretKeys = PGPainless.generateKeyRing().modernKeyRing("Alice <alice@pgpainless.org>");
|
||||||
|
byte[] bytes = secretKeys.getEncoded();
|
||||||
|
|
||||||
|
PGPKeyRing keyRing = PGPainless.readKeyRing()
|
||||||
|
.keyRing(bytes);
|
||||||
|
|
||||||
|
assertTrue(keyRing instanceof PGPSecretKeyRing);
|
||||||
|
assertArrayEquals(keyRing.getEncoded(), secretKeys.getEncoded());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testReadKeyRingWithArmoredPublicKey() throws PGPException, InvalidAlgorithmParameterException, NoSuchAlgorithmException, IOException {
|
||||||
|
PGPSecretKeyRing secretKeys = PGPainless.generateKeyRing().modernKeyRing("Alice <alice@pgpainless.org>");
|
||||||
|
PGPPublicKeyRing publicKeys = PGPainless.extractCertificate(secretKeys);
|
||||||
|
String armored = PGPainless.asciiArmor(publicKeys);
|
||||||
|
|
||||||
|
PGPKeyRing keyRing = PGPainless.readKeyRing()
|
||||||
|
.keyRing(armored);
|
||||||
|
|
||||||
|
assertTrue(keyRing instanceof PGPPublicKeyRing);
|
||||||
|
assertArrayEquals(keyRing.getEncoded(), publicKeys.getEncoded());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testReadKeyRingWithArmoredSecretKey() throws PGPException, InvalidAlgorithmParameterException, NoSuchAlgorithmException, IOException {
|
||||||
|
PGPSecretKeyRing secretKeys = PGPainless.generateKeyRing().modernKeyRing("Alice <alice@pgpainless.org>");
|
||||||
|
String armored = PGPainless.asciiArmor(secretKeys);
|
||||||
|
|
||||||
|
PGPKeyRing keyRing = PGPainless.readKeyRing()
|
||||||
|
.keyRing(armored);
|
||||||
|
|
||||||
|
assertTrue(keyRing instanceof PGPSecretKeyRing);
|
||||||
|
assertArrayEquals(keyRing.getEncoded(), secretKeys.getEncoded());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue