From 0e1c9655af71ec4fa159503b286fa28d4c01cb8d Mon Sep 17 00:00:00 2001 From: Aaron Sikes Date: Sun, 2 Jul 2023 13:52:56 -0400 Subject: [PATCH] Add failing test for arraybuffer attributes --- .../test/memory-source-updatable-test.ts | 25 +++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/packages/@orbit/memory/test/memory-source-updatable-test.ts b/packages/@orbit/memory/test/memory-source-updatable-test.ts index 859e55fa..9e1c05b2 100644 --- a/packages/@orbit/memory/test/memory-source-updatable-test.ts +++ b/packages/@orbit/memory/test/memory-source-updatable-test.ts @@ -15,6 +15,12 @@ const { module, test } = QUnit; module('MemorySource - updatable', function (hooks) { const schemaDefinition: RecordSchemaSettings = { models: { + thingy: { + attributes: { + ab: { type: 'object' }, + other: { type: 'object' }, + }, + }, star: { attributes: { name: { type: 'string' } @@ -70,6 +76,25 @@ module('MemorySource - updatable', function (hooks) { keyMap = new RecordKeyMap(); }); + test("#update - works with array buffers", async function(assert) { + const source = new MemorySource({schema, keyMap}); + const ident = {type: 'thingy', id: 'a'}; + + const record = {...ident, attributes: { + ab: new ArrayBuffer(32), + other: {x: 10, y: 10}, + }}; + + await source.update(t => t.addRecord(record)); + + await source.update(t => + t.replaceAttribute(ident, 'other', {x: 2, y: 2}) + ); + + let result = await source.query(q => q.findRecord(ident)); + assert.ok(result.attributes.ab instanceof ArrayBuffer); + }); + test("#update - transforms the source's cache", async function (assert) { assert.expect(4);