test: add tests for detached and clearsign signatures
This commit is contained in:
@@ -27,6 +27,7 @@ import java.util.Date;
|
|||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
|
||||||
|
import org.apache.tools.ant.util.StringUtils;
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
@@ -287,7 +288,7 @@ public class PgpEncryptDecryptTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testAsymmetricSign() {
|
public void testAsymmetricSignBinary() {
|
||||||
|
|
||||||
String plaintext = "dies ist ein plaintext ☭" + TestingUtils.genPassphrase(true);
|
String plaintext = "dies ist ein plaintext ☭" + TestingUtils.genPassphrase(true);
|
||||||
byte[] ciphertext;
|
byte[] ciphertext;
|
||||||
@@ -340,6 +341,118 @@ public class PgpEncryptDecryptTest {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testAsymmetricSignCleartext() {
|
||||||
|
|
||||||
|
String plaintext = "dies ist ein plaintext ☭" + TestingUtils.genPassphrase(true);
|
||||||
|
byte[] ciphertext;
|
||||||
|
|
||||||
|
{ // encrypt data with key
|
||||||
|
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
||||||
|
ByteArrayInputStream in = new ByteArrayInputStream(plaintext.getBytes());
|
||||||
|
|
||||||
|
PgpSignEncryptOperation op = new PgpSignEncryptOperation(RuntimeEnvironment.application,
|
||||||
|
new ProviderHelper(RuntimeEnvironment.application), null);
|
||||||
|
|
||||||
|
InputData data = new InputData(in, in.available());
|
||||||
|
PgpSignEncryptInputParcel input = new PgpSignEncryptInputParcel();
|
||||||
|
|
||||||
|
// only sign, as cleartext
|
||||||
|
input.setSignatureMasterKeyId(mStaticRing1.getMasterKeyId());
|
||||||
|
input.setSignatureSubKeyId(KeyringTestingHelper.getSubkeyId(mStaticRing1, 1));
|
||||||
|
input.setCleartextSignature(true);
|
||||||
|
input.setEnableAsciiArmorOutput(true);
|
||||||
|
input.setDetachedSignature(false);
|
||||||
|
|
||||||
|
PgpSignEncryptResult result = op.execute(input, new CryptoInputParcel(mKeyPhrase1), data, out);
|
||||||
|
Assert.assertTrue("signing must succeed", result.success());
|
||||||
|
|
||||||
|
ciphertext = out.toByteArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
Assert.assertTrue("clearsigned text must contain plaintext", new String(ciphertext).contains(plaintext));
|
||||||
|
|
||||||
|
{ // verification should succeed
|
||||||
|
|
||||||
|
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
||||||
|
ByteArrayInputStream in = new ByteArrayInputStream(ciphertext);
|
||||||
|
InputData data = new InputData(in, in.available());
|
||||||
|
|
||||||
|
PgpDecryptVerifyOperation op = operationWithFakePassphraseCache(null, null, null);
|
||||||
|
PgpDecryptVerifyInputParcel input = new PgpDecryptVerifyInputParcel();
|
||||||
|
DecryptVerifyResult result = op.execute(input, new CryptoInputParcel(), data, out);
|
||||||
|
|
||||||
|
Assert.assertTrue("verification must succeed", result.success());
|
||||||
|
Assert.assertArrayEquals("verification text should equal plaintext (save for a newline)",
|
||||||
|
(plaintext + StringUtils.LINE_SEP).getBytes(), out.toByteArray());
|
||||||
|
Assert.assertEquals("decryptionResult should be RESULT_NOT_ENCRYPTED",
|
||||||
|
OpenPgpDecryptionResult.RESULT_NOT_ENCRYPTED, result.getDecryptionResult().getResult());
|
||||||
|
Assert.assertEquals("signatureResult should be RESULT_VALID_CONFIRMED",
|
||||||
|
OpenPgpSignatureResult.RESULT_VALID_CONFIRMED, result.getSignatureResult().getResult());
|
||||||
|
|
||||||
|
OpenPgpMetadata metadata = result.getDecryptionMetadata();
|
||||||
|
Assert.assertEquals("filesize must be correct",
|
||||||
|
out.toByteArray().length, metadata.getOriginalSize());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testAsymmetricSignDetached() {
|
||||||
|
|
||||||
|
String plaintext = "dies ist ein plaintext ☭" + TestingUtils.genPassphrase(true);
|
||||||
|
byte[] detachedSignature;
|
||||||
|
|
||||||
|
{ // encrypt data with key
|
||||||
|
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
||||||
|
ByteArrayInputStream in = new ByteArrayInputStream(plaintext.getBytes());
|
||||||
|
|
||||||
|
PgpSignEncryptOperation op = new PgpSignEncryptOperation(RuntimeEnvironment.application,
|
||||||
|
new ProviderHelper(RuntimeEnvironment.application), null);
|
||||||
|
|
||||||
|
InputData data = new InputData(in, in.available());
|
||||||
|
PgpSignEncryptInputParcel input = new PgpSignEncryptInputParcel();
|
||||||
|
|
||||||
|
// only sign, as cleartext
|
||||||
|
input.setSignatureMasterKeyId(mStaticRing1.getMasterKeyId());
|
||||||
|
input.setSignatureSubKeyId(KeyringTestingHelper.getSubkeyId(mStaticRing1, 1));
|
||||||
|
input.setDetachedSignature(true);
|
||||||
|
|
||||||
|
PgpSignEncryptResult result = op.execute(input, new CryptoInputParcel(mKeyPhrase1), data, out);
|
||||||
|
Assert.assertTrue("signing must succeed", result.success());
|
||||||
|
|
||||||
|
detachedSignature = result.getDetachedSignature();
|
||||||
|
}
|
||||||
|
|
||||||
|
{ // verification should succeed
|
||||||
|
|
||||||
|
ByteArrayOutputStream out = new ByteArrayOutputStream();
|
||||||
|
ByteArrayInputStream in = new ByteArrayInputStream(plaintext.getBytes());
|
||||||
|
InputData data = new InputData(in, in.available());
|
||||||
|
|
||||||
|
PgpDecryptVerifyOperation op = operationWithFakePassphraseCache(null, null, null);
|
||||||
|
PgpDecryptVerifyInputParcel input = new PgpDecryptVerifyInputParcel();
|
||||||
|
input.setDetachedSignature(detachedSignature);
|
||||||
|
DecryptVerifyResult result = op.execute(input, new CryptoInputParcel(), data, out);
|
||||||
|
|
||||||
|
Assert.assertTrue("verification must succeed", result.success());
|
||||||
|
Assert.assertArrayEquals("verification text should equal plaintext (save for a newline)",
|
||||||
|
plaintext.getBytes(), out.toByteArray());
|
||||||
|
Assert.assertEquals("decryptionResult should be RESULT_NOT_ENCRYPTED",
|
||||||
|
OpenPgpDecryptionResult.RESULT_NOT_ENCRYPTED, result.getDecryptionResult().getResult());
|
||||||
|
Assert.assertEquals("signatureResult should be RESULT_VALID_CONFIRMED",
|
||||||
|
OpenPgpSignatureResult.RESULT_VALID_CONFIRMED, result.getSignatureResult().getResult());
|
||||||
|
|
||||||
|
// TODO should detached verify return any metadata?
|
||||||
|
// OpenPgpMetadata metadata = result.getDecryptionMetadata();
|
||||||
|
// Assert.assertEquals("filesize must be correct",
|
||||||
|
// out.toByteArray().length, metadata.getOriginalSize());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testAsymmetricEncryptDecrypt() {
|
public void testAsymmetricEncryptDecrypt() {
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user