123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- 'use strict'
- var test = require('tape')
- var txtStr = require('./')()
- var txtBin = require('./')({ binary: true })
- var obj = {
- String: 'foo',
- number: 42,
- empty: '',
- null: null,
- bool: true,
- buffer: new Buffer('bar')
- }
- test('encodingLength', function (t) {
- var len = txtBin.encodingLength(obj)
- t.equal(len, 54)
- t.end()
- })
- test('encode', function (t) {
- var buf = txtBin.encode(obj)
- var expected = new Buffer('0a' + '537472696e67' + '3d' + '666f6f' +
- '09' + '6e756d626572' + '3d' + '3432' +
- '06' + '656d707479' + '3d' +
- '09' + '6e756c6c' + '3d' + '6e756c6c' +
- '04' + '626f6f6c' +
- '0a' + '627566666572' + '3d' + '626172', 'hex')
- t.deepEqual(buf, expected)
- t.equal(txtBin.encode.bytes, expected.length)
- t.end()
- })
- test('encode - empty', function (t) {
- var buf = txtBin.encode({})
- var expected = new Buffer('00', 'hex')
- t.deepEqual(buf, expected)
- t.equal(txtBin.encode.bytes, expected.length)
- t.end()
- })
- test('encode - undefined', function (t) {
- var buf = txtBin.encode()
- var expected = new Buffer('00', 'hex')
- t.deepEqual(buf, expected)
- t.equal(txtBin.encode.bytes, expected.length)
- t.end()
- })
- test('encode - with buffer', function (t) {
- var buf = new Buffer(3)
- buf.fill(255)
- txtBin.encode({}, buf)
- var expected = new Buffer('00ffff', 'hex')
- t.deepEqual(buf, expected)
- t.equal(txtBin.encode.bytes, 1)
- t.end()
- })
- test('encode - with buffer and offset', function (t) {
- var buf = new Buffer(3)
- buf.fill(255)
- txtBin.encode({}, buf, 1)
- var expected = new Buffer('ff00ff', 'hex')
- t.deepEqual(buf, expected)
- t.equal(txtBin.encode.bytes, 1)
- t.end()
- })
- test('decode', function (t) {
- var encoded = txtBin.encode(obj)
- var result = txtBin.decode(encoded)
- var expected = {
- string: new Buffer('foo'),
- number: new Buffer('42'),
- empty: new Buffer(0),
- null: new Buffer('null'),
- bool: true,
- buffer: new Buffer('bar')
- }
- t.deepEqual(result, expected)
- t.equal(txtBin.decode.bytes, encoded.length)
- t.end()
- })
- test('decode - strings', function (t) {
- var encoded = txtStr.encode(obj)
- var result = txtStr.decode(encoded)
- var expected = {
- string: 'foo',
- number: '42',
- empty: '',
- null: 'null',
- bool: true,
- buffer: 'bar'
- }
- t.deepEqual(result, expected)
- t.equal(txtStr.decode.bytes, encoded.length)
- t.end()
- })
- test('decode - duplicate', function (t) {
- var orig = {
- Foo: 'bar',
- foo: 'ignore this'
- }
- var expected = {
- foo: new Buffer('bar')
- }
- var encoded = txtBin.encode(orig)
- var result = txtBin.decode(encoded)
- t.deepEqual(result, expected)
- t.equal(txtBin.decode.bytes, encoded.length)
- t.end()
- })
- test('decode - single zero bype', function (t) {
- var encoded = new Buffer('00', 'hex')
- var result = txtBin.decode(encoded)
- t.deepEqual(result, {})
- t.equal(txtBin.decode.bytes, encoded.length)
- t.end()
- })
- test('decode - with offset', function (t) {
- var encoded = new Buffer('012300', 'hex')
- var result = txtBin.decode(encoded, 2)
- t.deepEqual(result, {})
- t.equal(txtBin.decode.bytes, 1)
- t.end()
- })
- test('decode - exactly 256 bytes', function (t) {
- var expected = { foo: '' }
- var maxLength = Object.keys(expected).reduce(function (total, key) {
- return total - key.length - 1 // - 1 for the equal sign used to separate the key and the value
- }, 255)
- for (var n = 0; n < maxLength; n++) {
- expected.foo += 'x'
- }
- // the max case:
- var encoded = txtStr.encode(expected)
- t.equal(txtStr.encode.bytes, 256)
- var result = txtStr.decode(encoded)
- t.deepEqual(result, expected)
- t.equal(txtStr.decode.bytes, encoded.length)
- // go beound the max:
- expected.foo += 'x'
- encoded = txtStr.encode(expected)
- t.equal(txtStr.encode.bytes, 257)
- result = txtStr.decode(encoded)
- t.notDeepEqual(result, expected)
- t.ok(txtStr.decode.bytes > encoded.length)
- t.end()
- })
|