43 lines
1.7 KiB
Java
43 lines
1.7 KiB
Java
// SPDX-FileCopyrightText: 2020 Paul Schaub <vanitasvitae@fsfe.org>
|
|
//
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package org.pgpainless.key.generation;
|
|
|
|
import static org.junit.jupiter.api.Assertions.assertThrows;
|
|
|
|
import org.junit.jupiter.api.TestTemplate;
|
|
import org.junit.jupiter.api.extension.ExtendWith;
|
|
import org.pgpainless.PGPainless;
|
|
import org.pgpainless.algorithm.KeyFlag;
|
|
import org.pgpainless.key.generation.type.KeyType;
|
|
import org.pgpainless.key.generation.type.ecc.EllipticCurve;
|
|
import org.pgpainless.key.generation.type.xdh_legacy.XDHLegacySpec;
|
|
import org.pgpainless.util.TestAllImplementations;
|
|
|
|
public class CertificationKeyMustBeAbleToCertifyTest {
|
|
|
|
/**
|
|
* Generating a key ring that has a primary key which is unable to create signatures (and therefore signatures)
|
|
* would result in an invalid key.
|
|
* This test therefore verifies that generating such keys fails.
|
|
*/
|
|
@TestTemplate
|
|
@ExtendWith(TestAllImplementations.class)
|
|
public void testCertificationIncapableKeyTypesThrow() {
|
|
KeyType[] typesIncapableOfCreatingVerifications = new KeyType[] {
|
|
KeyType.ECDH(EllipticCurve._P256),
|
|
KeyType.ECDH(EllipticCurve._P384),
|
|
KeyType.ECDH(EllipticCurve._P521),
|
|
KeyType.XDH_LEGACY(XDHLegacySpec._X25519)
|
|
};
|
|
for (KeyType type : typesIncapableOfCreatingVerifications) {
|
|
assertThrows(IllegalArgumentException.class, () -> PGPainless
|
|
.buildKeyRing()
|
|
.setPrimaryKey(KeySpec.getBuilder(type, KeyFlag.CERTIFY_OTHER, KeyFlag.SIGN_DATA))
|
|
.addUserId("should@throw.ex")
|
|
.build());
|
|
}
|
|
}
|
|
}
|