From d0cb8bfaed39738f60445db103d3da9d52e44694 Mon Sep 17 00:00:00 2001 From: Derek Wickern Date: Wed, 3 Nov 2021 10:55:17 -0700 Subject: [PATCH] prioritize newer mock handlers --- addon/mocks/mock-create-request.js | 1 - addon/mocks/mock-request.js | 8 +++++++ addon/mocks/mock-update-request.js | 1 - addon/mocks/request-wrapper.js | 7 ++++-- tests/unit/mocks/mock-create-test.js | 2 +- tests/unit/mocks/mock-find-all-test.js | 2 +- tests/unit/mocks/request-wrapper-test.js | 29 ++++++++++++++++++------ 7 files changed, 37 insertions(+), 13 deletions(-) diff --git a/addon/mocks/mock-create-request.js b/addon/mocks/mock-create-request.js index a26cb0c4..143c4a06 100644 --- a/addon/mocks/mock-create-request.js +++ b/addon/mocks/mock-create-request.js @@ -11,7 +11,6 @@ export default class MockCreateRequest extends AttributeMatcher( super(modelName, 'createRecord'); this.model = model; this.returnArgs = {}; - this.matchArgs = {}; this.setupHandler(); } diff --git a/addon/mocks/mock-request.js b/addon/mocks/mock-request.js index 739fcc95..e10a4a2a 100644 --- a/addon/mocks/mock-request.js +++ b/addon/mocks/mock-request.js @@ -140,6 +140,10 @@ export default class { return this; } + hasSomeParams() { + return !isEmptyObject(this.someQueryParams); + } + paramsMatch(request) { if (!isEmptyObject(this.someQueryParams)) { return isPartOf( @@ -179,6 +183,10 @@ export default class { return true; } + hasMatch() { + return this.matchArgs != null; + } + // mockId holds the url for this mock request oldUrl() { return this.mockId && this.mockId.url; diff --git a/addon/mocks/mock-update-request.js b/addon/mocks/mock-update-request.js index f9a1b361..54933957 100644 --- a/addon/mocks/mock-update-request.js +++ b/addon/mocks/mock-update-request.js @@ -13,7 +13,6 @@ export default class MockUpdateRequest extends MaybeIdUrlMatch( this.id = id; this.model = model; this.returnArgs = {}; - this.matchArgs = {}; this.setupHandler(); } diff --git a/addon/mocks/request-wrapper.js b/addon/mocks/request-wrapper.js index 4864facd..f3e6942c 100644 --- a/addon/mocks/request-wrapper.js +++ b/addon/mocks/request-wrapper.js @@ -55,12 +55,15 @@ export default class RequestWrapper { */ getHandlers() { return this.handlers.sort( - (a, b) => b.hasQueryParams() - a.hasQueryParams() + (a, b) => + b.hasMatch() - a.hasMatch() || + b.hasQueryParams() - a.hasQueryParams() || + b.hasSomeParams() - a.hasSomeParams() ); } addHandler(handler) { - this.handlers.push(handler); + this.handlers.unshift(handler); return this.index++; } diff --git a/tests/unit/mocks/mock-create-test.js b/tests/unit/mocks/mock-create-test.js index 75727fa1..e7ac58c2 100644 --- a/tests/unit/mocks/mock-create-test.js +++ b/tests/unit/mocks/mock-create-test.js @@ -53,10 +53,10 @@ module('MockCreate', function (hooks) { let user1 = build('user'); let user2 = build('user'); + mockCreate('user').returns({ attrs: { id: user2.get('id') } }); mockCreate('user') .returns({ attrs: { id: user1.get('id') } }) .singleUse(); - mockCreate('user').returns({ attrs: { id: user2.get('id') } }); let model1 = FactoryGuy.store.createRecord('user', user1.get()); await model1.save(); diff --git a/tests/unit/mocks/mock-find-all-test.js b/tests/unit/mocks/mock-find-all-test.js index b5ce281b..b5368e5f 100644 --- a/tests/unit/mocks/mock-find-all-test.js +++ b/tests/unit/mocks/mock-find-all-test.js @@ -108,8 +108,8 @@ module('MockFindAll', function (hooks) { let wrapper = RequestManager.findWrapper({ type: 'GET', url: '/users' }); let ids = wrapper.getHandlers().map((h) => h.mockId); assert.deepEqual(ids, [ - { type: 'GET', url: '/users', num: 0 }, { type: 'GET', url: '/users', num: 1 }, + { type: 'GET', url: '/users', num: 0 }, ]); }); diff --git a/tests/unit/mocks/request-wrapper-test.js b/tests/unit/mocks/request-wrapper-test.js index e6f0512a..080cb14a 100644 --- a/tests/unit/mocks/request-wrapper-test.js +++ b/tests/unit/mocks/request-wrapper-test.js @@ -1,6 +1,6 @@ import { module, test } from 'qunit'; import { setupTest } from 'ember-qunit'; -import { mockFindAll, mockQuery } from 'ember-data-factory-guy'; +import { mockFindAll, mockCreate } from 'ember-data-factory-guy'; import { inlineSetup } from '../../helpers/utility-methods'; import RequestManager from 'ember-data-factory-guy/mocks/request-manager'; @@ -10,12 +10,27 @@ module('RequestWrapper', function (hooks) { setupTest(hooks); inlineSetup(hooks, serializerType); - test('#getHandlers', function (assert) { - let mockF = mockFindAll('user', 2), - mockFQ = mockFindAll('user', 2).withParams({ foo: true }), - mockQ = mockQuery('user', { moo: true }), - wrapper = RequestManager.findWrapper({ handler: mockF }); + test('#getHandlers should prioritize handlers with match and query params', function (assert) { + const withoutParams = mockCreate('user', 2); + const withParams = mockCreate('user').withParams({ foo: true }); + const withSomeParams = mockCreate('user').withSomeParams({ foo: true }); + const withMatch = mockCreate('user').match({ foo: true }); + const wrapper = RequestManager.findWrapper({ handler: withoutParams }); - assert.deepEqual(wrapper.getHandlers(), [mockFQ, mockQ, mockF]); + assert.deepEqual(wrapper.getHandlers(), [ + withMatch, + withParams, + withSomeParams, + withoutParams, + ]); + }); + + test('#getHandlers should prioritize newer handlers', function (assert) { + const first = mockFindAll('user', 2); + const second = mockFindAll('user', 2); + const third = mockFindAll('user', 2); + const wrapper = RequestManager.findWrapper({ handler: first }); + + assert.deepEqual(wrapper.getHandlers(), [third, second, first]); }); });