ddb-table
Version:
Strongly typed library for querying and modeling DynamoDB documents.
185 lines (184 loc) • 19.6 kB
JavaScript
"use strict";
require("mocha");
var _chai = require("chai");
var _Table = _interopRequireDefault(require("./Table"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
describe('Table', () => {
describe('.index()', () => {
it('Basic Usage', () => {
const table = new _Table.default({
tableName: 'MyTable',
primaryKey: 'Id',
sortKey: 'Ver',
documentClient: {
scan: () => null
}
});
const index = table.index('Id-foo', 'Id', 'foo');
_chai.assert.deepEqual(index.scan().serialize(), {
TableName: 'MyTable',
IndexName: 'Id-foo'
});
});
});
describe('.put()', () => {
it('Basic Usage', () => {
const table = new _Table.default({
tableName: 'MyTable',
primaryKey: 'Id',
sortKey: 'Ver',
documentClient: {
put: () => null
}
});
_chai.assert.deepEqual(table.put({
Id: '12',
Ver: 2,
foo: 12.33,
inner: {
obj: 'foo'
},
hidden: false
}).condition(cn => cn.attributeNotExists('Id')).return('NONE').serialize(), {
TableName: 'MyTable',
ConditionExpression: 'attribute_not_exists(#Id)',
ExpressionAttributeNames: {
'#Id': 'Id'
},
Item: {
Id: '12',
Ver: 2,
foo: 12.33,
inner: {
obj: 'foo'
},
hidden: false
},
ReturnValues: 'NONE'
});
});
});
describe('.get()', () => {
it('Basic Usage', () => {
const table = new _Table.default({
tableName: 'MyTable',
primaryKey: 'Id',
sortKey: 'Ver',
documentClient: {
get: () => null
}
});
_chai.assert.deepEqual(table.get('ss', 1).project({
foo: false,
maybe: 1
}).serialize(), {
TableName: 'MyTable',
Key: {
Id: 'ss',
Ver: 1
},
ProjectionExpression: '#maybe',
ExpressionAttributeNames: {
'#maybe': 'maybe'
}
});
});
it('project(fields) type', () => {
const table = new _Table.default({
tableName: 'MyTable',
primaryKey: 'Id',
sortKey: 'Ver',
documentClient: {
get: () => null
}
});
const query = table.get('ss', 1).project({
foo: false,
maybe: 1
});
_chai.assert.ok(query);
});
it('project(fields) query', () => {
const table = new _Table.default({
tableName: 'MyTable',
primaryKey: 'Id',
sortKey: 'Ver',
documentClient: {
get: () => null
}
});
const query = table.get('ss', 1);
_chai.assert.ok({
foo: 1,
// Id2kk: true,
maybe: true,
hidden: false,
set: false,
inner: {
obj: false
}
});
});
});
describe('.update()', () => {
it('Basic Usage', () => {
const table = new _Table.default({
tableName: 'MyTable',
primaryKey: 'Id',
sortKey: 'Ver',
documentClient: {
update: () => null
}
});
_chai.assert.deepEqual(table.update('12', 2).condition(cn => cn.attributeExists('Id')).set(['inner', 'obj'], 'hello').add('foo', 5).delete('set', new Set(['del'])).remove('hidden').serialize(), {
TableName: 'MyTable',
Key: {
Id: '12',
Ver: 2
},
UpdateExpression: 'SET #inner.#obj = :obj REMOVE #hidden ADD #foo :foo DELETE #set :set',
ConditionExpression: 'attribute_exists(#Id)',
ExpressionAttributeNames: {
'#Id': 'Id',
'#foo': 'foo',
'#hidden': 'hidden',
'#inner': 'inner',
'#obj': 'obj',
'#set': 'set'
},
ExpressionAttributeValues: {
':foo': 5,
':obj': 'hello',
':set': new Set(['del'])
}
});
});
});
describe('.delete()', () => {
it('Basic Usage', () => {
const table = new _Table.default({
tableName: 'MyTable',
primaryKey: 'Id',
sortKey: 'Ver',
documentClient: {
delete: () => null
}
});
_chai.assert.deepEqual(table.delete('12', 2).condition(cn => cn.eq('foo', 12)).serialize(), {
TableName: 'MyTable',
Key: {
Id: '12',
Ver: 2
},
ConditionExpression: '#foo = :foo',
ExpressionAttributeNames: {
'#foo': 'foo'
},
ExpressionAttributeValues: {
':foo': 12
}
});
});
});
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["require","_chai","_Table","_interopRequireDefault","obj","__esModule","default","describe","it","table","Table","tableName","primaryKey","sortKey","documentClient","scan","index","assert","deepEqual","serialize","TableName","IndexName","put","Id","Ver","foo","inner","hidden","condition","cn","attributeNotExists","return","ConditionExpression","ExpressionAttributeNames","Item","ReturnValues","get","project","maybe","Key","ProjectionExpression","query","ok","set","update","attributeExists","add","delete","Set","remove","UpdateExpression","ExpressionAttributeValues","eq"],"sources":["../src/Table.test.ts"],"sourcesContent":["import 'mocha';\nimport { assert } from 'chai';\nimport Table from './Table';\nimport { GetQuery } from './queries';\nimport { TableKey } from './TableIndex';\n\ninterface DemoItem {\n  Id: string;\n  Ver: number;\n  foo: number;\n  inner: {\n    obj: string;\n  };\n  set?: Set<string>;\n  maybe?: boolean;\n  hidden: boolean;\n}\n\ntype DemoIndex = Pick<DemoItem, 'Id' | 'foo' | 'maybe'>;\n\ndescribe('Table', () => {\n  describe('.index()', () => {\n    it('Basic Usage', () => {\n      const table = new Table<DemoItem, 'Id', 'Ver'>({\n        tableName: 'MyTable',\n        primaryKey: 'Id',\n        sortKey: 'Ver',\n        documentClient: { scan: () => null } as never,\n      });\n\n      const index = table.index<DemoIndex, 'Id', 'foo'>('Id-foo', 'Id', 'foo');\n\n      assert.deepEqual(index.scan().serialize(), {\n        TableName: 'MyTable',\n        IndexName: 'Id-foo',\n      });\n    });\n  });\n\n  describe('.put()', () => {\n    it('Basic Usage', () => {\n      const table = new Table<DemoItem, 'Id', 'Ver'>({\n        tableName: 'MyTable',\n        primaryKey: 'Id',\n        sortKey: 'Ver',\n        documentClient: { put: () => null } as never,\n      });\n\n      assert.deepEqual(\n        table\n          .put({\n            Id: '12',\n            Ver: 2,\n            foo: 12.33,\n            inner: {\n              obj: 'foo',\n            },\n            hidden: false,\n          })\n          .condition((cn) => cn.attributeNotExists('Id'))\n          .return('NONE')\n          .serialize(),\n        {\n          TableName: 'MyTable',\n          ConditionExpression: 'attribute_not_exists(#Id)',\n          ExpressionAttributeNames: {\n            '#Id': 'Id',\n          },\n          Item: {\n            Id: '12',\n            Ver: 2,\n            foo: 12.33,\n            inner: {\n              obj: 'foo',\n            },\n            hidden: false,\n          },\n          ReturnValues: 'NONE',\n        },\n      );\n    });\n  });\n\n  describe('.get()', () => {\n    it('Basic Usage', () => {\n      const table = new Table<DemoItem, 'Id', 'Ver'>({\n        tableName: 'MyTable',\n        primaryKey: 'Id',\n        sortKey: 'Ver',\n        documentClient: { get: () => null } as never,\n      });\n\n      assert.deepEqual(\n        table\n          .get('ss', 1)\n          .project({ foo: false as boolean, maybe: 1 })\n          .serialize(),\n        {\n          TableName: 'MyTable',\n          Key: {\n            Id: 'ss',\n            Ver: 1,\n          },\n          ProjectionExpression: '#maybe',\n          ExpressionAttributeNames: {\n            '#maybe': 'maybe',\n          },\n        },\n      );\n    });\n\n    it('project(fields) type', () => {\n      const table = new Table<DemoItem, 'Id', 'Ver'>({\n        tableName: 'MyTable',\n        primaryKey: 'Id',\n        sortKey: 'Ver',\n        documentClient: { get: () => null } as never,\n      });\n\n      const query = table\n        .get('ss', 1)\n        .project({ foo: false as boolean, maybe: 1 });\n\n      assert.ok<\n        GetQuery<\n          Omit<DemoItem, 'foo' | 'hidden' | 'inner'> & { foo?: number },\n          TableKey<DemoItem, 'Id', 'Ver'>\n        >\n      >(query);\n    });\n\n    it('project(fields) query', () => {\n      const table = new Table<DemoItem, 'Id', 'Ver'>({\n        tableName: 'MyTable',\n        primaryKey: 'Id',\n        sortKey: 'Ver',\n        documentClient: { get: () => null } as never,\n      });\n\n      const query = table.get('ss', 1);\n\n      assert.ok<Required<Parameters<typeof query.project>[0]>>({\n        foo: 1,\n        // Id2kk: true,\n        maybe: true,\n        hidden: false,\n        set: false,\n        inner: {\n          obj: false,\n        },\n      });\n    });\n  });\n\n  describe('.update()', () => {\n    it('Basic Usage', () => {\n      const table = new Table<DemoItem, 'Id', 'Ver'>({\n        tableName: 'MyTable',\n        primaryKey: 'Id',\n        sortKey: 'Ver',\n        documentClient: { update: () => null } as never,\n      });\n\n      assert.deepEqual(\n        table\n          .update('12', 2)\n          .condition((cn) => cn.attributeExists('Id'))\n          .set(['inner', 'obj'], 'hello')\n          .add('foo', 5)\n          .delete('set', new Set(['del']))\n          .remove('hidden')\n          .serialize(),\n        {\n          TableName: 'MyTable',\n          Key: {\n            Id: '12',\n            Ver: 2,\n          },\n          UpdateExpression:\n            'SET #inner.#obj = :obj REMOVE #hidden ADD #foo :foo DELETE #set :set',\n          ConditionExpression: 'attribute_exists(#Id)',\n          ExpressionAttributeNames: {\n            '#Id': 'Id',\n            '#foo': 'foo',\n            '#hidden': 'hidden',\n            '#inner': 'inner',\n            '#obj': 'obj',\n            '#set': 'set',\n          },\n          ExpressionAttributeValues: {\n            ':foo': 5,\n            ':obj': 'hello',\n            ':set': new Set(['del']),\n          },\n        },\n      );\n    });\n  });\n\n  describe('.delete()', () => {\n    it('Basic Usage', () => {\n      const table = new Table<DemoItem, 'Id', 'Ver'>({\n        tableName: 'MyTable',\n        primaryKey: 'Id',\n        sortKey: 'Ver',\n        documentClient: { delete: () => null } as never,\n      });\n\n      assert.deepEqual(\n        table\n          .delete('12', 2)\n          .condition((cn) => cn.eq('foo', 12))\n          .serialize(),\n        {\n          TableName: 'MyTable',\n          Key: {\n            Id: '12',\n            Ver: 2,\n          },\n          ConditionExpression: '#foo = :foo',\n          ExpressionAttributeNames: {\n            '#foo': 'foo',\n          },\n          ExpressionAttributeValues: {\n            ':foo': 12,\n          },\n        },\n      );\n    });\n  });\n});\n"],"mappings":"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"}