aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rspamd.com>2024-08-07 15:02:01 +0100
committerVsevolod Stakhov <vsevolod@rspamd.com>2024-08-07 15:02:01 +0100
commite8ebda335dd97598d4387fc601515f822304e3fc (patch)
tree9824c33d73cc9d25f0974082797a6fe2099829dd
parent22238913eb72f646d5584ab443d54609ac034188 (diff)
downloadrspamd-e8ebda335dd97598d4387fc601515f822304e3fc.tar.gz
rspamd-e8ebda335dd97598d4387fc601515f822304e3fc.zip
[Test] Fix some test
-rw-r--r--test/rspamd_cxx_unit_cryptobox.hxx51
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);
}
}