ref: f6ba58c5be0d9632a34ae6ad1a305445a71ebc89
dir: /lib/crypto/test/md5.myr/
use std use crypto const main = { hasheq(crypto.md5("")[:], \ "d41d8cd98f00b204e9800998ecf8427e") hasheq(crypto.md5("h")[:], \ "2510c39011c5be704182423e3a695e91") /* 64 byte block */ hasheq(crypto.md5("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa")[:], \ "014842d480b571495a4a0363793f7367") /* tail spanning */ hasheq(crypto.md5("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaabbbbb")[:], \ "3b0bb4c5ece4a6568caa7266e740a140") } const hasheq = {got, expected var sb, str sb = std.mksb() for x : got std.sbfmt(sb, "{p=0,w=2,x}", x) ;; str = std.sbfin(sb) if (!std.sleq(str, expected)) std.fatal("mismatched hashes:\n\tgot:\t{}\n\texpected:\t{}\n", str, expected) ;; std.slfree(str) }