mirror of
https://github.com/nodejs/node.git
synced 2025-05-21 19:44:16 +00:00

Enable linting for the test directory. A number of changes was made so all tests conform the current rules used by lib and src directories. The only exception for tests is that unreachable (dead) code is allowed. test-fs-non-number-arguments-throw had to be excluded from the changes because of a weird issue on Windows CI. PR-URL: https://github.com/nodejs/io.js/pull/1721 Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
47 lines
1.3 KiB
JavaScript
47 lines
1.3 KiB
JavaScript
'use strict';
|
|
// This is the same as test/simple/test-crypto, but from before the shift
|
|
// to use buffers by default.
|
|
|
|
|
|
var common = require('../common');
|
|
var assert = require('assert');
|
|
|
|
if (!common.hasCrypto) {
|
|
console.log('1..0 # Skipped: missing crypto');
|
|
process.exit();
|
|
}
|
|
var crypto = require('crypto');
|
|
|
|
var EXTERN_APEX = 0xFBEE9;
|
|
|
|
// manually controlled string for checking binary output
|
|
var ucs2_control = 'a\u0000';
|
|
|
|
// grow the strings to proper length
|
|
while (ucs2_control.length <= EXTERN_APEX) {
|
|
ucs2_control += ucs2_control;
|
|
}
|
|
|
|
|
|
// check resultant buffer and output string
|
|
var b = new Buffer(ucs2_control + ucs2_control, 'ucs2');
|
|
|
|
//
|
|
// Test updating from birant data
|
|
//
|
|
(function() {
|
|
var datum1 = b.slice(700000);
|
|
var hash1_converted = crypto.createHash('sha1')
|
|
.update(datum1.toString('base64'), 'base64')
|
|
.digest('hex');
|
|
var hash1_direct = crypto.createHash('sha1').update(datum1).digest('hex');
|
|
assert.equal(hash1_direct, hash1_converted, 'should hash the same.');
|
|
|
|
var datum2 = b;
|
|
var hash2_converted = crypto.createHash('sha1')
|
|
.update(datum2.toString('base64'), 'base64')
|
|
.digest('hex');
|
|
var hash2_direct = crypto.createHash('sha1').update(datum2).digest('hex');
|
|
assert.equal(hash2_direct, hash2_converted, 'should hash the same.');
|
|
})();
|