mirror of
https://github.com/denoland/deno.git
synced 2025-01-11 16:42:21 -05:00
fix(ext/node): fix hash.flush (#18818)
This commit is contained in:
parent
5b4a9b48ae
commit
63befe9377
4 changed files with 100 additions and 3 deletions
|
@ -48,6 +48,7 @@
|
|||
"test-crypto-hkdf.js",
|
||||
"test-crypto-hmac.js",
|
||||
"test-crypto-prime.js",
|
||||
"test-crypto-stream.js",
|
||||
"test-crypto-x509.js",
|
||||
"test-dgram-custom-lookup.js",
|
||||
"test-dgram-ipv6only.js",
|
||||
|
@ -242,6 +243,7 @@
|
|||
"test-crypto-hmac.js",
|
||||
"test-crypto-prime.js",
|
||||
"test-crypto-secret-keygen.js",
|
||||
"test-crypto-stream.js",
|
||||
"test-crypto-update-encoding.js",
|
||||
"test-crypto-x509.js",
|
||||
"test-dgram-close-during-bind.js",
|
||||
|
|
96
cli/tests/node_compat/test/parallel/test-crypto-stream.js
Normal file
96
cli/tests/node_compat/test/parallel/test-crypto-stream.js
Normal file
|
@ -0,0 +1,96 @@
|
|||
// deno-fmt-ignore-file
|
||||
// deno-lint-ignore-file
|
||||
|
||||
// Copyright Joyent and Node contributors. All rights reserved. MIT license.
|
||||
// Taken from Node 18.12.1
|
||||
// This file is automatically generated by "node/_tools/setup.ts". Do not modify this file manually
|
||||
|
||||
// Copyright Joyent, Inc. and other Node contributors.
|
||||
//
|
||||
// Permission is hereby granted, free of charge, to any person obtaining a
|
||||
// copy of this software and associated documentation files (the
|
||||
// "Software"), to deal in the Software without restriction, including
|
||||
// without limitation the rights to use, copy, modify, merge, publish,
|
||||
// distribute, sublicense, and/or sell copies of the Software, and to permit
|
||||
// persons to whom the Software is furnished to do so, subject to the
|
||||
// following conditions:
|
||||
//
|
||||
// The above copyright notice and this permission notice shall be included
|
||||
// in all copies or substantial portions of the Software.
|
||||
//
|
||||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||||
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
|
||||
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
||||
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||||
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
||||
// USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
||||
'use strict';
|
||||
const common = require('../common');
|
||||
if (!common.hasCrypto)
|
||||
common.skip('missing crypto');
|
||||
|
||||
const assert = require('assert');
|
||||
const stream = require('stream');
|
||||
const crypto = require('crypto');
|
||||
|
||||
if (!common.hasFipsCrypto) {
|
||||
// Small stream to buffer converter
|
||||
class Stream2buffer extends stream.Writable {
|
||||
constructor(callback) {
|
||||
super();
|
||||
|
||||
this._buffers = [];
|
||||
this.once('finish', function() {
|
||||
callback(null, Buffer.concat(this._buffers));
|
||||
});
|
||||
}
|
||||
|
||||
_write(data, encoding, done) {
|
||||
this._buffers.push(data);
|
||||
return done(null);
|
||||
}
|
||||
}
|
||||
|
||||
// Create an md5 hash of "Hallo world"
|
||||
const hasher1 = crypto.createHash('md5');
|
||||
hasher1.pipe(new Stream2buffer(common.mustCall(function end(err, hash) {
|
||||
assert.strictEqual(err, null);
|
||||
assert.strictEqual(
|
||||
hash.toString('hex'), '06460dadb35d3d503047ce750ceb2d07'
|
||||
);
|
||||
})));
|
||||
hasher1.end('Hallo world');
|
||||
|
||||
// Simpler check for unpipe, setEncoding, pause and resume
|
||||
crypto.createHash('md5').unpipe({});
|
||||
crypto.createHash('md5').setEncoding('utf8');
|
||||
crypto.createHash('md5').pause();
|
||||
crypto.createHash('md5').resume();
|
||||
}
|
||||
|
||||
// Decipher._flush() should emit an error event, not an exception.
|
||||
const key = Buffer.from('48fb56eb10ffeb13fc0ef551bbca3b1b', 'hex');
|
||||
const badkey = Buffer.from('12341234123412341234123412341234', 'hex');
|
||||
const iv = Buffer.from('6d358219d1f488f5f4eb12820a66d146', 'hex');
|
||||
const cipher = crypto.createCipheriv('aes-128-cbc', key, iv);
|
||||
const decipher = crypto.createDecipheriv('aes-128-cbc', badkey, iv);
|
||||
|
||||
// TODO(kt3k): Align error message of decipher with wrong padding and
|
||||
// enable the below test case.
|
||||
/*
|
||||
cipher.pipe(decipher)
|
||||
.on('error', common.expectsError(common.hasOpenSSL3 ? {
|
||||
message: /bad decrypt/,
|
||||
library: 'Provider routines',
|
||||
reason: 'bad decrypt',
|
||||
} : {
|
||||
message: /bad decrypt/,
|
||||
function: 'EVP_DecryptFinal_ex',
|
||||
library: 'digital envelope routines',
|
||||
reason: 'bad decrypt',
|
||||
}));
|
||||
*/
|
||||
|
||||
cipher.end('Papaya!'); // Should not cause an unhandled exception.
|
|
@ -66,7 +66,7 @@ export class Hash extends Transform {
|
|||
callback();
|
||||
},
|
||||
flush(callback: () => void) {
|
||||
this.push(context.digest(undefined));
|
||||
this.push(this.digest(undefined));
|
||||
callback();
|
||||
},
|
||||
});
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
|
||||
NOTE: This file should not be manually edited. Please edit 'cli/tests/node_compat/config.json' and run 'tools/node_compat/setup.ts' instead.
|
||||
|
||||
Total: 2924
|
||||
Total: 2923
|
||||
|
||||
- [abort/test-abort-backtrace.js](https://github.com/nodejs/node/tree/v18.12.1/test/abort/test-abort-backtrace.js)
|
||||
- [abort/test-abort-fatal-error.js](https://github.com/nodejs/node/tree/v18.12.1/test/abort/test-abort-fatal-error.js)
|
||||
|
@ -504,7 +504,6 @@ Total: 2924
|
|||
- [parallel/test-crypto-scrypt.js](https://github.com/nodejs/node/tree/v18.12.1/test/parallel/test-crypto-scrypt.js)
|
||||
- [parallel/test-crypto-secure-heap.js](https://github.com/nodejs/node/tree/v18.12.1/test/parallel/test-crypto-secure-heap.js)
|
||||
- [parallel/test-crypto-sign-verify.js](https://github.com/nodejs/node/tree/v18.12.1/test/parallel/test-crypto-sign-verify.js)
|
||||
- [parallel/test-crypto-stream.js](https://github.com/nodejs/node/tree/v18.12.1/test/parallel/test-crypto-stream.js)
|
||||
- [parallel/test-crypto-subtle-zero-length.js](https://github.com/nodejs/node/tree/v18.12.1/test/parallel/test-crypto-subtle-zero-length.js)
|
||||
- [parallel/test-crypto-verify-failure.js](https://github.com/nodejs/node/tree/v18.12.1/test/parallel/test-crypto-verify-failure.js)
|
||||
- [parallel/test-crypto-webcrypto-aes-decrypt-tag-too-small.js](https://github.com/nodejs/node/tree/v18.12.1/test/parallel/test-crypto-webcrypto-aes-decrypt-tag-too-small.js)
|
||||
|
|
Loading…
Reference in a new issue