• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

randombit / botan / 23225340130

18 Mar 2026 01:53AM UTC coverage: 89.677% (-0.001%) from 89.678%
23225340130

push

github

web-flow
Merge pull request #5456 from randombit/jack/clang-tidy-22

Fix various warnings from clang-tidy 22

104438 of 116460 relevant lines covered (89.68%)

11819947.55 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

99.53
/src/tests/test_sodium.cpp
1
/*
2
* (C) 2019 Jack Lloyd
3
*
4
* Botan is released under the Simplified BSD License (see license.txt)
5
*/
6

7
#include "tests.h"
8

9
#if defined(BOTAN_HAS_SODIUM_API)
10
   #include <botan/hex.h>
11
   #include <botan/sodium.h>
12
   #include <cstring>
13
#endif
14

15
namespace Botan_Tests {
16

17
namespace {
18

19
#if defined(BOTAN_HAS_SODIUM_API)
20

21
class Sodium_API_Tests : public Test {
1✔
22
   public:
23
      std::vector<Test::Result> run() override {
1✔
24
         std::vector<Test::Result> results;
1✔
25

26
         results.push_back(aead_chacha20poly1305());
2✔
27
         results.push_back(aead_chacha20poly1305_ietf());
2✔
28
         results.push_back(aead_xchacha20poly1305());
2✔
29
         results.push_back(auth_hmacsha256());
2✔
30
         results.push_back(auth_hmacsha512());
2✔
31
         results.push_back(auth_hmacsha512256());
2✔
32
         results.push_back(auth_poly1305());
2✔
33
         results.push_back(box_curve25519xsalsa20poly1305());
2✔
34
         results.push_back(hash_sha256());
2✔
35
         results.push_back(hash_sha512());
2✔
36
         results.push_back(randombytes_buf_deterministic());
2✔
37
         results.push_back(secretbox_xsalsa20poly1305());
2✔
38
         results.push_back(secretbox_xsalsa20poly1305_detached());
2✔
39
         results.push_back(shorthash_siphash24());
2✔
40
         results.push_back(stream_chacha20());
2✔
41
         results.push_back(stream_chacha20_ietf());
2✔
42
         results.push_back(stream_salsa20());
2✔
43
         results.push_back(stream_xchacha20());
2✔
44
         results.push_back(stream_xsalsa20());
2✔
45
         results.push_back(sign_ed25519());
2✔
46
         results.push_back(sodium_malloc());
2✔
47
         results.push_back(sodium_utils());
2✔
48

49
         return results;
1✔
50
      }
×
51

52
   private:
53
      static Test::Result sodium_malloc() {
1✔
54
         Test::Result result("sodium_malloc");
1✔
55

56
         void* p = Botan::Sodium::sodium_malloc(50);
1✔
57
         std::memset(p, 0xFF, 50);
1✔
58

59
         Botan::Sodium::sodium_free(p);
60
         Botan::Sodium::sodium_free(nullptr);
1✔
61

62
         result.test_success("Didn't crash");
1✔
63

64
         return result;
1✔
65
      }
×
66

67
      static Test::Result sodium_utils() {
1✔
68
         Test::Result result("sodium math utils");
1✔
69

70
         result.test_is_true("sodium_is_zero", Botan::Sodium::sodium_is_zero(nullptr, 0) == 1);
1✔
71

72
         std::vector<uint8_t> a(5);
1✔
73
         result.test_is_true("sodium_is_zero", Botan::Sodium::sodium_is_zero(a.data(), a.size()) == 1);
1✔
74
         Botan::Sodium::sodium_increment(a.data(), a.size());
1✔
75
         result.test_bin_eq("sodium_increment", a, "0100000000");
1✔
76
         result.test_is_true("sodium_is_zero", Botan::Sodium::sodium_is_zero(a.data(), a.size()) == 0);
1✔
77

78
         std::memset(a.data(), 0xFF, a.size());
1✔
79
         Botan::Sodium::sodium_increment(a.data(), a.size());
1✔
80
         result.test_bin_eq("sodium_increment", a, "0000000000");
1✔
81
         Botan::Sodium::sodium_increment(a.data(), a.size());
1✔
82
         result.test_bin_eq("sodium_increment", a, "0100000000");
1✔
83

84
         result.test_is_true("sodium_compare", Botan::Sodium::sodium_compare(a.data(), a.data(), a.size()) == 0);
1✔
85
         result.test_is_true("sodium_memcmp", Botan::Sodium::sodium_memcmp(a.data(), a.data(), a.size()) == 0);
1✔
86

87
         std::vector<uint8_t> b(5, 0x10);
1✔
88
         result.test_is_true("sodium_compare a<b", Botan::Sodium::sodium_compare(a.data(), b.data(), a.size()) == -1);
1✔
89
         result.test_is_true("sodium_compare b<a", Botan::Sodium::sodium_compare(b.data(), a.data(), a.size()) == 1);
1✔
90
         result.test_is_true("sodium_memcmp a<b", Botan::Sodium::sodium_memcmp(a.data(), b.data(), a.size()) == -1);
1✔
91
         result.test_is_true("sodium_memcmp b<a", Botan::Sodium::sodium_memcmp(b.data(), a.data(), a.size()) == -1);
1✔
92

93
         Botan::Sodium::sodium_add(a.data(), b.data(), a.size());
1✔
94
         result.test_bin_eq("sodium_add", a, "1110101010");
1✔
95
         Botan::Sodium::sodium_add(b.data(), a.data(), a.size());
1✔
96
         result.test_bin_eq("sodium_add", b, "2120202020");
1✔
97
         Botan::Sodium::sodium_add(a.data(), b.data(), a.size());
1✔
98
         result.test_bin_eq("sodium_add", a, "3230303030");
1✔
99
         Botan::Sodium::sodium_add(b.data(), a.data(), a.size());
1✔
100
         result.test_bin_eq("sodium_add", b, "5350505050");
1✔
101

102
         return result;
1✔
103
      }
1✔
104

105
      static Test::Result randombytes_buf_deterministic() {
1✔
106
         Test::Result result("randombytes_buf_deterministic");
1✔
107

108
         const uint8_t seed[32] = {1, 0};
1✔
109
         std::vector<uint8_t> output(18);
1✔
110

111
         Botan::Sodium::randombytes_buf_deterministic(output.data(), output.size(), seed);
1✔
112

113
         result.test_bin_eq("output", output, "04069B5F37E82F91DC37FD5EB99F1A4124B1");
1✔
114

115
         return result;
1✔
116
      }
1✔
117

118
      static Test::Result hash_sha512() {
1✔
119
         Test::Result result("crypto_hash_sha512");
1✔
120

121
         std::vector<uint8_t> output(64);
1✔
122
         Botan::Sodium::crypto_hash_sha512(output.data(), nullptr, 0);
1✔
123

124
         result.test_bin_eq(
1✔
125
            "expected output",
126
            output,
127
            "cf83e1357eefb8bdf1542850d66d8007d620e4050b5715dc83f4a921d36ce9ce47d0d13c5d85f2b0ff8318d2877eec2f63b931bd47417a81a538327af927da3e");
128

129
         return result;
1✔
130
      }
1✔
131

132
      static Test::Result hash_sha256() {
1✔
133
         Test::Result result("crypto_hash_sha256");
1✔
134

135
         std::vector<uint8_t> output(32);
1✔
136
         Botan::Sodium::crypto_hash_sha256(output.data(), nullptr, 0);
1✔
137

138
         result.test_bin_eq(
1✔
139
            "expected output", output, "e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855");
140

141
         return result;
1✔
142
      }
1✔
143

144
      static Test::Result box_curve25519xsalsa20poly1305() {
1✔
145
         Test::Result result("crypto_box_curve25519xsalsa20poly1305");
1✔
146

147
         const std::vector<uint8_t> seed(32);
1✔
148

149
         std::vector<uint8_t> pk1(32);
1✔
150
         std::vector<uint8_t> sk1(32);
1✔
151
         result.test_rc_ok("seed_keypair", Botan::Sodium::crypto_box_seed_keypair(pk1.data(), sk1.data(), seed.data()));
1✔
152
         result.test_bin_eq("pk1", pk1, "5BF55C73B82EBE22BE80F3430667AF570FAE2556A6415E6B30D4065300AA947D");
1✔
153
         result.test_bin_eq("sk1", sk1, "5046ADC1DBA838867B2BBBFDD0C3423E58B57970B5267A90F57960924A87F196");
1✔
154

155
         std::vector<uint8_t> pk2(32);
1✔
156
         std::vector<uint8_t> sk2(32);
1✔
157
         result.test_rc_ok("seed_keypair", Botan::Sodium::crypto_box_seed_keypair(pk2.data(), sk2.data(), sk1.data()));
1✔
158
         result.test_bin_eq("pk2", pk2, "E0CFC9C6B2FE5BF85F48671691225C03D763F2305206FE3D3B0ED7B76153684A");
1✔
159
         result.test_bin_eq("sk2", sk2, "58E2E4C71F138FBC97F9341735B4581746761F9A104540007FE12CFC4D9FDA15");
1✔
160

161
         const std::vector<uint8_t> ptext(15);
1✔
162
         std::vector<uint8_t> ctext(ptext.size() + 16);
1✔
163
         const std::vector<uint8_t> nonce(Botan::Sodium::crypto_box_noncebytes());
2✔
164

165
         result.test_rc_ok("crypto_box_easy",
1✔
166
                           Botan::Sodium::crypto_box_easy(
167
                              ctext.data(), ptext.data(), ptext.size(), nonce.data(), pk2.data(), sk1.data()));
1✔
168

169
         result.test_bin_eq("ctext1", ctext, "11D78D4C32C5674390C0425D8BBB5928AFE7F767E2A7E4427E1A1362F1FD92");
1✔
170

171
         result.test_rc_ok("crypto_box_easy",
1✔
172
                           Botan::Sodium::crypto_box_easy(
173
                              ctext.data(), ptext.data(), ptext.size(), nonce.data(), pk1.data(), sk2.data()));
1✔
174

175
         // same shared secret, same nonce, same data -> same ciphertext
176
         result.test_bin_eq("ctext2", ctext, "11D78D4C32C5674390C0425D8BBB5928AFE7F767E2A7E4427E1A1362F1FD92");
1✔
177

178
         std::vector<uint8_t> recovered(15);
1✔
179

180
         result.test_rc_ok("crypto_box_open_easy",
2✔
181
                           Botan::Sodium::crypto_box_open_easy(
182
                              recovered.data(), ctext.data(), ctext.size(), nonce.data(), pk1.data(), sk2.data()));
1✔
183

184
         result.test_bin_eq("recover1", recovered, ptext);
1✔
185

186
         result.test_rc_ok("crypto_box_open_easy",
2✔
187
                           Botan::Sodium::crypto_box_open_easy(
188
                              recovered.data(), ctext.data(), ctext.size(), nonce.data(), pk2.data(), sk1.data()));
1✔
189

190
         result.test_bin_eq("recover1", recovered, ptext);
1✔
191

192
         return result;
1✔
193
      }
1✔
194

195
      static Test::Result aead_chacha20poly1305() {
1✔
196
         Test::Result result("crypto_aead_chacha20poly1305");
1✔
197

198
         const std::vector<uint8_t> key =
1✔
199
            Botan::hex_decode("0000000000000000000000000000000000000000000000000000000000000000");
1✔
200
         const std::vector<uint8_t> ad;
1✔
201
         const std::vector<uint8_t> nonce = Botan::hex_decode("0000000000000000");
1✔
202
         const std::vector<uint8_t> in = Botan::hex_decode("000000000000000000000000000000");
1✔
203

204
         result.test_sz_eq("key len", Botan::Sodium::crypto_aead_chacha20poly1305_keybytes(), key.size());
1✔
205
         result.test_sz_eq("nonce len", Botan::Sodium::crypto_aead_chacha20poly1305_npubbytes(), nonce.size());
1✔
206

207
         std::vector<uint8_t> ctext(in.size());
1✔
208
         std::vector<uint8_t> mac(16);
1✔
209
         unsigned long long maclen = 0;
1✔
210
         Botan::Sodium::crypto_aead_chacha20poly1305_encrypt_detached(ctext.data(),
1✔
211
                                                                      mac.data(),
212
                                                                      &maclen,
213
                                                                      in.data(),
214
                                                                      in.size(),
215
                                                                      ad.data(),
216
                                                                      ad.size(),
217
                                                                      nullptr,
218
                                                                      nonce.data(),
219
                                                                      key.data());
220

221
         result.test_sz_eq("maclen", size_t(maclen), 16);
1✔
222
         result.test_bin_eq("mac", mac, "09998877ABA156DDC68F8344098F68B9");
1✔
223
         result.test_bin_eq("ctext", ctext, "9F07E7BE5551387A98BA977C732D08");
1✔
224

225
         std::vector<uint8_t> recovered(ctext.size());
1✔
226
         result.test_rc_ok("decrypt",
1✔
227
                           Botan::Sodium::crypto_aead_chacha20poly1305_decrypt_detached(recovered.data(),
228
                                                                                        nullptr,
229
                                                                                        ctext.data(),
1✔
230
                                                                                        ctext.size(),
231
                                                                                        mac.data(),
1✔
232
                                                                                        ad.data(),
233
                                                                                        ad.size(),
234
                                                                                        nonce.data(),
235
                                                                                        key.data()));
236

237
         result.test_bin_eq("plaintext", recovered, in);
1✔
238

239
         mac[0] ^= 1;
1✔
240
         result.test_rc_fail("decrypt",
1✔
241
                             "invalid ciphertext",
242
                             Botan::Sodium::crypto_aead_chacha20poly1305_decrypt_detached(recovered.data(),
243
                                                                                          nullptr,
244
                                                                                          ctext.data(),
1✔
245
                                                                                          ctext.size(),
246
                                                                                          mac.data(),
1✔
247
                                                                                          ad.data(),
248
                                                                                          ad.size(),
249
                                                                                          nonce.data(),
250
                                                                                          key.data()));
251

252
         ctext.resize(in.size() + mac.size());
1✔
253
         unsigned long long ctext_len = 0;
1✔
254
         result.test_rc_ok("encrypt",
1✔
255
                           Botan::Sodium::crypto_aead_chacha20poly1305_encrypt(ctext.data(),
256
                                                                               &ctext_len,
257
                                                                               in.data(),
258
                                                                               in.size(),
259
                                                                               ad.data(),
260
                                                                               ad.size(),
261
                                                                               nullptr,
262
                                                                               nonce.data(),
263
                                                                               key.data()));
264

265
         result.test_sz_eq("ctext_len", size_t(ctext_len), ctext.size());
1✔
266
         result.test_bin_eq("ctext", ctext, "9F07E7BE5551387A98BA977C732D0809998877ABA156DDC68F8344098F68B9");
1✔
267

268
         unsigned long long recovered_len = 0;
1✔
269
         result.test_rc_ok("decrypt",
1✔
270
                           Botan::Sodium::crypto_aead_chacha20poly1305_decrypt(recovered.data(),
271
                                                                               &recovered_len,
272
                                                                               nullptr,
273
                                                                               ctext.data(),
1✔
274
                                                                               ctext.size(),
275
                                                                               ad.data(),
276
                                                                               ad.size(),
277
                                                                               nonce.data(),
278
                                                                               key.data()));
279

280
         result.test_bin_eq("recovered", recovered, in);
1✔
281

282
         return result;
1✔
283
      }
1✔
284

285
      static Test::Result aead_chacha20poly1305_ietf() {
1✔
286
         Test::Result result("crypto_aead_chacha20poly1305_ietf");
1✔
287

288
         const std::vector<uint8_t> key =
1✔
289
            Botan::hex_decode("0000000000000000000000000000000000000000000000000000000000000000");
1✔
290
         const std::vector<uint8_t> ad;
1✔
291
         const std::vector<uint8_t> nonce = Botan::hex_decode("000000000000000000000000");
1✔
292
         const std::vector<uint8_t> in = Botan::hex_decode("000000000000000000000000000000");
1✔
293

294
         result.test_sz_eq("key len", Botan::Sodium::crypto_aead_chacha20poly1305_ietf_keybytes(), key.size());
1✔
295
         result.test_sz_eq("nonce len", Botan::Sodium::crypto_aead_chacha20poly1305_ietf_npubbytes(), nonce.size());
1✔
296

297
         std::vector<uint8_t> ctext(in.size());
1✔
298
         std::vector<uint8_t> mac(16);
1✔
299
         unsigned long long maclen = 0;
1✔
300
         Botan::Sodium::crypto_aead_chacha20poly1305_ietf_encrypt_detached(ctext.data(),
1✔
301
                                                                           mac.data(),
302
                                                                           &maclen,
303
                                                                           in.data(),
304
                                                                           in.size(),
305
                                                                           ad.data(),
306
                                                                           ad.size(),
307
                                                                           nullptr,
308
                                                                           nonce.data(),
309
                                                                           key.data());
310

311
         result.test_sz_eq("maclen", size_t(maclen), 16);
1✔
312
         result.test_bin_eq("mac", mac, "3679F1FB9843FD81E26D962888296954");
1✔
313
         result.test_bin_eq("ctext", ctext, "9F07E7BE5551387A98BA977C732D08");
1✔
314

315
         std::vector<uint8_t> recovered(ctext.size());
1✔
316
         result.test_rc_ok("decrypt",
1✔
317
                           Botan::Sodium::crypto_aead_chacha20poly1305_ietf_decrypt_detached(recovered.data(),
318
                                                                                             nullptr,
319
                                                                                             ctext.data(),
1✔
320
                                                                                             ctext.size(),
321
                                                                                             mac.data(),
1✔
322
                                                                                             ad.data(),
323
                                                                                             ad.size(),
324
                                                                                             nonce.data(),
325
                                                                                             key.data()));
326

327
         result.test_bin_eq("plaintext", recovered, in);
1✔
328

329
         mac[0] ^= 1;
1✔
330
         result.test_rc_fail("decrypt",
1✔
331
                             "invalid ciphertext",
332
                             Botan::Sodium::crypto_aead_chacha20poly1305_ietf_decrypt_detached(recovered.data(),
333
                                                                                               nullptr,
334
                                                                                               ctext.data(),
1✔
335
                                                                                               ctext.size(),
336
                                                                                               mac.data(),
1✔
337
                                                                                               ad.data(),
338
                                                                                               ad.size(),
339
                                                                                               nonce.data(),
340
                                                                                               key.data()));
341

342
         ctext.resize(in.size() + mac.size());
1✔
343
         unsigned long long ctext_len = 0;
1✔
344
         result.test_rc_ok("encrypt",
1✔
345
                           Botan::Sodium::crypto_aead_chacha20poly1305_ietf_encrypt(ctext.data(),
346
                                                                                    &ctext_len,
347
                                                                                    in.data(),
348
                                                                                    in.size(),
349
                                                                                    ad.data(),
350
                                                                                    ad.size(),
351
                                                                                    nullptr,
352
                                                                                    nonce.data(),
353
                                                                                    key.data()));
354

355
         result.test_sz_eq("ctext_len", size_t(ctext_len), ctext.size());
1✔
356
         result.test_bin_eq("ctext", ctext, "9F07E7BE5551387A98BA977C732D083679F1FB9843FD81E26D962888296954");
1✔
357

358
         unsigned long long recovered_len = 0;
1✔
359
         result.test_rc_ok("decrypt",
1✔
360
                           Botan::Sodium::crypto_aead_chacha20poly1305_ietf_decrypt(recovered.data(),
361
                                                                                    &recovered_len,
362
                                                                                    nullptr,
363
                                                                                    ctext.data(),
1✔
364
                                                                                    ctext.size(),
365
                                                                                    ad.data(),
366
                                                                                    ad.size(),
367
                                                                                    nonce.data(),
368
                                                                                    key.data()));
369

370
         result.test_bin_eq("recovered", recovered, in);
1✔
371

372
         return result;
1✔
373
      }
1✔
374

375
      static Test::Result aead_xchacha20poly1305() {
1✔
376
         Test::Result result("crypto_aead_xchacha20poly1305");
1✔
377

378
         const std::vector<uint8_t> key =
1✔
379
            Botan::hex_decode("0000000000000000000000000000000000000000000000000000000000000000");
1✔
380
         const std::vector<uint8_t> ad;
1✔
381
         const std::vector<uint8_t> nonce = Botan::hex_decode("000000000000000000000000000000000000000000000000");
1✔
382
         const std::vector<uint8_t> in = Botan::hex_decode("000000000000000000000000000000");
1✔
383

384
         result.test_sz_eq("key len", Botan::Sodium::crypto_aead_xchacha20poly1305_ietf_keybytes(), key.size());
1✔
385
         result.test_sz_eq("nonce len", Botan::Sodium::crypto_aead_xchacha20poly1305_ietf_npubbytes(), nonce.size());
1✔
386

387
         std::vector<uint8_t> ctext(in.size());
1✔
388
         std::vector<uint8_t> mac(16);
1✔
389
         unsigned long long maclen = 0;
1✔
390
         Botan::Sodium::crypto_aead_xchacha20poly1305_ietf_encrypt_detached(ctext.data(),
1✔
391
                                                                            mac.data(),
392
                                                                            &maclen,
393
                                                                            in.data(),
394
                                                                            in.size(),
395
                                                                            ad.data(),
396
                                                                            ad.size(),
397
                                                                            nullptr,
398
                                                                            nonce.data(),
399
                                                                            key.data());
400

401
         result.test_sz_eq("maclen", size_t(maclen), 16);
1✔
402
         result.test_bin_eq("mac", mac, "b2f7033812ac9ebd3745e2c99c7bbfeb");
1✔
403
         result.test_bin_eq("ctext", ctext, "789e9689e5208d7fd9e1f3c5b5341f");
1✔
404

405
         std::vector<uint8_t> recovered(ctext.size());
1✔
406
         result.test_rc_ok("decrypt",
1✔
407
                           Botan::Sodium::crypto_aead_xchacha20poly1305_ietf_decrypt_detached(recovered.data(),
408
                                                                                              nullptr,
409
                                                                                              ctext.data(),
1✔
410
                                                                                              ctext.size(),
411
                                                                                              mac.data(),
1✔
412
                                                                                              ad.data(),
413
                                                                                              ad.size(),
414
                                                                                              nonce.data(),
415
                                                                                              key.data()));
416

417
         result.test_bin_eq("plaintext", recovered, in);
1✔
418

419
         mac[0] ^= 1;
1✔
420
         result.test_rc_fail("decrypt",
1✔
421
                             "invalid ciphertext",
422
                             Botan::Sodium::crypto_aead_xchacha20poly1305_ietf_decrypt_detached(recovered.data(),
423
                                                                                                nullptr,
424
                                                                                                ctext.data(),
1✔
425
                                                                                                ctext.size(),
426
                                                                                                mac.data(),
1✔
427
                                                                                                ad.data(),
428
                                                                                                ad.size(),
429
                                                                                                nonce.data(),
430
                                                                                                key.data()));
431

432
         ctext.resize(in.size() + mac.size());
1✔
433
         unsigned long long ctext_len = 0;
1✔
434
         result.test_rc_ok("encrypt",
1✔
435
                           Botan::Sodium::crypto_aead_xchacha20poly1305_ietf_encrypt(ctext.data(),
436
                                                                                     &ctext_len,
437
                                                                                     in.data(),
438
                                                                                     in.size(),
439
                                                                                     ad.data(),
440
                                                                                     ad.size(),
441
                                                                                     nullptr,
442
                                                                                     nonce.data(),
443
                                                                                     key.data()));
444

445
         result.test_sz_eq("ctext_len", size_t(ctext_len), ctext.size());
1✔
446
         result.test_bin_eq("ctext", ctext, "789e9689e5208d7fd9e1f3c5b5341fb2f7033812ac9ebd3745e2c99c7bbfeb");
1✔
447

448
         unsigned long long recovered_len = 0;
1✔
449
         result.test_rc_ok("decrypt",
1✔
450
                           Botan::Sodium::crypto_aead_xchacha20poly1305_ietf_decrypt(recovered.data(),
451
                                                                                     &recovered_len,
452
                                                                                     nullptr,
453
                                                                                     ctext.data(),
1✔
454
                                                                                     ctext.size(),
455
                                                                                     ad.data(),
456
                                                                                     ad.size(),
457
                                                                                     nonce.data(),
458
                                                                                     key.data()));
459

460
         result.test_bin_eq("recovered", recovered, in);
1✔
461

462
         return result;
1✔
463
      }
1✔
464

465
      static Test::Result auth_hmacsha512() {
1✔
466
         Test::Result result("crypto_auth_hmacsha512");
1✔
467

468
         const std::vector<uint8_t> key =
1✔
469
            Botan::hex_decode("000102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F");
1✔
470
         const std::vector<uint8_t> in = Botan::hex_decode("616263");
1✔
471

472
         result.test_sz_eq("key_size", key.size(), Botan::Sodium::crypto_auth_hmacsha512_keybytes());
1✔
473

474
         std::vector<uint8_t> mac(64);
1✔
475
         Botan::Sodium::crypto_auth_hmacsha512(mac.data(), in.data(), in.size(), key.data());
1✔
476

477
         result.test_bin_eq(
1✔
478
            "expected mac",
479
            mac,
480
            "69D4A21E226BF0D348CB9A847C01CF24E93E8AC30D7C951704B936F82F795A624B470E23ABD33AC8700E797F0F2A499B932BAC7D283BBBB37D8FECF70D5E08A7");
481

482
         result.test_rc_ok("verify",
1✔
483
                           Botan::Sodium::crypto_auth_hmacsha512_verify(mac.data(), in.data(), in.size(), key.data()));
1✔
484

485
         mac[0] ^= 1;
1✔
486
         result.test_rc_fail(
1✔
487
            "verify",
488
            "invalid mac",
489
            Botan::Sodium::crypto_auth_hmacsha512_verify(mac.data(), in.data(), in.size(), key.data()));
1✔
490

491
         return result;
1✔
492
      }
1✔
493

494
      static Test::Result auth_hmacsha512256() {
1✔
495
         Test::Result result("crypto_auth_hmacsha512256");
1✔
496

497
         const std::vector<uint8_t> key =
1✔
498
            Botan::hex_decode("000102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F");
1✔
499
         const std::vector<uint8_t> in = Botan::hex_decode("616263");
1✔
500

501
         std::vector<uint8_t> mac(32);
1✔
502
         Botan::Sodium::crypto_auth_hmacsha512256(mac.data(), in.data(), in.size(), key.data());
1✔
503

504
         result.test_bin_eq("expected mac", mac, "69D4A21E226BF0D348CB9A847C01CF24E93E8AC30D7C951704B936F82F795A62");
1✔
505

506
         result.test_rc_ok(
1✔
507
            "verify", Botan::Sodium::crypto_auth_hmacsha512256_verify(mac.data(), in.data(), in.size(), key.data()));
1✔
508

509
         mac[0] ^= 1;
1✔
510
         result.test_rc_fail(
1✔
511
            "verify",
512
            "invalid mac",
513
            Botan::Sodium::crypto_auth_hmacsha512256_verify(mac.data(), in.data(), in.size(), key.data()));
1✔
514

515
         return result;
1✔
516
      }
1✔
517

518
      static Test::Result auth_hmacsha256() {
1✔
519
         Test::Result result("crypto_auth_hmacsha256");
1✔
520

521
         const std::vector<uint8_t> key =
1✔
522
            Botan::hex_decode("0102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F20");
1✔
523
         const std::vector<uint8_t> in = Botan::hex_decode("616263");
1✔
524

525
         std::vector<uint8_t> mac(32);
1✔
526
         Botan::Sodium::crypto_auth_hmacsha256(mac.data(), in.data(), in.size(), key.data());
1✔
527

528
         result.test_bin_eq("expected mac", mac, "A21B1F5D4CF4F73A4DD939750F7A066A7F98CC131CB16A6692759021CFAB8181");
1✔
529

530
         result.test_rc_ok("verify",
1✔
531
                           Botan::Sodium::crypto_auth_hmacsha256_verify(mac.data(), in.data(), in.size(), key.data()));
1✔
532

533
         mac[0] ^= 1;
1✔
534
         result.test_rc_fail(
1✔
535
            "verify",
536
            "invalid mac",
537
            Botan::Sodium::crypto_auth_hmacsha256_verify(mac.data(), in.data(), in.size(), key.data()));
1✔
538

539
         return result;
1✔
540
      }
1✔
541

542
      static Test::Result auth_poly1305() {
1✔
543
         Test::Result result("crypto_onetimeauth_poly1305");
1✔
544

545
         const std::vector<uint8_t> key(Botan::Sodium::crypto_onetimeauth_keybytes(), 0x42);
1✔
546
         const std::vector<uint8_t> in(15);
1✔
547

548
         std::vector<uint8_t> mac(16);
1✔
549

550
         result.test_rc_ok("poly1305",
1✔
551
                           Botan::Sodium::crypto_onetimeauth_poly1305(mac.data(), in.data(), in.size(), key.data()));
552

553
         result.test_bin_eq("expected mac", mac, "12154512151545121515451215154584");
1✔
554

555
         result.test_rc_ok(
1✔
556
            "poly1305 verify",
557
            Botan::Sodium::crypto_onetimeauth_poly1305_verify(mac.data(), in.data(), in.size(), key.data()));
1✔
558

559
         mac[0] ^= 1;
1✔
560
         result.test_rc_fail(
1✔
561
            "poly1305 verify",
562
            "invalid mac",
563
            Botan::Sodium::crypto_onetimeauth_poly1305_verify(mac.data(), in.data(), in.size(), key.data()));
1✔
564

565
         return result;
1✔
566
      }
1✔
567

568
      static Test::Result shorthash_siphash24() {
1✔
569
         Test::Result result("crypto_shorthash_siphash24");
1✔
570

571
         const std::vector<uint8_t> key = Botan::hex_decode("000102030405060708090A0B0C0D0E0F");
1✔
572
         const std::vector<uint8_t> in = Botan::hex_decode("000102030405060708090A0B0C0D0E");
1✔
573

574
         std::vector<uint8_t> mac(8);
1✔
575
         Botan::Sodium::crypto_shorthash_siphash24(mac.data(), in.data(), in.size(), key.data());
1✔
576

577
         result.test_bin_eq("expected mac", mac, "E545BE4961CA29A1");
1✔
578

579
         return result;
1✔
580
      }
1✔
581

582
      static Test::Result secretbox_xsalsa20poly1305() {
1✔
583
         Test::Result result("secretbox_xsalsa20poly1305");
1✔
584

585
         const std::vector<uint8_t> ptext(33);
1✔
586
         std::vector<uint8_t> ctext(33);
1✔
587
         const std::vector<uint8_t> nonce(Botan::Sodium::crypto_secretbox_xsalsa20poly1305_noncebytes());
1✔
588
         const std::vector<uint8_t> key(Botan::Sodium::crypto_secretbox_xsalsa20poly1305_keybytes());
1✔
589

590
         result.test_rc_ok("encrypt",
1✔
591
                           Botan::Sodium::crypto_secretbox_xsalsa20poly1305(
592
                              ctext.data(), ptext.data(), ptext.size(), nonce.data(), key.data()));
593

594
         result.test_bin_eq("ctext", ctext, "0000000000000000000000000000000042E45EB764A1B706D4776A849BC2526BC6");
1✔
595

596
         std::vector<uint8_t> recovered(33);
1✔
597
         result.test_rc_ok("decrypt",
1✔
598
                           Botan::Sodium::crypto_secretbox_xsalsa20poly1305_open(
599
                              recovered.data(), ctext.data(), ctext.size(), nonce.data(), key.data()));
1✔
600

601
         result.test_bin_eq("decrypted", recovered, ptext);
1✔
602

603
         return result;
1✔
604
      }
1✔
605

606
      static Test::Result secretbox_xsalsa20poly1305_detached() {
1✔
607
         Test::Result result("secretbox_xsalsa20poly1305");
1✔
608

609
         const std::vector<uint8_t> ptext(33);
1✔
610
         const std::vector<uint8_t> nonce(Botan::Sodium::crypto_secretbox_xsalsa20poly1305_noncebytes());
1✔
611
         const std::vector<uint8_t> key(Botan::Sodium::crypto_secretbox_xsalsa20poly1305_keybytes());
1✔
612
         std::vector<uint8_t> ctext(33);
1✔
613
         std::vector<uint8_t> mac(16);
1✔
614

615
         result.test_rc_ok("encrypt detached",
1✔
616
                           Botan::Sodium::crypto_secretbox_detached(
617
                              ctext.data(), mac.data(), ptext.data(), ptext.size(), nonce.data(), key.data()));
618

619
         result.test_bin_eq("ctext", ctext, "C63EBBFFFE85CE2CEBDEF7DC42F494576D05BDD7B929EBB045F2A793F740277D05");
1✔
620
         result.test_bin_eq("mac", mac, "0D6681DCED740667C699F0AC71BFD1BD");
1✔
621

622
         std::vector<uint8_t> recovered(ctext.size());
1✔
623

624
         result.test_rc_ok("open detached",
1✔
625
                           Botan::Sodium::crypto_secretbox_open_detached(
626
                              recovered.data(), ctext.data(), mac.data(), ctext.size(), nonce.data(), key.data()));
1✔
627

628
         result.test_bin_eq("recovered", recovered, ptext);
1✔
629

630
         return result;
1✔
631
      }
1✔
632

633
      static Test::Result sign_ed25519() {
1✔
634
         Test::Result result("crypto_sign_ed25519");
1✔
635

636
         const std::vector<uint8_t> seed(32);
1✔
637
         std::vector<uint8_t> pk(32);
1✔
638
         std::vector<uint8_t> sk(64);
1✔
639

640
         result.test_rc_ok("seed_keypair",
1✔
641
                           Botan::Sodium::crypto_sign_ed25519_seed_keypair(pk.data(), sk.data(), seed.data()));
642

643
         result.test_bin_eq("pk", pk, "3B6A27BCCEB6A42D62A3A8D02A6F0D73653215771DE243A63AC048A18B59DA29");
1✔
644
         result.test_bin_eq(
1✔
645
            "sk",
646
            sk,
647
            "00000000000000000000000000000000000000000000000000000000000000003B6A27BCCEB6A42D62A3A8D02A6F0D73653215771DE243A63AC048A18B59DA29");
648

649
         const std::vector<uint8_t> msg = {1, 2, 3};
1✔
650
         std::vector<uint8_t> sig(64);
1✔
651
         unsigned long long sig_len = 0;
1✔
652
         result.test_rc_ok(
1✔
653
            "sign_detached",
654
            Botan::Sodium::crypto_sign_ed25519_detached(sig.data(), &sig_len, msg.data(), msg.size(), sk.data()));
1✔
655
         result.test_is_true("sig len", sig_len == 64);
1✔
656

657
         result.test_bin_eq(
1✔
658
            "sig",
659
            sig,
660
            "2A26779BA6CBB5E54292257F725AF112B273C38728329682D99ED81BA6D7670350AE4CC53C5456FA437128D19298A5D949AB46E3D41AB3DBCFB0B35C895E9304");
661

662
         result.test_rc_ok(
1✔
663
            "verify",
664
            Botan::Sodium::crypto_sign_ed25519_verify_detached(sig.data(), msg.data(), msg.size(), pk.data()));
1✔
665

666
         sig[0] ^= 1;
1✔
667
         result.test_rc_fail(
1✔
668
            "verify",
669
            "reject invalid",
670
            Botan::Sodium::crypto_sign_ed25519_verify_detached(sig.data(), msg.data(), msg.size(), pk.data()));
1✔
671

672
         return result;
1✔
673
      }
1✔
674

675
      static Test::Result stream_salsa20() {
1✔
676
         Test::Result result("crypto_stream_salsa20");
1✔
677

678
         const std::vector<uint8_t> key =
1✔
679
            Botan::hex_decode("0F62B5085BAE0154A7FA4DA0F34699EC3F92E5388BDE3184D72A7DD02376C91C");
1✔
680
         const std::vector<uint8_t> nonce = Botan::hex_decode("288FF65DC42B92F9");
1✔
681
         const std::vector<uint8_t> expected =
1✔
682
            Botan::hex_decode("5E5E71F90199340304ABB22A37B6625BF883FB89CE3B21F54A10B81066EF87DA");
1✔
683

684
         std::vector<uint8_t> output(32);
1✔
685
         Botan::Sodium::crypto_stream_salsa20(output.data(), output.size(), nonce.data(), key.data());
1✔
686
         result.test_bin_eq("stream", output, expected);
1✔
687

688
         std::vector<uint8_t> xor_output(32);
1✔
689
         Botan::Sodium::crypto_stream_salsa20_xor(
1✔
690
            xor_output.data(), output.data(), output.size(), nonce.data(), key.data());
1✔
691
         result.test_bin_eq("stream", xor_output, std::vector<uint8_t>(32));  // all zeros
1✔
692

693
         return result;
1✔
694
      }
1✔
695

696
      static Test::Result stream_xsalsa20() {
1✔
697
         Test::Result result("crypto_stream_xsalsa20");
1✔
698

699
         const std::vector<uint8_t> key =
1✔
700
            Botan::hex_decode("1B27556473E985D462CD51197A9A46C76009549EAC6474F206C4EE0844F68389");
1✔
701
         const std::vector<uint8_t> nonce = Botan::hex_decode("69696EE955B62B73CD62BDA875FC73D68219E0036B7A0B37");
1✔
702
         const std::vector<uint8_t> expected =
1✔
703
            Botan::hex_decode("EEA6A7251C1E72916D11C2CB214D3C252539121D8E234E652D651FA4C8CFF880");
1✔
704

705
         std::vector<uint8_t> output(32);
1✔
706
         Botan::Sodium::crypto_stream_xsalsa20(output.data(), output.size(), nonce.data(), key.data());
1✔
707
         result.test_bin_eq("stream", output, expected);
1✔
708

709
         std::vector<uint8_t> xor_output(32);
1✔
710
         Botan::Sodium::crypto_stream_xsalsa20_xor(
1✔
711
            xor_output.data(), output.data(), output.size(), nonce.data(), key.data());
1✔
712
         result.test_bin_eq("stream", xor_output, std::vector<uint8_t>(32));  // all zeros
1✔
713

714
         return result;
1✔
715
      }
1✔
716

717
      static Test::Result stream_chacha20() {
1✔
718
         Test::Result result("crypto_stream_chacha20");
1✔
719

720
         const std::vector<uint8_t> key =
1✔
721
            Botan::hex_decode("000102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F");
1✔
722
         const std::vector<uint8_t> nonce = Botan::hex_decode("0001020304050607");
1✔
723
         const std::vector<uint8_t> expected =
1✔
724
            Botan::hex_decode("F798A189F195E66982105FFB640BB7757F579DA31602FC93EC01AC56F85AC3C1");
1✔
725

726
         std::vector<uint8_t> output(32);
1✔
727
         Botan::Sodium::crypto_stream_chacha20(output.data(), output.size(), nonce.data(), key.data());
1✔
728
         result.test_bin_eq("stream", output, expected);
1✔
729

730
         std::vector<uint8_t> xor_output(32);
1✔
731
         Botan::Sodium::crypto_stream_chacha20_xor(
1✔
732
            xor_output.data(), output.data(), output.size(), nonce.data(), key.data());
1✔
733
         result.test_bin_eq("stream", xor_output, std::vector<uint8_t>(32));  // all zeros
1✔
734

735
         return result;
1✔
736
      }
1✔
737

738
      static Test::Result stream_chacha20_ietf() {
1✔
739
         Test::Result result("crypto_stream_chacha20");
1✔
740

741
         const std::vector<uint8_t> key =
1✔
742
            Botan::hex_decode("000102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F");
1✔
743
         const std::vector<uint8_t> nonce = Botan::hex_decode("000102030405060708090A0B0C");
1✔
744
         const std::vector<uint8_t> expected =
1✔
745
            Botan::hex_decode("103AF111C18B549D39248FB07D60C29A95D1DB88D892F7B4AF709A5FD47A9E4B");
1✔
746

747
         std::vector<uint8_t> output(32);
1✔
748
         Botan::Sodium::crypto_stream_chacha20_ietf(output.data(), output.size(), nonce.data(), key.data());
1✔
749
         result.test_bin_eq("stream", output, expected);
1✔
750

751
         std::vector<uint8_t> xor_output(32);
1✔
752
         Botan::Sodium::crypto_stream_chacha20_ietf_xor(
1✔
753
            xor_output.data(), output.data(), output.size(), nonce.data(), key.data());
1✔
754
         result.test_bin_eq("stream", xor_output, std::vector<uint8_t>(32));  // all zeros
1✔
755

756
         return result;
1✔
757
      }
1✔
758

759
      static Test::Result stream_xchacha20() {
1✔
760
         Test::Result result("crypto_stream_xchacha20");
1✔
761

762
         const std::vector<uint8_t> key =
1✔
763
            Botan::hex_decode("000102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F");
1✔
764
         const std::vector<uint8_t> nonce = Botan::hex_decode("000102030405060708090a0b0c0d0e0f1011121314151617");
1✔
765
         const std::vector<uint8_t> expected =
1✔
766
            Botan::hex_decode("e53a61cef151e81401067de33adfc02e90ab205361b49b539fda7f0e63b1bc7d");
1✔
767

768
         std::vector<uint8_t> output(32);
1✔
769
         Botan::Sodium::crypto_stream_xchacha20(output.data(), output.size(), nonce.data(), key.data());
1✔
770
         result.test_bin_eq("stream", output, expected);
1✔
771

772
         std::vector<uint8_t> xor_output(32);
1✔
773
         Botan::Sodium::crypto_stream_xchacha20_xor(
1✔
774
            xor_output.data(), output.data(), output.size(), nonce.data(), key.data());
1✔
775
         result.test_bin_eq("stream", xor_output, std::vector<uint8_t>(32));  // all zeros
1✔
776

777
         return result;
1✔
778
      }
1✔
779
};
780

781
BOTAN_REGISTER_TEST("compat", "sodium", Sodium_API_Tests);
782

783
#endif
784

785
}  // namespace
786

787
}  // namespace Botan_Tests
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc