diff options
author | Vsevolod Stakhov <vsevolod@rspamd.com> | 2024-08-07 15:02:01 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@rspamd.com> | 2024-08-07 15:02:01 +0100 |
commit | e8ebda335dd97598d4387fc601515f822304e3fc (patch) | |
tree | 9824c33d73cc9d25f0974082797a6fe2099829dd | |
parent | 22238913eb72f646d5584ab443d54609ac034188 (diff) | |
download | rspamd-e8ebda335dd97598d4387fc601515f822304e3fc.tar.gz rspamd-e8ebda335dd97598d4387fc601515f822304e3fc.zip |
[Test] Fix some test
-rw-r--r-- | test/rspamd_cxx_unit_cryptobox.hxx | 51 |
1 files changed, 45 insertions, 6 deletions
diff --git a/test/rspamd_cxx_unit_cryptobox.hxx b/test/rspamd_cxx_unit_cryptobox.hxx index b23cd138a..feed5bbe3 100644 --- a/test/rspamd_cxx_unit_cryptobox.hxx +++ b/test/rspamd_cxx_unit_cryptobox.hxx @@ -116,7 +116,28 @@ TEST_SUITE("rspamd_cryptobox") } - TEST_CASE("rspamd_cryptobox_encrypt_inplace") + TEST_CASE("rspamd_cryptobox_encrypt_inplace_25519") + { + unsigned char data[256]; + gsize len = sizeof(data); + rspamd_nonce_t nonce; + rspamd_pk_t pk; + rspamd_sk_t sk; + rspamd_mac_t sig; + enum rspamd_cryptobox_mode mode = RSPAMD_CRYPTOBOX_MODE_25519; + + ottery_rand_bytes(nonce, sizeof(nonce)); + + rspamd_cryptobox_keypair(pk, sk, mode); + + memset(sig, 0, sizeof(sig)); + + rspamd_cryptobox_encrypt_inplace(data, len, nonce, pk, sk, sig, mode); + + CHECK(rspamd_cryptobox_decrypt_inplace(data, len, nonce, pk, sk, sig, mode)); + } + + TEST_CASE("rspamd_cryptobox_encrypt_inplace_p256") { unsigned char data[256]; gsize len = sizeof(data); @@ -137,21 +158,39 @@ TEST_SUITE("rspamd_cryptobox") CHECK(rspamd_cryptobox_decrypt_inplace(data, len, nonce, pk, sk, sig, mode)); } + TEST_CASE("rspamd_cryptobox_sign_25519") + { + enum rspamd_cryptobox_mode mode = RSPAMD_CRYPTOBOX_MODE_25519; + rspamd_sk_t sk; + rspamd_pk_t pk; + unsigned char sig[256]; + unsigned long long siglen; + std::string m{"data to be signed"}; + + rspamd_cryptobox_keypair(pk, sk, mode); + + rspamd_cryptobox_sign(sig, &siglen, + reinterpret_cast<const unsigned char *>(m.data()), m.size(), sk, mode); + bool check_result = rspamd_cryptobox_verify(sig, siglen, + reinterpret_cast<const unsigned char *>(m.data()), m.size(), pk, mode); + CHECK(check_result == true); + } - TEST_CASE("rspamd_cryptobox_sign") + TEST_CASE("rspamd_cryptobox_sign_nist") { enum rspamd_cryptobox_mode mode = RSPAMD_CRYPTOBOX_MODE_NIST; rspamd_sk_t sk; rspamd_pk_t pk; unsigned char sig[256]; unsigned long long siglen; - const unsigned char m[] = "data to be signed"; - size_t mlen = strlen((const char *) m); + std::string m{"data to be signed"}; rspamd_cryptobox_keypair(pk, sk, mode); - rspamd_cryptobox_sign(sig, &siglen, m, mlen, sk, mode); - bool check_result = rspamd_cryptobox_verify(sig, siglen, m, mlen, pk, mode); + rspamd_cryptobox_sign(sig, &siglen, + reinterpret_cast<const unsigned char *>(m.data()), m.size(), sk, mode); + bool check_result = rspamd_cryptobox_verify(sig, siglen, + reinterpret_cast<const unsigned char *>(m.data()), m.size(), pk, mode); CHECK(check_result == true); } } |