1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
//! AEAD tests

use super::*;

define_test_set!("AEAD", "aead_test_schema.json");

define_test_set_names!(
    Aegis128 => "aegis128",
    Aegis128L => "aegis128L",
    Aegis256 => "aegis256",
    Aes128CbcHmacSha256 => "a128cbc_hs256",
    Aes192CbcHmacSha384 => "a192cbc_hs384",
    Aes256CbcHmacSha512 => "a256cbc_hs512",
    AesCcm => "aes_ccm",
    AesEax => "aes_eax",
    AesGcm => "aes_gcm",
    AesGcmSiv => "aes_gcm_siv",
    AesSivCmac => "aead_aes_siv_cmac",
    AriaCcm => "aria_ccm",
    AriaGcm => "aria_gcm",
    Ascon128 => "ascon128",
    Ascon128a => "ascon128a",
    Ascon80pq => "ascon80pq",
    CamelliaCcm => "camellia_ccm",
    ChaCha20Poly1305 => "chacha20_poly1305",
    Morus1280 => "morus1280",
    Morus640 => "morus640",
    SeedCcm => "seed_ccm",
    SeedGcm => "seed_gcm",
    Sm4Ccm => "sm4_ccm",
    Sm4Gcm => "sm4_gcm",
    XChaCha20Poly1305 => "xchacha20_poly1305",
);

define_algorithm_map!(
    "A128CBC-HS256" => Aes128CbcHmacSha256,
    "A192CBC-HS384" => Aes192CbcHmacSha384,
    "A256CBC-HS512" => Aes256CbcHmacSha512,
    "AEAD-AES-SIV-CMAC" => AesSivCmac,
    "AEGIS128" => Aegis128,
    "AEGIS128L" => Aegis128L,
    "AEGIS256" => Aegis256,
    "AES-CCM" => AesCcm,
    "AES-EAX" => AesEax,
    "AES-GCM" => AesGcm,
    "AES-GCM-SIV" => AesGcmSiv,
    "ARIA-CCM" => AriaCcm,
    "ARIA-GCM" => AriaGcm,
    "ASCON128" => Ascon128,
    "ASCON128A" => Ascon128a,
    "ASCON80PQ" => Ascon80pq,
    "CAMELLIA-CCM" => CamelliaCcm,
    "CAMELLIA-GCM" => CamelliaGcm,
    "CHACHA20-POLY1305" => ChaCha20Poly1305,
    "MORUS1280" => Morus1280,
    "MORUS640" => Morus640,
    "SEED-CCM" => SeedCcm,
    "SEED-GCM" => SeedGcm,
    "SM4-CCM" => Sm4Ccm,
    "SM4-GCM" => Sm4Gcm,
    "XCHACHA20-POLY1305" => XChaCha20Poly1305,
);

define_test_flags!(
    "CVE-2017-18330" => LongNonce,
    "Ktv" => KnownTestVector,
    "TagCollision_1" => TagCollisionPtext,
    "TagCollision_2" => TagCollisionAad,
    CounterWrap,
    EdgeCaseCiphertext,
    EdgeCasePoly1305,
    EdgeCasePolyKey,
    EdgeCaseSiv,
    EdgeCaseTag,
    InsecureTagSize,
    InvalidNonceSize,
    InvalidTagSize,
    LongIv,
    ModifiedTag,
    OldVersion,
    Pseudorandom,
    SmallIv,
    SpecialCase,
    SpecialCaseIv,
    WrappedIv,
    ZeroLengthIv,
);

define_test_group_type_id!(
    "AeadTest" => Aead,
);

define_test_group!(
    "ivSize" => nonce_size: usize,
    "keySize" => key_size: usize,
    "tagSize" => tag_size: usize,
);

define_test!(
    key: ByteString,
    "iv" => nonce: ByteString,
    aad: ByteString,
    "msg" => pt: ByteString,
    ct: ByteString,
    tag: ByteString,
);