UNPKG

cose-js

Version:

JavaScript COSE implementation

200 lines (182 loc) 7.61 kB
/* jshint esversion: 6 */ /* jslint node: true */ 'use strict'; const cose = require('../'); const test = require('ava'); const jsonfile = require('jsonfile'); const base64url = require('base64url'); const cbor = require('cbor'); const deepEqual = require('./util.js').deepEqual; test('create HMac-01', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/HMac-01.json'); const p = example.input.mac.protected; const u = example.input.mac.recipients[0].unprotected; const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const plaintext = Buffer.from(example.input.plaintext); const recipents = [{ key: key, u: u }]; const header = { p: p }; const buf = await cose.mac.create(header, plaintext, recipents); t.true(Buffer.isBuffer(buf)); t.true(buf.length > 0); const actual = cbor.decodeFirstSync(buf); const expected = cbor.decodeFirstSync(example.output.cbor); t.true(deepEqual(actual, expected)); }); test('verify HMac-01', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/HMac-01.json'); const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const data = example.output.cbor; const buf = await cose.mac.read(data, key); t.true(Buffer.isBuffer(buf)); t.true(buf.length > 0); t.is(buf.toString('utf8'), example.input.plaintext); }); test('create mac-pass-01', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-pass-01.json'); const p = example.input.mac.protected; const u = example.input.mac.unprotected; const ru = example.input.mac.recipients[0].unprotected; const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const plaintext = Buffer.from(example.input.plaintext); const recipents = [{ key: key, u: ru }]; const header = { p: p, u: u }; const buf = await cose.mac.create(header, plaintext, recipents); t.true(Buffer.isBuffer(buf)); t.true(buf.length > 0); t.is(buf.toString('hex'), example.output.cbor.toLowerCase()); const actual = cbor.decodeFirstSync(buf); const expected = cbor.decodeFirstSync(example.output.cbor); t.true(deepEqual(actual, expected)); }); test('create mac-pass-02', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-pass-02.json'); const p = example.input.mac.protected; const u = example.input.mac.unprotected; const ru = example.input.mac.recipients[0].unprotected; const external = Buffer.from(example.input.mac.external, 'hex'); const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const plaintext = Buffer.from(example.input.plaintext); const options = { encodep: 'empty' }; const header = { p: p, u: u }; const recipents = [{ key: key, u: ru }]; const buf = await cose.mac.create(header, plaintext, recipents, external, options); t.true(Buffer.isBuffer(buf)); t.true(buf.length > 0); const actual = cbor.decodeFirstSync(buf); const expected = cbor.decodeFirstSync(example.output.cbor); t.true(deepEqual(actual, expected)); }); test('create mac-pass-03', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-pass-03.json'); const p = example.input.mac.protected; const u = example.input.mac.unprotected; const ru = example.input.mac.recipients[0].unprotected; const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const plaintext = Buffer.from(example.input.plaintext); const options = { encodep: 'empty', excludetag: true }; const header = { p: p, u: u }; const recipents = [{ key: key, u: ru }]; const external = null; const buf = await cose.mac.create(header, plaintext, recipents, external, options); t.true(Buffer.isBuffer(buf)); t.true(buf.length > 0); const actual = cbor.decodeFirstSync(buf); const expected = cbor.decodeFirstSync(example.output.cbor); t.true(deepEqual(actual, expected)); }); test('verify mac-pass-01', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-pass-01.json'); const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const data = example.output.cbor; const buf = await cose.mac.read(data, key); t.true(Buffer.isBuffer(buf)); t.true(buf.length > 0); t.is(buf.toString('utf8'), example.input.plaintext); }); test('verify mac-pass-02', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-pass-02.json'); const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const external = Buffer.from(example.input.mac.external, 'hex'); const data = example.output.cbor; const buf = await cose.mac.read(data, key, external); t.true(Buffer.isBuffer(buf)); t.true(buf.length > 0); t.is(buf.toString('utf8'), example.input.plaintext); }); test('verify mac-pass-03', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-pass-03.json'); const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const options = { defaultType: cose.mac.MACTag }; const external = null; const data = example.output.cbor; const buf = await cose.mac.read(data, key, external, options); t.true(Buffer.isBuffer(buf)); t.true(buf.length > 0); t.is(buf.toString('utf8'), example.input.plaintext); }); test('verify mac-fail-01', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-fail-01.json'); const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const data = example.output.cbor; try { await cose.mac.read(data, key); t.fail('Expecting Array of lenght 4'); } catch (error) { t.is(error.message, 'Expecting Array of lenght 4'); } }); test('verify mac-fail-02', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-fail-02.json'); const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const data = example.output.cbor; try { await cose.mac.read(data, key); t.fail('Tag mismatch'); } catch (error) { t.is(error.message, 'Tag mismatch'); } }); test('verify mac-fail-03', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-fail-03.json'); const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const data = example.output.cbor; try { await cose.mac.read(data, key); t.fail('Unknown algorithm, -999'); } catch (error) { t.is(error.message, 'Unknown algorithm, -999'); } }); test('verify mac-fail-04', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-fail-04.json'); const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const data = example.output.cbor; try { await cose.mac.read(data, key); t.fail('Unknown algorithm, Unknown'); } catch (error) { t.is(error.message, 'Unknown algorithm, Unknown'); } }); test('verify mac-fail-06', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-fail-06.json'); const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const data = example.output.cbor; try { await cose.mac.read(data, key); t.fail('Tag mismatch'); } catch (error) { t.is(error.message, 'Tag mismatch'); } }); test('verify mac-fail-07', async t => { const example = jsonfile.readFileSync('test/Examples/mac-tests/mac-fail-07.json'); const key = base64url.toBuffer(example.input.mac.recipients[0].key.k); const data = example.output.cbor; try { await cose.mac.read(data, key); t.fail('Tag mismatch'); } catch (error) { t.is(error.message, 'Tag mismatch'); } });