mirror of
https://github.com/pgpainless/pgpainless.git
synced 2025-01-09 03:37:57 +01:00
Add tests for PGPPublicKeyExtensions
This commit is contained in:
parent
e561d58562
commit
c89c47c491
1 changed files with 60 additions and 0 deletions
|
@ -0,0 +1,60 @@
|
||||||
|
// SPDX-FileCopyrightText: 2024 Paul Schaub <vanitasvitae@fsfe.org>
|
||||||
|
//
|
||||||
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
package org.pgpainless.bouncycastle.extensions
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Assertions.assertEquals
|
||||||
|
import org.junit.jupiter.api.Test
|
||||||
|
import org.junit.jupiter.api.assertThrows
|
||||||
|
import org.pgpainless.PGPainless
|
||||||
|
import org.pgpainless.algorithm.PublicKeyAlgorithm
|
||||||
|
import org.pgpainless.key.TestKeys
|
||||||
|
import org.pgpainless.key.generation.KeySpec
|
||||||
|
import org.pgpainless.key.generation.type.KeyType
|
||||||
|
import org.pgpainless.key.generation.type.ecc.EllipticCurve
|
||||||
|
import org.pgpainless.key.generation.type.eddsa.EdDSACurve
|
||||||
|
|
||||||
|
class PGPPublicKeyExtensionsTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `test getCurveName for all ECDSA curves`() {
|
||||||
|
for (curve in EllipticCurve.values()) {
|
||||||
|
val key = PGPainless.buildKeyRing()
|
||||||
|
.setPrimaryKey(KeySpec.getBuilder(KeyType.ECDSA(curve)))
|
||||||
|
.build()
|
||||||
|
.publicKey
|
||||||
|
|
||||||
|
assertEquals(curve.curveName, key.getCurveName())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `test getCurveName for legacy EdDSA curves`() {
|
||||||
|
for (curve in EdDSACurve.values()) {
|
||||||
|
val key = PGPainless.buildKeyRing()
|
||||||
|
.setPrimaryKey(KeySpec.getBuilder(KeyType.EDDSA(curve)))
|
||||||
|
.build()
|
||||||
|
.publicKey
|
||||||
|
|
||||||
|
assertEquals(curve.curveName, key.getCurveName())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `test getCurveName fails for non-curve keys`() {
|
||||||
|
// RSA
|
||||||
|
val key = TestKeys.getJulietPublicKeyRing()
|
||||||
|
assertEquals(PublicKeyAlgorithm.RSA_GENERAL, key.publicKey.publicKeyAlgorithm)
|
||||||
|
|
||||||
|
assertThrows<IllegalArgumentException> {
|
||||||
|
key.publicKey.getCurveName()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `openPgpFingerprint returns fitting fingerprint`() {
|
||||||
|
val key = TestKeys.getEmilSecretKeyRing()
|
||||||
|
assertEquals(TestKeys.EMIL_FINGERPRINT, key.publicKey.openPgpFingerprint)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue