UNPKG

didjs

Version:

Decentralized Identifiers parser for javascript

361 lines (303 loc) 13.6 kB
var assert = require('assert'); var didjs = require('./index.js') describe('isReference', function() { it('should return false if no path or fragment', function() { var did = {method: 'example', id: '123'} assert.equal(didjs.utils.isReference(did), false); }); it('should return true if path', function() { var did = {method: 'example', id: '123', path:'a/b'} assert.equal(didjs.utils.isReference(did), true); }); it('should return true if pathSegments', function() { var did = {method: 'example', id: '123', pathSegments:['a','b']} assert.equal(didjs.utils.isReference(did), true); }); it('should return true if fragment', function() { var did = {method: 'example', id: '123', fragment:'#keys-1'} assert.equal(didjs.utils.isReference(did), true); }); it('should return true if path and fragment', function() { var did = {method: 'example', id: '123', path:'a/b', fragment:'#keys-1'} assert.equal(didjs.utils.isReference(did), true); }); }) describe('stringifyTest', function() { it('assembles a DID', function() { var did = {method: 'example', id: '123'} assert.equal('did:example:123', didjs.stringify(did)); }); it('assembles a DID from idStrings', function() { var did = {method: 'example', idStrings: ['123','456']} assert.equal('did:example:123:456', didjs.stringify(did)); }); it('returns empty string if no method', function() { var did = {id:'123'} assert.equal('', didjs.stringify(did)); }); it('returns empty string in no id or idStrings', function() { var did = {method:'example'} assert.equal('', didjs.stringify(did)); }); it('includes path', function() { var did = {id:'123', method:'example', path:'a/b'} assert.equal('did:example:123/a/b', didjs.stringify(did)); }); it('includes path assembled from pathSegments', function() { var did = {id:'123', method:'example', pathSegments:['a','b']} assert.equal('did:example:123/a/b', didjs.stringify(did)); }); it('includes fragment', function() { var did = {id:'123', method:'example', fragment:'keys-1'} assert.equal('did:example:123#keys-1', didjs.stringify(did)); }); it('does not include fragment if path is present', function() { var did = {id:'123', method:'example', fragment:'keys-1', path:'a/b'} assert.equal('did:example:123/a/b', didjs.stringify(did)); }); it('does not include fragment if pathSegemnts is present', function() { var did = {id:'123', method:'example', fragment:'keys-1', pathSegments:['a','b']} assert.equal('did:example:123/a/b', didjs.stringify(did)); }); }) describe('parseTest', function() { it('throws error if input is empty', function() { assert.throws(function(){didjs.parse('')}, Error); }); it('returns error if input length is less than length 7', function() { assert.throws(function(){didjs.parse('did:')}, Error); assert.throws(function(){didjs.parse('did:a')}, Error); assert.throws(function(){didjs.parse('did:a:')}, Error); }) it('returns error if input does not have a second : to mark end of method', function() { assert.throws(function(){didjs.parse('did:aaaaaaaaaaa')}, Error); }) it('returns error if method is empty', function() { assert.throws(function(){didjs.parse('did::aaaaaaaaaaa')}, Error); }) it('returns error if idstring is empty', function() { var dids = [ "did:a::123:456", "did:a:123::456", "did:a:123:456:", "did:a:123:/abc", "did:a:123:#abc", ] for (var i=0; i<dids.length; i++) { assert.throws(function(){didjs.parse(dids[i])}, Error) } }) it('returns error if input does not begin with did: scheme', function() { assert.throws(function(){didjs.parse('a:12345')}, Error); }) it('succeeds if it has did prefix and length is greater than 7', function() { assert.deepEqual(didjs.parse('did:a:1'), { method: 'a', idStrings: [ '1' ], id: '1', pathSegments: [], path: '' }); }) it('succeeds to extract method', function() { assert.equal(didjs.parse('did:a:1').method, 'a'); }) it('returns error if method has any other char than 0-9 or a-z', function() { assert.throws(function(){didjs.parse('did:aA:1')}, Error); }) it('succeeds to extract id', function() { assert.equal(didjs.parse('did:a:1').id, '1'); }) it('succeeds to extract id parts', function() { const did = didjs.parse('did:a:123:456') assert.equal(did.idStrings[0], '123'); assert.equal(did.idStrings[1], '456'); }) it('returns error if ID has an invalid char', function() { assert.throws(function(){didjs.parse('did:a:1&&111')}, Error); }) it('succeeds to extract path', function() { assert.equal(didjs.parse('did:a:123:456/someService').path, 'someService'); }) it('succeeds to extract path segments', function() { const did = didjs.parse('did:a:123:456/a/b') assert.equal(did.pathSegments[0], 'a'); assert.equal(did.pathSegments[1], 'b'); }) it('succeeds with percent encoded chars in path', function() { assert.equal(didjs.parse('did:a:123:456/a/%20a').path, 'a/%20a'); }) it('returns error if % in path is not followed by 2 hex chars', function() { var dids = [ "did:a:123:456/%", "did:a:123:456/%a", "did:a:123:456/%!*", "did:a:123:456/%A!", "did:xyz:pqr#%A!", "did:a:123:456/%A%", ] for (var i=0; i<dids.length; i++) { assert.throws(function(){didjs.parse(dids[i])}, Error) } }) it('returns error if path is empty but there is a slash', function() { assert.throws(function(){didjs.parse('did:a:123:456/')}, Error); }) it('returns error if first path segment is empty', function() { assert.throws(function(){didjs.parse('did:a:123:456//abc')}, Error); }) it('does not fail if second path segment is empty', function() { assert.doesNotThrow(function(){didjs.parse('did:a:123:456/abc//pqr')}, Error); }) it('returns error if path has invalid char', function() { assert.throws(function(){didjs.parse('did:a:123:456/ssss^sss')}, Error); }) it('does not fail if path has at least one segment and a trailing slash', function() { assert.doesNotThrow(function(){didjs.parse('did:a:123:456/a/b/')}, Error); }) it('succeeds to extract fragment', function() { assert.equal(didjs.parse('did:a:123:456#keys-1').fragment, 'keys-1'); }) it('succeeds to extract fragment', function() { assert.equal(didjs.parse('did:a:123:456#aaaaaa%20a').fragment, 'aaaaaa%20a'); }) it('returns error if % in fragment is not followed by 2 hex chars', function() { var dids = [ "did:xyz:pqr#%", "did:xyz:pqr#%a", "did:xyz:pqr#%!*", "did:xyz:pqr#%!A", "did:xyz:pqr#%A!", "did:xyz:pqr#%A%", ] for (var i=0; i<dids.length; i++) { assert.throws(function(){didjs.parse(dids[i])}, Error) } }) it('fails if fragment has invalid char', function() { assert.throws(function(){didjs.parse('did:a:123:456#ssss^sss')}, Error); }) }) describe('utilsTest', function() { }) describe('utils test', function() { it('tests isNotValidIDChar', function() { var valid = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '.', '-'] for (var i=0; i<valid.length; i++) { assert.strictEqual(didjs.utils.isNotValidIDChar(valid[i]), false) } var notvalid = ['%', '^', '#', ' ', '_', '~', '!', '$', '&', '\'', '(', ')', '*', '+', ',', ';', '=', ':', '@', '/', '?'] for (var i=0; i<notvalid.length; i++) { assert.strictEqual(didjs.utils.isNotValidIDChar(notvalid[i]), true) } }) it('tests isNotValidFragmentChar', function() { var valid = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '-', '.', '_', '~', '!', '$', '&', '\'', '(', ')', '*', '+', ',', ';', '=', ':', '@', '/', '?'] for (var i=0; i<valid.length; i++) { assert.strictEqual(didjs.utils.isNotValidFragmentChar(valid[i]), false) } var notvalid = ['%', '^', '#', ' '] for (var i=0; i<notvalid.length; i++) { assert.strictEqual(didjs.utils.isNotValidFragmentChar(notvalid[i]), true) } }) it('tests isNotValidPathChar', function() { var valid = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '-', '.', '_', '~', '!', '$', '&', '\'', '(', ')', '*', '+', ',', ';', '=', ':', '@'] for (var i=0; i<valid.length; i++) { assert.strictEqual(didjs.utils.isNotValidPathChar(valid[i]), false) } var notvalid = ['%', '/', '?'] for (var i=0; i<notvalid.length; i++) { assert.strictEqual(didjs.utils.isNotValidPathChar(notvalid[i]), true) } }) it('tests isNotUnreservedOrSubdelim', function() { var valid = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '-', '.', '_', '~', '!', '$', '&', '\'', '(', ')', '*', '+', ',', ';', '='] for (var i=0; i<valid.length; i++) { assert.strictEqual(didjs.utils.isNotUnreservedOrSubdelim(valid[i]), false) } var notvalid = ['%', ':', '@', '/', '?'] for (var i=0; i<notvalid.length; i++) { assert.strictEqual(didjs.utils.isNotUnreservedOrSubdelim(notvalid[i]), true) } }) it('tests isNotHexDigit', function() { var valid = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'a', 'b', 'c', 'd', 'e', 'f'] for (var i=0; i<valid.length; i++) { assert.strictEqual(didjs.utils.isNotHexDigit(valid[i]), false) } var notvalid = ['G', 'g', '%', '\x40', '\x47', '\x60', '\x67'] for (var i=0; i<notvalid.length; i++) { assert.strictEqual(didjs.utils.isNotHexDigit(notvalid[i]), true) } }) it('tests isNotDigit', function() { var valid = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9'] for (var i=0; i<valid.length; i++) { assert.strictEqual(didjs.utils.isNotDigit(valid[i]), false) } var notvalid = ['A', 'a', '\x29', '\x40', '/'] for (var i=0; i<notvalid.length; i++) { assert.strictEqual(didjs.utils.isNotDigit(notvalid[i]), true) } }) it('tests isNotAlpha', function() { var valid = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'] for (var i=0; i<valid.length; i++) { assert.strictEqual(didjs.utils.isNotAlpha(valid[i]), false) } var notvalid = ['\x40', '\x5B', '\x60', '\x7B', '0', '9', '-', '%'] for (var i=0; i<notvalid.length; i++) { assert.strictEqual(didjs.utils.isNotAlpha(notvalid[i]), true) } }) it('tests isNotBigLetter', function() { var valid = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'] for (var i=0; i<valid.length; i++) { assert.strictEqual(didjs.utils.isNotBigLetter(valid[i]), false) } var notvalid = ['\x40', '\x5B', 'a', 'z', '1', '9', '-', '%'] for (var i=0; i<notvalid.length; i++) { assert.strictEqual(didjs.utils.isNotBigLetter(notvalid[i]), true) } }) it('tests isNotSmallLetter', function() { var valid = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'] for (var i=0; i<valid.length; i++) { assert.strictEqual(didjs.utils.isNotSmallLetter(valid[i]), false) } var notvalid = ['\x60', '\x7B', 'A', 'Z', '1', '9', '-', '%'] for (var i=0; i<notvalid.length; i++) { assert.strictEqual(didjs.utils.isNotSmallLetter(notvalid[i]), true) } }) })