summaryrefslogtreecommitdiff
path: root/school/node_modules/xxhashjs/test/XXH-test.js
diff options
context:
space:
mode:
authorMinteck <contact@minteck.org>2023-01-10 14:54:04 +0100
committerMinteck <contact@minteck.org>2023-01-10 14:54:04 +0100
commit99c1d9af689e5325f3cf535c4007b3aeb8325229 (patch)
treee663b3c2ebdbd67c818ac0c5147f0ce1d2463cda /school/node_modules/xxhashjs/test/XXH-test.js
parent9871b03912fc28ad38b4037ebf26a78aa937baba (diff)
downloadpluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.tar.gz
pluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.tar.bz2
pluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.zip
Update - This is an automated commit
Diffstat (limited to 'school/node_modules/xxhashjs/test/XXH-test.js')
-rw-r--r--school/node_modules/xxhashjs/test/XXH-test.js172
1 files changed, 172 insertions, 0 deletions
diff --git a/school/node_modules/xxhashjs/test/XXH-test.js b/school/node_modules/xxhashjs/test/XXH-test.js
new file mode 100644
index 0000000..a2765c0
--- /dev/null
+++ b/school/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()
+ })
+
+ })
+
+})