From 0eb072c2cf2b0b0b52d2635b1c77c36538f3d95c Mon Sep 17 00:00:00 2001 From: Lawrence <34475808+acodeninja@users.noreply.github.com> Date: Mon, 30 Sep 2024 14:39:19 +0100 Subject: [PATCH] test: ensure that dry models are not put (#22) * test: ensure that dry models are not put * chore: fix empty functions --- src/engine/Engine.test.js | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/src/engine/Engine.test.js b/src/engine/Engine.test.js index 75bcb24..920d318 100644 --- a/src/engine/Engine.test.js +++ b/src/engine/Engine.test.js @@ -141,3 +141,38 @@ test('ImplementedEngine.search(MainModel, "test") when caching is on calls Imple t.is(engine.getSearchIndexCompiled.getCalls().length, 1); }); + +test('ImplementedEngine.put(partialModel) does not put dry models', async t => { + const models = new Models(); + const model = models.createFullTestModel(); + + const partialModel = MainModel.fromData(model.toData()); + + class ImplementedEngine extends Engine { + static getById(id) { + return models.models[id]; + } + + static getSearchIndexCompiled = sinon.stub().callsFake((model) => + Promise.resolve(JSON.parse(JSON.stringify(models.getSearchIndex(model)))), + ); + + static getSearchIndexRaw = sinon.stub().callsFake((model) => + Promise.resolve(JSON.parse(JSON.stringify(models.getRawSearchIndex(model)))), + ); + + static putSearchIndexRaw = sinon.stub(); + + static putSearchIndexCompiled = sinon.stub(); + + static putIndex = sinon.stub(); + + static putModel = sinon.stub(); + } + + const engine = ImplementedEngine.configure({cache: {search: 5000}}); + + await engine.put(partialModel); + + t.is(engine.putModel.getCalls().length, 1); +});