diff options
| author | Dominik Schürmann <dominik@dominikschuermann.de> | 2014-08-14 19:25:43 +0200 | 
|---|---|---|
| committer | Dominik Schürmann <dominik@dominikschuermann.de> | 2014-08-14 19:25:43 +0200 | 
| commit | 750ced4525463d3cdcd4aa2530bd3e088cc7dcc0 (patch) | |
| tree | 85935df171a0e8a8ed5f88f7fcf58d7747f2567b /OpenKeychain-Test/src/test/java | |
| parent | 0f60bcbc3d2438a8822e9bc1c6d80f8d0b743e3d (diff) | |
| parent | 621978a7f501197d7f662c657f4bd6813391bab0 (diff) | |
| download | open-keychain-750ced4525463d3cdcd4aa2530bd3e088cc7dcc0.tar.gz open-keychain-750ced4525463d3cdcd4aa2530bd3e088cc7dcc0.tar.bz2 open-keychain-750ced4525463d3cdcd4aa2530bd3e088cc7dcc0.zip | |
Merge branch 'master' of github.com:open-keychain/open-keychain
Diffstat (limited to 'OpenKeychain-Test/src/test/java')
| -rw-r--r-- | OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperationTest.java | 22 | 
1 files changed, 22 insertions, 0 deletions
| diff --git a/OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperationTest.java b/OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperationTest.java index 93aaf05c5..f37f11d87 100644 --- a/OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperationTest.java +++ b/OpenKeychain-Test/src/test/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperationTest.java @@ -16,6 +16,7 @@ import org.spongycastle.bcpg.SecretSubkeyPacket;  import org.spongycastle.bcpg.SignaturePacket;  import org.spongycastle.bcpg.UserIDPacket;  import org.spongycastle.bcpg.sig.KeyFlags; +import org.spongycastle.jce.provider.BouncyCastleProvider;  import org.spongycastle.openpgp.PGPSignature;  import org.spongycastle.bcpg.PublicKeyAlgorithmTags;  import org.sufficientlysecure.keychain.service.OperationResultParcel.OperationLog; @@ -31,6 +32,7 @@ import org.sufficientlysecure.keychain.util.ProgressScaler;  import java.io.ByteArrayInputStream;  import java.io.IOException; +import java.security.Security;  import java.util.ArrayList;  import java.util.Date;  import java.util.Iterator; @@ -51,6 +53,8 @@ public class PgpKeyOperationTest {      ArrayList<RawPacket> onlyB = new ArrayList<RawPacket>();      @BeforeClass public static void setUpOnce() throws Exception { +        Security.insertProviderAt(new BouncyCastleProvider(), 1); +          ShadowLog.stream = System.out;          { @@ -409,6 +413,24 @@ public class PgpKeyOperationTest {                      expiry, modified.getPublicKey(keyId).getExpiryTime().getTime()/1000);          } +        { // expiry of 0 should be "no expiry" +            parcel.reset(); +            parcel.mChangeSubKeys.add(new SubkeyChange(keyId, null, 0L)); +            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.assertNull("key must not expire anymore", modified.getPublicKey(keyId).getExpiryTime()); +        } +          { // a past expiry should fail              parcel.reset();              parcel.mChangeSubKeys.add(new SubkeyChange(keyId, null, new Date().getTime()/1000-10)); | 
