aboutsummaryrefslogtreecommitdiffstats
path: root/OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/tests/PgpKeyOperationTest.java
diff options
context:
space:
mode:
authorVincent Breitmoser <valodim@mugenguild.com>2014-08-01 16:47:06 +0200
committerVincent Breitmoser <valodim@mugenguild.com>2014-08-01 16:50:33 +0200
commit11e5261f07d85d76d6fe58aabb5981cda9ead22b (patch)
tree5e99fed9c694d674f293cd626f3d6ec682db1fda /OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/tests/PgpKeyOperationTest.java
parentacbf2a18617eea73924dd109e09189420d9876fe (diff)
downloadopen-keychain-11e5261f07d85d76d6fe58aabb5981cda9ead22b.tar.gz
open-keychain-11e5261f07d85d76d6fe58aabb5981cda9ead22b.tar.bz2
open-keychain-11e5261f07d85d76d6fe58aabb5981cda9ead22b.zip
move classes around a bit
Diffstat (limited to 'OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/tests/PgpKeyOperationTest.java')
-rw-r--r--OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/tests/PgpKeyOperationTest.java770
1 files changed, 0 insertions, 770 deletions
diff --git a/OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/tests/PgpKeyOperationTest.java b/OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/tests/PgpKeyOperationTest.java
deleted file mode 100644
index 4f6694049..000000000
--- a/OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/tests/PgpKeyOperationTest.java
+++ /dev/null
@@ -1,770 +0,0 @@
-package org.sufficientlysecure.keychain.tests;
-
-import junit.framework.AssertionFailedError;
-
-import org.junit.Assert;
-import org.junit.Test;
-import org.junit.Before;
-import org.junit.BeforeClass;
-import org.junit.runner.RunWith;
-import org.robolectric.*;
-import org.robolectric.shadows.ShadowLog;
-import org.spongycastle.bcpg.BCPGInputStream;
-import org.spongycastle.bcpg.Packet;
-import org.spongycastle.bcpg.PacketTags;
-import org.spongycastle.bcpg.SecretSubkeyPacket;
-import org.spongycastle.bcpg.SignaturePacket;
-import org.spongycastle.bcpg.UserIDPacket;
-import org.spongycastle.bcpg.sig.KeyFlags;
-import org.spongycastle.openpgp.PGPSignature;
-import org.sufficientlysecure.keychain.Constants;
-import org.sufficientlysecure.keychain.Constants.choice.algorithm;
-import org.sufficientlysecure.keychain.pgp.CanonicalizedKeyRing;
-import org.sufficientlysecure.keychain.pgp.CanonicalizedSecretKeyRing;
-import org.sufficientlysecure.keychain.pgp.PgpKeyOperation;
-import org.sufficientlysecure.keychain.pgp.UncachedKeyRing;
-import org.sufficientlysecure.keychain.pgp.UncachedPublicKey;
-import org.sufficientlysecure.keychain.pgp.WrappedSignature;
-import org.sufficientlysecure.keychain.service.OperationResultParcel.OperationLog;
-import org.sufficientlysecure.keychain.service.SaveKeyringParcel;
-import org.sufficientlysecure.keychain.service.SaveKeyringParcel.SubkeyAdd;
-import org.sufficientlysecure.keychain.service.SaveKeyringParcel.SubkeyChange;
-import org.sufficientlysecure.keychain.support.KeyringBuilder;
-import org.sufficientlysecure.keychain.support.KeyringTestingHelper;
-import org.sufficientlysecure.keychain.support.KeyringTestingHelper.RawPacket;
-import org.sufficientlysecure.keychain.support.TestDataUtil;
-import org.sufficientlysecure.keychain.util.ProgressScaler;
-
-import java.io.ByteArrayInputStream;
-import java.io.IOException;
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.Iterator;
-import java.util.Random;
-
-@RunWith(RobolectricTestRunner.class)
-@org.robolectric.annotation.Config(emulateSdk = 18) // Robolectric doesn't yet support 19
-public class PgpKeyOperationTest {
-
- static UncachedKeyRing staticRing;
- static String passphrase;
-
- UncachedKeyRing ring;
- PgpKeyOperation op;
- SaveKeyringParcel parcel;
- ArrayList<RawPacket> onlyA = new ArrayList<RawPacket>();
- ArrayList<RawPacket> onlyB = new ArrayList<RawPacket>();
-
- @BeforeClass public static void setUpOnce() throws Exception {
- ShadowLog.stream = System.out;
-
- {
- String chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ123456789!@#$%^&*()-_=";
- Random r = new Random();
- StringBuilder passbuilder = new StringBuilder();
- // 20% chance for an empty passphrase
- for(int i = 0, j = r.nextInt(10) > 2 ? r.nextInt(20) : 0; i < j; i++) {
- passbuilder.append(chars.charAt(r.nextInt(chars.length())));
- }
- passphrase = passbuilder.toString();
- System.out.println("Passphrase is '" + passphrase + "'");
- }
-
- SaveKeyringParcel parcel = new SaveKeyringParcel();
- parcel.mAddSubKeys.add(new SaveKeyringParcel.SubkeyAdd(
- Constants.choice.algorithm.rsa, 1024, KeyFlags.CERTIFY_OTHER, null));
- parcel.mAddSubKeys.add(new SaveKeyringParcel.SubkeyAdd(
- Constants.choice.algorithm.rsa, 1024, KeyFlags.SIGN_DATA, null));
- parcel.mAddSubKeys.add(new SaveKeyringParcel.SubkeyAdd(
- Constants.choice.algorithm.rsa, 1024, KeyFlags.ENCRYPT_COMMS, null));
-
- parcel.mAddUserIds.add("twi");
- parcel.mAddUserIds.add("pink");
- parcel.mNewPassphrase = passphrase;
- PgpKeyOperation op = new PgpKeyOperation(null);
-
- staticRing = op.createSecretKeyRing(parcel).getRing();
-
- Assert.assertNotNull("initial test key creation must succeed", staticRing);
-
- // we sleep here for a second, to make sure all new certificates have different timestamps
- Thread.sleep(1000);
- }
-
- @Before public void setUp() throws Exception {
- // show Log.x messages in system.out
- ShadowLog.stream = System.out;
- ring = staticRing;
-
- // setting up some parameters just to reduce code duplication
- op = new PgpKeyOperation(new ProgressScaler(null, 0, 100, 100));
-
- // set this up, gonna need it more than once
- parcel = new SaveKeyringParcel();
- parcel.mMasterKeyId = ring.getMasterKeyId();
- parcel.mFingerprint = ring.getFingerprint();
-
- }
-
- @Test
- public void createSecretKeyRingTests() {
-
- {
- parcel.reset();
- parcel.mAddSubKeys.add(new SaveKeyringParcel.SubkeyAdd(
- Constants.choice.algorithm.rsa, new Random().nextInt(256)+255, KeyFlags.CERTIFY_OTHER, null));
- parcel.mAddUserIds.add("shy");
- parcel.mNewPassphrase = passphrase;
-
- UncachedKeyRing ring = op.createSecretKeyRing(parcel).getRing();
-
- Assert.assertNull("creating ring with < 512 bytes keysize should fail", ring);
- }
-
- {
- parcel.reset();
- parcel.mAddSubKeys.add(new SaveKeyringParcel.SubkeyAdd(
- Constants.choice.algorithm.elgamal, 1024, KeyFlags.CERTIFY_OTHER, null));
- parcel.mAddUserIds.add("shy");
- parcel.mNewPassphrase = passphrase;
-
- UncachedKeyRing ring = op.createSecretKeyRing(parcel).getRing();
-
- Assert.assertNull("creating ring with ElGamal master key should fail", ring);
- }
-
- {
- parcel.reset();
- parcel.mAddSubKeys.add(new SaveKeyringParcel.SubkeyAdd(
- 12345, 1024, KeyFlags.CERTIFY_OTHER, null));
- parcel.mAddUserIds.add("shy");
- parcel.mNewPassphrase = passphrase;
-
- UncachedKeyRing ring = op.createSecretKeyRing(parcel).getRing();
- Assert.assertNull("creating ring with bad algorithm choice should fail", ring);
- }
-
- {
- parcel.reset();
- parcel.mAddSubKeys.add(new SaveKeyringParcel.SubkeyAdd(
- Constants.choice.algorithm.rsa, 1024, KeyFlags.SIGN_DATA, null));
- parcel.mAddUserIds.add("shy");
- parcel.mNewPassphrase = passphrase;
-
- UncachedKeyRing ring = op.createSecretKeyRing(parcel).getRing();
- Assert.assertNull("creating ring with non-certifying master key should fail", ring);
- }
-
- {
- parcel.reset();
- parcel.mAddSubKeys.add(new SaveKeyringParcel.SubkeyAdd(
- Constants.choice.algorithm.rsa, 1024, KeyFlags.CERTIFY_OTHER, null));
- parcel.mNewPassphrase = passphrase;
-
- UncachedKeyRing ring = op.createSecretKeyRing(parcel).getRing();
- Assert.assertNull("creating ring without user ids should fail", ring);
- }
-
- {
- parcel.reset();
- parcel.mAddUserIds.add("shy");
- parcel.mNewPassphrase = passphrase;
-
- UncachedKeyRing ring = op.createSecretKeyRing(parcel).getRing();
- Assert.assertNull("creating ring without subkeys should fail", ring);
- }
-
- }
-
- @Test
- // this is a special case since the flags are in user id certificates rather than
- // subkey binding certificates
- public void testMasterFlags() throws Exception {
- SaveKeyringParcel parcel = new SaveKeyringParcel();
- parcel.mAddSubKeys.add(new SaveKeyringParcel.SubkeyAdd(
- Constants.choice.algorithm.rsa, 1024, KeyFlags.CERTIFY_OTHER | KeyFlags.SIGN_DATA, null));
- parcel.mAddUserIds.add("luna");
- ring = op.createSecretKeyRing(parcel).getRing();
-
- Assert.assertEquals("the keyring should contain only the master key",
- 1, KeyringTestingHelper.itToList(ring.getPublicKeys()).size());
- Assert.assertEquals("first (master) key must have both flags",
- KeyFlags.CERTIFY_OTHER | KeyFlags.SIGN_DATA, ring.getPublicKey().getKeyUsage());
-
- }
-
- @Test
- public void testCreatedKey() throws Exception {
-
- // an empty modification should change nothing. this also ensures the keyring
- // is constant through canonicalization.
- // applyModificationWithChecks(parcel, ring, onlyA, onlyB);
-
- Assert.assertNotNull("key creation failed", ring);
-
- Assert.assertNull("primary user id must be empty",
- ring.getPublicKey().getPrimaryUserId());
-
- Assert.assertEquals("number of user ids must be two",
- 2, ring.getPublicKey().getUnorderedUserIds().size());
-
- Assert.assertEquals("number of subkeys must be three",
- 3, KeyringTestingHelper.itToList(ring.getPublicKeys()).size());
-
- Assert.assertTrue("key ring should have been created in the last 120 seconds",
- ring.getPublicKey().getCreationTime().after(new Date(new Date().getTime()-1000*120)));
-
- Assert.assertNull("key ring should not expire",
- ring.getPublicKey().getExpiryTime());
-
- Iterator<UncachedPublicKey> it = ring.getPublicKeys();
-
- Assert.assertEquals("first (master) key can certify",
- KeyFlags.CERTIFY_OTHER, it.next().getKeyUsage());
-
- UncachedPublicKey signingKey = it.next();
- Assert.assertEquals("second key can sign",
- KeyFlags.SIGN_DATA, signingKey.getKeyUsage());
- ArrayList<WrappedSignature> sigs = signingKey.getSignatures().next().getEmbeddedSignatures();
- Assert.assertEquals("signing key signature should have one embedded signature",
- 1, sigs.size());
- Assert.assertEquals("embedded signature should be of primary key binding type",
- PGPSignature.PRIMARYKEY_BINDING, sigs.get(0).getSignatureType());
- Assert.assertEquals("primary key binding signature issuer should be signing subkey",
- signingKey.getKeyId(), sigs.get(0).getKeyId());
-
- Assert.assertEquals("third key can encrypt",
- KeyFlags.ENCRYPT_COMMS, it.next().getKeyUsage());
-
- }
-
- @Test
- public void testBadKeyModification() throws Exception {
-
- {
- SaveKeyringParcel parcel = new SaveKeyringParcel();
- // off by one
- parcel.mMasterKeyId = ring.getMasterKeyId() -1;
- parcel.mFingerprint = ring.getFingerprint();
-
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- UncachedKeyRing modified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
-
- Assert.assertNull("keyring modification with bad master key id should fail", modified);
- }
-
- {
- SaveKeyringParcel parcel = new SaveKeyringParcel();
- // off by one
- parcel.mMasterKeyId = null;
- parcel.mFingerprint = ring.getFingerprint();
-
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- UncachedKeyRing modified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
-
- Assert.assertNull("keyring modification with null master key id should fail", modified);
- }
-
- {
- SaveKeyringParcel parcel = new SaveKeyringParcel();
- parcel.mMasterKeyId = ring.getMasterKeyId();
- parcel.mFingerprint = ring.getFingerprint();
- // some byte, off by one
- parcel.mFingerprint[5] += 1;
-
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- UncachedKeyRing modified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
-
- Assert.assertNull("keyring modification with bad fingerprint should fail", modified);
- }
-
- {
- SaveKeyringParcel parcel = new SaveKeyringParcel();
- parcel.mMasterKeyId = ring.getMasterKeyId();
- parcel.mFingerprint = null;
-
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- UncachedKeyRing modified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
-
- Assert.assertNull("keyring modification with null fingerprint should fail", modified);
- }
-
- {
- String badphrase = "";
- if (badphrase.equals(passphrase)) {
- badphrase = "a";
- }
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- UncachedKeyRing modified = op.modifySecretKeyRing(secretRing, parcel, badphrase).getRing();
-
- Assert.assertNull("keyring modification with bad passphrase should fail", modified);
- }
-
- }
-
- @Test
- public void testSubkeyAdd() throws Exception {
-
- long expiry = new Date().getTime() / 1000 + 159;
- int flags = KeyFlags.SIGN_DATA;
- int bits = 1024 + new Random().nextInt(8);
- parcel.mAddSubKeys.add(new SubkeyAdd(algorithm.rsa, bits, flags, expiry));
-
- UncachedKeyRing modified = applyModificationWithChecks(parcel, ring, onlyA, onlyB);
-
- Assert.assertEquals("no extra packets in original", 0, onlyA.size());
- Assert.assertEquals("exactly two extra packets in modified", 2, onlyB.size());
-
- Packet p;
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyB.get(0).buf)).readPacket();
- Assert.assertTrue("first new packet must be secret subkey", p instanceof SecretSubkeyPacket);
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyB.get(1).buf)).readPacket();
- Assert.assertTrue("second new packet must be signature", p instanceof SignaturePacket);
- Assert.assertEquals("signature type must be subkey binding certificate",
- PGPSignature.SUBKEY_BINDING, ((SignaturePacket) p).getSignatureType());
- Assert.assertEquals("signature must have been created by master key",
- ring.getMasterKeyId(), ((SignaturePacket) p).getKeyID());
-
- // get new key from ring. it should be the last one (add a check to make sure?)
- UncachedPublicKey newKey = null;
- {
- Iterator<UncachedPublicKey> it = modified.getPublicKeys();
- while (it.hasNext()) {
- newKey = it.next();
- }
- }
-
- Assert.assertNotNull("new key is not null", newKey);
- Assert.assertNotNull("added key must have an expiry date",
- newKey.getExpiryTime());
- Assert.assertEquals("added key must have expected expiry date",
- expiry, newKey.getExpiryTime().getTime()/1000);
- Assert.assertEquals("added key must have expected flags",
- flags, newKey.getKeyUsage());
- Assert.assertEquals("added key must have expected bitsize",
- bits, newKey.getBitStrength());
-
- { // bad keysize should fail
- parcel.reset();
- parcel.mAddSubKeys.add(new SubkeyAdd(
- algorithm.rsa, new Random().nextInt(512), KeyFlags.SIGN_DATA, null));
-
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- modified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
-
- Assert.assertNull("creating a subkey with keysize < 512 should fail", modified);
- }
-
- { // a past expiry should fail
- parcel.reset();
- parcel.mAddSubKeys.add(new SubkeyAdd(algorithm.rsa, 1024, KeyFlags.SIGN_DATA,
- new Date().getTime()/1000-10));
-
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- modified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
-
- Assert.assertNull("creating subkey with past expiry date should fail", modified);
- }
-
- }
-
- @Test
- public void testSubkeyModify() throws Exception {
-
- long expiry = new Date().getTime()/1000 + 1024;
- long keyId = KeyringTestingHelper.getSubkeyId(ring, 1);
-
- UncachedKeyRing modified = ring;
- {
- parcel.mChangeSubKeys.add(new SubkeyChange(keyId, null, expiry));
- modified = applyModificationWithChecks(parcel, modified, onlyA, onlyB);
-
- Assert.assertEquals("one extra packet in original", 1, onlyA.size());
- Assert.assertEquals("one extra packet in modified", 1, onlyB.size());
-
- Assert.assertEquals("old packet must be signature",
- PacketTags.SIGNATURE, onlyA.get(0).tag);
-
- Packet p = new BCPGInputStream(new ByteArrayInputStream(onlyB.get(0).buf)).readPacket();
- Assert.assertTrue("first new packet must be signature", p instanceof SignaturePacket);
- Assert.assertEquals("signature type must be subkey binding certificate",
- PGPSignature.SUBKEY_BINDING, ((SignaturePacket) p).getSignatureType());
- Assert.assertEquals("signature must have been created by master key",
- ring.getMasterKeyId(), ((SignaturePacket) p).getKeyID());
-
- Assert.assertNotNull("modified key must have an expiry date",
- modified.getPublicKey(keyId).getExpiryTime());
- Assert.assertEquals("modified key must have expected expiry date",
- expiry, modified.getPublicKey(keyId).getExpiryTime().getTime()/1000);
- Assert.assertEquals("modified key must have same flags as before",
- ring.getPublicKey(keyId).getKeyUsage(), modified.getPublicKey(keyId).getKeyUsage());
- }
-
- {
- int flags = KeyFlags.SIGN_DATA | KeyFlags.ENCRYPT_COMMS;
- parcel.reset();
- parcel.mChangeSubKeys.add(new SubkeyChange(keyId, flags, null));
- modified = applyModificationWithChecks(parcel, modified, onlyA, onlyB);
-
- Assert.assertEquals("old packet must be signature",
- PacketTags.SIGNATURE, onlyA.get(0).tag);
-
- Packet p = new BCPGInputStream(new ByteArrayInputStream(onlyB.get(0).buf)).readPacket();
- Assert.assertTrue("first new packet must be signature", p instanceof SignaturePacket);
- Assert.assertEquals("signature type must be subkey binding certificate",
- PGPSignature.SUBKEY_BINDING, ((SignaturePacket) p).getSignatureType());
- Assert.assertEquals("signature must have been created by master key",
- ring.getMasterKeyId(), ((SignaturePacket) p).getKeyID());
-
- Assert.assertEquals("modified key must have expected flags",
- flags, modified.getPublicKey(keyId).getKeyUsage());
- Assert.assertNotNull("key must retain its expiry",
- modified.getPublicKey(keyId).getExpiryTime());
- Assert.assertEquals("key expiry must be unchanged",
- expiry, modified.getPublicKey(keyId).getExpiryTime().getTime()/1000);
- }
-
- { // a past expiry should fail
- parcel.reset();
- parcel.mChangeSubKeys.add(new SubkeyChange(keyId, null, new Date().getTime()/1000-10));
-
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- modified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
-
- Assert.assertNull("setting subkey expiry to a past date should fail", modified);
- }
-
- { // modifying nonexistent keyring should fail
- parcel.reset();
- parcel.mChangeSubKeys.add(new SubkeyChange(123, null, null));
-
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- modified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
-
- Assert.assertNull("modifying non-existent subkey should fail", modified);
- }
-
- }
-
- @Test
- public void testSubkeyRevoke() throws Exception {
-
- long keyId = KeyringTestingHelper.getSubkeyId(ring, 1);
- int flags = ring.getPublicKey(keyId).getKeyUsage();
-
- UncachedKeyRing modified;
-
- {
-
- parcel.reset();
- parcel.mRevokeSubKeys.add(123L);
-
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- UncachedKeyRing otherModified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
-
- Assert.assertNull("revoking a nonexistent subkey should fail", otherModified);
-
- }
-
- { // revoked second subkey
-
- parcel.reset();
- parcel.mRevokeSubKeys.add(keyId);
-
- modified = applyModificationWithChecks(parcel, ring, onlyA, onlyB);
-
- Assert.assertEquals("no extra packets in original", 0, onlyA.size());
- Assert.assertEquals("exactly one extra packet in modified", 1, onlyB.size());
-
- Packet p;
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyB.get(0).buf)).readPacket();
- Assert.assertTrue("first new packet must be secret subkey", p instanceof SignaturePacket);
- Assert.assertEquals("signature type must be subkey binding certificate",
- PGPSignature.SUBKEY_REVOCATION, ((SignaturePacket) p).getSignatureType());
- Assert.assertEquals("signature must have been created by master key",
- ring.getMasterKeyId(), ((SignaturePacket) p).getKeyID());
-
- Assert.assertTrue("subkey must actually be revoked",
- modified.getPublicKey(keyId).isRevoked());
- }
-
- { // re-add second subkey
-
- parcel.reset();
- parcel.mChangeSubKeys.add(new SubkeyChange(keyId, null, null));
-
- modified = applyModificationWithChecks(parcel, modified, onlyA, onlyB);
-
- Assert.assertEquals("exactly two outdated packets in original", 2, onlyA.size());
- Assert.assertEquals("exactly one extra packet in modified", 1, onlyB.size());
-
- Packet p;
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyA.get(0).buf)).readPacket();
- Assert.assertTrue("first outdated packet must be signature", p instanceof SignaturePacket);
- Assert.assertEquals("first outdated signature type must be subkey binding certification",
- PGPSignature.SUBKEY_BINDING, ((SignaturePacket) p).getSignatureType());
- Assert.assertEquals("first outdated signature must have been created by master key",
- ring.getMasterKeyId(), ((SignaturePacket) p).getKeyID());
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyA.get(1).buf)).readPacket();
- Assert.assertTrue("second outdated packet must be signature", p instanceof SignaturePacket);
- Assert.assertEquals("second outdated signature type must be subkey revocation",
- PGPSignature.SUBKEY_REVOCATION, ((SignaturePacket) p).getSignatureType());
- Assert.assertEquals("second outdated signature must have been created by master key",
- ring.getMasterKeyId(), ((SignaturePacket) p).getKeyID());
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyB.get(0).buf)).readPacket();
- Assert.assertTrue("new packet must be signature ", p instanceof SignaturePacket);
- Assert.assertEquals("new signature type must be subkey binding certification",
- PGPSignature.SUBKEY_BINDING, ((SignaturePacket) p).getSignatureType());
- Assert.assertEquals("signature must have been created by master key",
- ring.getMasterKeyId(), ((SignaturePacket) p).getKeyID());
-
- Assert.assertFalse("subkey must no longer be revoked",
- modified.getPublicKey(keyId).isRevoked());
- Assert.assertEquals("subkey must have the same usage flags as before",
- flags, modified.getPublicKey(keyId).getKeyUsage());
-
- }
- }
-
- @Test
- public void testUserIdRevoke() throws Exception {
-
- UncachedKeyRing modified;
- String uid = ring.getPublicKey().getUnorderedUserIds().get(1);
-
- { // revoke second user id
-
- parcel.mRevokeUserIds.add(uid);
-
- modified = applyModificationWithChecks(parcel, ring, onlyA, onlyB);
-
- Assert.assertEquals("no extra packets in original", 0, onlyA.size());
- Assert.assertEquals("exactly one extra packet in modified", 1, onlyB.size());
-
- Packet p;
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyB.get(0).buf)).readPacket();
- Assert.assertTrue("first new packet must be secret subkey", p instanceof SignaturePacket);
- Assert.assertEquals("signature type must be subkey binding certificate",
- PGPSignature.CERTIFICATION_REVOCATION, ((SignaturePacket) p).getSignatureType());
- Assert.assertEquals("signature must have been created by master key",
- ring.getMasterKeyId(), ((SignaturePacket) p).getKeyID());
-
- }
-
- { // re-add second user id
-
- parcel.reset();
- parcel.mChangePrimaryUserId = uid;
-
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(modified.getEncoded(), false, 0);
- UncachedKeyRing otherModified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
-
- Assert.assertNull("setting primary user id to a revoked user id should fail", otherModified);
-
- }
-
- { // re-add second user id
-
- parcel.reset();
- parcel.mAddUserIds.add(uid);
-
- applyModificationWithChecks(parcel, modified, onlyA, onlyB);
-
- Assert.assertEquals("exactly two outdated packets in original", 2, onlyA.size());
- Assert.assertEquals("exactly one extra packet in modified", 1, onlyB.size());
-
- Packet p;
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyA.get(0).buf)).readPacket();
- Assert.assertTrue("first outdated packet must be signature", p instanceof SignaturePacket);
- Assert.assertEquals("first outdated signature type must be positive certification",
- PGPSignature.POSITIVE_CERTIFICATION, ((SignaturePacket) p).getSignatureType());
- Assert.assertEquals("first outdated signature must have been created by master key",
- ring.getMasterKeyId(), ((SignaturePacket) p).getKeyID());
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyA.get(1).buf)).readPacket();
- Assert.assertTrue("second outdated packet must be signature", p instanceof SignaturePacket);
- Assert.assertEquals("second outdated signature type must be certificate revocation",
- PGPSignature.CERTIFICATION_REVOCATION, ((SignaturePacket) p).getSignatureType());
- Assert.assertEquals("second outdated signature must have been created by master key",
- ring.getMasterKeyId(), ((SignaturePacket) p).getKeyID());
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyB.get(0).buf)).readPacket();
- Assert.assertTrue("new packet must be signature ", p instanceof SignaturePacket);
- Assert.assertEquals("new signature type must be positive certification",
- PGPSignature.POSITIVE_CERTIFICATION, ((SignaturePacket) p).getSignatureType());
- Assert.assertEquals("signature must have been created by master key",
- ring.getMasterKeyId(), ((SignaturePacket) p).getKeyID());
- }
-
- }
-
- @Test
- public void testUserIdAdd() throws Exception {
-
- {
- parcel.mAddUserIds.add("");
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- UncachedKeyRing modified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
- Assert.assertNull("adding an empty user id should fail", modified);
- }
-
- parcel.reset();
- parcel.mAddUserIds.add("rainbow");
-
- UncachedKeyRing modified = applyModificationWithChecks(parcel, ring, onlyA, onlyB);
-
- Assert.assertTrue("keyring must contain added user id",
- modified.getPublicKey().getUnorderedUserIds().contains("rainbow"));
-
- Assert.assertEquals("no extra packets in original", 0, onlyA.size());
- Assert.assertEquals("exactly two extra packets in modified", 2, onlyB.size());
-
- Assert.assertTrue("keyring must contain added user id",
- modified.getPublicKey().getUnorderedUserIds().contains("rainbow"));
-
- Packet p;
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyB.get(0).buf)).readPacket();
- Assert.assertTrue("first new packet must be user id", p instanceof UserIDPacket);
- Assert.assertEquals("user id packet must match added user id",
- "rainbow", ((UserIDPacket) p).getID());
-
- p = new BCPGInputStream(new ByteArrayInputStream(onlyB.get(1).buf)).readPacket();
- Assert.assertTrue("second new packet must be signature", p instanceof SignaturePacket);
- Assert.assertEquals("signature type must be positive certification",
- PGPSignature.POSITIVE_CERTIFICATION, ((SignaturePacket) p).getSignatureType());
-
- }
-
- @Test
- public void testUserIdPrimary() throws Exception {
-
- UncachedKeyRing modified = ring;
- String uid = ring.getPublicKey().getUnorderedUserIds().get(1);
-
- { // first part, add new user id which is also primary
- parcel.mAddUserIds.add("jack");
- parcel.mChangePrimaryUserId = "jack";
-
- modified = applyModificationWithChecks(parcel, modified, onlyA, onlyB);
-
- Assert.assertEquals("primary user id must be the one added",
- "jack", modified.getPublicKey().getPrimaryUserId());
- }
-
- { // second part, change primary to a different one
- parcel.reset();
- parcel.mChangePrimaryUserId = uid;
-
- modified = applyModificationWithChecks(parcel, modified, onlyA, onlyB);
-
- Assert.assertEquals("old keyring must have two outdated certificates", 2, onlyA.size());
- Assert.assertEquals("new keyring must have two new packets", 2, onlyB.size());
-
- Assert.assertEquals("primary user id must be the one changed to",
- "pink", modified.getPublicKey().getPrimaryUserId());
- }
-
- { // third part, change primary to a non-existent one
- parcel.reset();
- //noinspection SpellCheckingInspection
- parcel.mChangePrimaryUserId = "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA";
- if (parcel.mChangePrimaryUserId.equals(passphrase)) {
- parcel.mChangePrimaryUserId += "A";
- }
-
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
- modified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
-
- Assert.assertNull("changing primary user id to a non-existent one should fail", modified);
- }
-
- // check for revoked primary user id already done in revoke test
-
- }
-
-
- private static UncachedKeyRing applyModificationWithChecks(SaveKeyringParcel parcel,
- UncachedKeyRing ring,
- ArrayList<RawPacket> onlyA,
- ArrayList<RawPacket> onlyB) {
- return applyModificationWithChecks(parcel, ring, onlyA, onlyB, true, true);
- }
-
- // applies a parcel modification while running some integrity checks
- private static UncachedKeyRing applyModificationWithChecks(SaveKeyringParcel parcel,
- UncachedKeyRing ring,
- ArrayList<RawPacket> onlyA,
- ArrayList<RawPacket> onlyB,
- boolean canonicalize,
- boolean constantCanonicalize) {
-
- try {
-
- Assert.assertTrue("modified keyring must be secret", ring.isSecret());
- CanonicalizedSecretKeyRing secretRing = new CanonicalizedSecretKeyRing(ring.getEncoded(), false, 0);
-
- PgpKeyOperation op = new PgpKeyOperation(null);
- UncachedKeyRing rawModified = op.modifySecretKeyRing(secretRing, parcel, passphrase).getRing();
- Assert.assertNotNull("key modification failed", rawModified);
-
- if (!canonicalize) {
- Assert.assertTrue("keyring must differ from original", KeyringTestingHelper.diffKeyrings(
- ring.getEncoded(), rawModified.getEncoded(), onlyA, onlyB));
- return rawModified;
- }
-
- CanonicalizedKeyRing modified = rawModified.canonicalize(new OperationLog(), 0);
- if (constantCanonicalize) {
- Assert.assertTrue("key must be constant through canonicalization",
- !KeyringTestingHelper.diffKeyrings(
- modified.getEncoded(), rawModified.getEncoded(), onlyA, onlyB)
- );
- }
- Assert.assertTrue("keyring must differ from original", KeyringTestingHelper.diffKeyrings(
- ring.getEncoded(), modified.getEncoded(), onlyA, onlyB));
-
- return modified.getUncachedKeyRing();
-
- } catch (IOException e) {
- throw new AssertionFailedError("error during encoding!");
- }
- }
-
- @Test
- public void testVerifySuccess() throws Exception {
-
- UncachedKeyRing expectedKeyRing = KeyringBuilder.correctRing();
- UncachedKeyRing inputKeyRing = KeyringBuilder.ringWithExtraIncorrectSignature();
-
- CanonicalizedKeyRing canonicalized = inputKeyRing.canonicalize(new OperationLog(), 0);
- Assert.assertNotNull("canonicalization must succeed", canonicalized);
-
- ArrayList onlyA = new ArrayList<RawPacket>();
- ArrayList onlyB = new ArrayList<RawPacket>();
- //noinspection unchecked
- Assert.assertTrue("keyrings differ", !KeyringTestingHelper.diffKeyrings(
- expectedKeyRing.getEncoded(), expectedKeyRing.getEncoded(), onlyA, onlyB));
-
- }
-
- /**
- * Just testing my own test code. Should really be using a library for this.
- */
- @Test
- public void testConcat() throws Exception {
- byte[] actual = TestDataUtil.concatAll(new byte[]{1}, new byte[]{2,-2}, new byte[]{5},new byte[]{3});
- byte[] expected = new byte[]{1,2,-2,5,3};
- Assert.assertEquals(java.util.Arrays.toString(expected), java.util.Arrays.toString(actual));
- }
-
-
-}