import test from "tape"; import vectors from "hash-test-vectors"; import createHash from "./browser"; var algorithms = ['sha1', 'sha224', 'sha256', 'sha384', 'sha512', 'md5', 'rmd160', 'ripemd160']; var encodings = ['hex', 'base64']; // ignore binary vectors.forEach(function (vector) { vector.ripemd160 = vector.rmd160; }); algorithms.forEach(function (algorithm) { test('test ' + algorithm + ' against test vectors', function (t) { vectors.forEach(function (obj, i) { var input = Buffer.from(obj.input, 'base64'); var node = obj[algorithm]; var js = createHash(algorithm).update(input).digest('hex'); t.equal(js, node, algorithm + '(testVector[' + i + ']) == ' + node); }); encodings.forEach(function (encoding) { vectors.forEach(function (obj, i) { var input = Buffer.from(obj.input, 'base64').toString(encoding); var node = obj[algorithm]; var js = createHash(algorithm).update(input, encoding).digest('hex'); t.equal(js, node, algorithm + '(testVector[' + i + '], ' + encoding + ') == ' + node); }); }); vectors.forEach(function (obj, i) { var input = Buffer.from(obj.input, 'base64'); var node = obj[algorithm]; var hash = createHash(algorithm); hash.end(input); var js = hash.read().toString('hex'); t.equal(js, node, algorithm + '(testVector[' + i + ']) == ' + node); }); t.end(); }); });