From caf89650a49305ee47f9c1b9e192f6b8df6814bb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tobias=20Nie=C3=9Fen?= Date: Mon, 7 Jan 2019 20:27:31 +0100 Subject: [PATCH] test: improve test coverage of native crypto code PR-URL: https://github.com/nodejs/node/pull/25400 Reviewed-By: Colin Ihrig Reviewed-By: Sam Roberts Reviewed-By: Luigi Pinca Reviewed-By: James M Snell Reviewed-By: Ruben Bridgewater --- test/parallel/test-crypto-cipheriv-decipheriv.js | 12 ++++++++++++ test/parallel/test-crypto-hmac.js | 6 ++++++ test/parallel/test-crypto-sign-verify.js | 6 ++++++ 3 files changed, 24 insertions(+) diff --git a/test/parallel/test-crypto-cipheriv-decipheriv.js b/test/parallel/test-crypto-cipheriv-decipheriv.js index c0073abcfd4ee9..a6bb0266ff45d0 100644 --- a/test/parallel/test-crypto-cipheriv-decipheriv.js +++ b/test/parallel/test-crypto-cipheriv-decipheriv.js @@ -205,3 +205,15 @@ for (let n = 1; n < 256; n += 1) { if (common.hasFipsCrypto && n < 12) continue; crypto.createCipheriv('aes-128-gcm', Buffer.alloc(16), Buffer.alloc(n)); } + +{ + // Passing an invalid cipher name should throw. + assert.throws( + () => crypto.createCipheriv('aes-127', Buffer.alloc(16), null), + /Unknown cipher/); + + // Passing a key with an invalid length should throw. + assert.throws( + () => crypto.createCipheriv('aes-128-ecb', Buffer.alloc(17), null), + /Invalid key length/); +} diff --git a/test/parallel/test-crypto-hmac.js b/test/parallel/test-crypto-hmac.js index f21db29d36107f..8e04396bc1e7e4 100644 --- a/test/parallel/test-crypto-hmac.js +++ b/test/parallel/test-crypto-hmac.js @@ -463,3 +463,9 @@ common.expectsError( assert.deepStrictEqual(h.digest('latin1'), ''); } } + +{ + assert.throws( + () => crypto.createHmac('sha7', 'key'), + /Unknown message digest/); +} diff --git a/test/parallel/test-crypto-sign-verify.js b/test/parallel/test-crypto-sign-verify.js index eaf555ff57f9d8..f87e21d223ba27 100644 --- a/test/parallel/test-crypto-sign-verify.js +++ b/test/parallel/test-crypto-sign-verify.js @@ -363,3 +363,9 @@ common.expectsError( assert.throws(() => verify.verify('test', input), errObj); }); } + +{ + assert.throws( + () => crypto.createSign('sha8'), + /Unknown message digest/); +}