summaryrefslogtreecommitdiff
path: root/alarm/node_modules/xxhashjs/test
diff options
context:
space:
mode:
authorMinteck <contact@minteck.org>2022-10-18 08:59:09 +0200
committerMinteck <contact@minteck.org>2022-10-18 08:59:09 +0200
commit2c4ae43e688a9873e86211ea0e7aeb9ba770dd77 (patch)
tree17848d95522dab25d3cdeb9c4a6450e2a234861f /alarm/node_modules/xxhashjs/test
parent108525534c28013cfe1897c30e4565f9893f3766 (diff)
downloadpluralconnect-2c4ae43e688a9873e86211ea0e7aeb9ba770dd77.tar.gz
pluralconnect-2c4ae43e688a9873e86211ea0e7aeb9ba770dd77.tar.bz2
pluralconnect-2c4ae43e688a9873e86211ea0e7aeb9ba770dd77.zip
Update
Diffstat (limited to 'alarm/node_modules/xxhashjs/test')
-rw-r--r--alarm/node_modules/xxhashjs/test/XXH-test.js172
1 files changed, 172 insertions, 0 deletions
diff --git a/alarm/node_modules/xxhashjs/test/XXH-test.js b/alarm/node_modules/xxhashjs/test/XXH-test.js
new file mode 100644
index 0000000..a2765c0
--- /dev/null
+++ b/alarm/node_modules/xxhashjs/test/XXH-test.js
@@ -0,0 +1,172 @@
+var assert = require('assert')
+var XXH = require('..')
+
+describe('XXH', function () {
+ var seed = 0
+
+ describe('with small input multiple of 4', function () {
+ var input = 'abcd'
+ var expected = 'A3643705' // Computed with xxHash C version
+
+ it('should return hash in a single step', function (done) {
+ var h = XXH.h32( input, seed ).toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ it('should return hash in many steps', function (done) {
+ var H = XXH.h32( seed )
+ var h = H.update( input ).digest().toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ })
+
+ describe('with medium input multiple of 4', function () {
+ var input = Array(1001).join('abcd')
+ var expected = 'E18CBEA'
+
+ it('should return hash in a single step', function (done) {
+ var h = XXH.h32( input, seed ).toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ it('should return hash in many steps', function (done) {
+ var H = XXH.h32( seed )
+ var h = H.update( input ).digest().toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ })
+
+ describe('with small input', function () {
+ var input = 'abc'
+ var expected = '32D153FF' // Computed with xxHash C version
+
+ it('should return hash in a single step', function (done) {
+ var h = XXH.h32( input, seed ).toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ it('should return hash in many steps', function (done) {
+ var H = XXH.h32( seed )
+ var h = H.update( input ).digest().toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ })
+
+ describe('with medium input', function () {
+ var input = Array(1000).join('abc')
+ var expected = '89DA9B6E'
+
+ it('should return hash in a single step', function (done) {
+ var h = XXH.h32( input, seed ).toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ it('should return hash in many steps', function (done) {
+ var H = XXH.h32( seed )
+ var h = H.update( input ).digest().toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ })
+
+ describe('with split medium input', function () {
+ var input = Array(1000).join('abc')
+ var expected = '89DA9B6E'
+
+ it('should return hash with split input < 16', function (done) {
+ var H = XXH.h32( seed )
+ var h = H
+ .update( input.slice(0, 10) )
+ .update( input.slice(10) )
+ .digest().toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ it('should return hash with split input = 16', function (done) {
+ var H = XXH.h32( seed )
+ var h = H
+ .update( input.slice(0, 16) )
+ .update( input.slice(16) )
+ .digest().toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ it('should return hash with split input > 16', function (done) {
+ var H = XXH.h32( seed )
+ var h = H
+ .update( input.slice(0, 20) )
+ .update( input.slice(20) )
+ .digest().toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ })
+
+ describe('with utf-8 strings', function () {
+ var input = 'heiå'
+ var expected = 'DB5ABCCC' // Computed with xxHash C version
+
+ it('should return hash', function (done) {
+ var h = XXH.h32( input, seed ).toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ it('should return hash in many steps', function (done) {
+ var H = XXH.h32( seed )
+ var h = H.update( input ).digest().toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ })
+
+ describe('with utf-8 strings', function () {
+ var input = 'κόσμε'
+ var expected = 'D855F606' // Computed with xxHash C version
+
+ it('should return hash', function (done) {
+ var h = XXH.h32( input, seed ).toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ it('should return hash in many steps', function (done) {
+ var H = XXH.h32( seed )
+ var h = H.update( input ).digest().toString(16).toUpperCase()
+
+ assert.equal( h, expected )
+ done()
+ })
+
+ })
+
+})