mirror of
https://github.com/ziglang/zig.git
synced 2026-02-20 16:24:51 +00:00
Add crypto internal test functions
This commit is contained in:
parent
66a24c9c00
commit
73b4f09845
22
std/crypto/test.zig
Normal file
22
std/crypto/test.zig
Normal file
@ -0,0 +1,22 @@
|
||||
const debug = @import("../debug/index.zig");
|
||||
const mem = @import("../mem.zig");
|
||||
const fmt = @import("../fmt/index.zig");
|
||||
|
||||
// Hash using the specified hasher `H` asserting `expected == H(input)`.
|
||||
pub fn assertEqualHash(comptime Hasher: var, comptime expected: []const u8, input: []const u8) {
|
||||
var h: [expected.len / 2]u8 = undefined;
|
||||
Hasher.hash(input, h[0..]);
|
||||
|
||||
assertEqual(expected, h);
|
||||
}
|
||||
|
||||
// Assert `expected` == `input` where `input` is a bytestring.
|
||||
pub fn assertEqual(comptime expected: []const u8, input: []const u8) {
|
||||
var expected_bytes: [expected.len / 2]u8 = undefined;
|
||||
for (expected_bytes) |*r, i| {
|
||||
*r = fmt.parseInt(u8, expected[2*i .. 2*i+2], 16) catch unreachable;
|
||||
}
|
||||
|
||||
debug.assert(mem.eql(u8, expected_bytes, input));
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user