From 4b5852fab123017a47863a9c7c9b8b2411afd4b4 Mon Sep 17 00:00:00 2001 From: Naz Date: Mon, 21 Feb 2022 11:04:47 +0700 Subject: [PATCH] Extracted separate member agent test util refs https://github.com/TryGhost/Toolbox/issues/214 - TestAgent was used to initialize both Admin & Member API agents, which is somewhat confusing because Member API does not have the same "loginAs" functionality like Admin API does - Having distinct agents for each API makes the class API cleaner with possibility to extract common functionality even further --- ...{test-agent.js => admin-api-test-agent.js} | 4 ++-- test/utils/e2e-framework.js | 13 ++++++----- test/utils/members-api-test-agent.js | 22 +++++++++++++++++++ 3 files changed, 31 insertions(+), 8 deletions(-) rename test/utils/{test-agent.js => admin-api-test-agent.js} (95%) create mode 100644 test/utils/members-api-test-agent.js diff --git a/test/utils/test-agent.js b/test/utils/admin-api-test-agent.js similarity index 95% rename from test/utils/test-agent.js rename to test/utils/admin-api-test-agent.js index 6d1ec0d4b8..c290a94494 100644 --- a/test/utils/test-agent.js +++ b/test/utils/admin-api-test-agent.js @@ -14,7 +14,7 @@ const ownerUser = { * @param {String} options.apiURL * @param {String} options.originURL */ -class TestAgent extends Agent { +class AdminAPITestAgent extends Agent { constructor(app, options) { super(app, { baseUrl: options.apiURL, @@ -53,4 +53,4 @@ class TestAgent extends Agent { } } -module.exports = TestAgent; +module.exports = AdminAPITestAgent; diff --git a/test/utils/e2e-framework.js b/test/utils/e2e-framework.js index 5562499aaf..a5e98a87a7 100644 --- a/test/utils/e2e-framework.js +++ b/test/utils/e2e-framework.js @@ -27,7 +27,8 @@ const urlServiceUtils = require('./url-service-utils'); const mockManager = require('./e2e-framework-mock-manager'); const boot = require('../../core/boot'); -const TestAgent = require('./test-agent'); +const AdminAPITestAgent = require('./admin-api-test-agent'); +const MembersAPITestAgent = require('./members-api-test-agent'); const db = require('./db-utils'); // Services that need resetting @@ -161,7 +162,7 @@ const getAdminAPIAgent = async (options = {}) => { const app = await startGhost(bootOptions); const originURL = configUtils.config.get('url'); - return new TestAgent(app, { + return new AdminAPITestAgent(app, { apiURL: '/ghost/api/canary/admin/', originURL }); @@ -186,7 +187,7 @@ const getMembersAPIAgent = async () => { const app = await startGhost(bootOptions); const originURL = configUtils.config.get('url'); - return new TestAgent(app, { + return new MembersAPITestAgent(app, { apiURL: '/members/', originURL }); @@ -198,7 +199,7 @@ const getMembersAPIAgent = async () => { /** * - * @returns {Promise<{adminAgent: TestAgent, membersAgent: TestAgent}>} agent + * @returns {Promise<{adminAgent: AdminAPITestAgent, membersAgent: MembersAPITestAgent}>} agents */ const getAgentsForMembers = async () => { let membersAgent; @@ -212,11 +213,11 @@ const getAgentsForMembers = async () => { const app = await startGhost(bootOptions); const originURL = configUtils.config.get('url'); - membersAgent = new TestAgent(app, { + membersAgent = new MembersAPITestAgent(app, { apiURL: '/members/', originURL }); - adminAgent = new TestAgent(app, { + adminAgent = new AdminAPITestAgent(app, { apiURL: '/ghost/api/canary/admin/', originURL }); diff --git a/test/utils/members-api-test-agent.js b/test/utils/members-api-test-agent.js new file mode 100644 index 0000000000..336820c6c8 --- /dev/null +++ b/test/utils/members-api-test-agent.js @@ -0,0 +1,22 @@ +const Agent = require('@tryghost/express-test'); + +/** + * @constructor + * @param {Object} app Ghost express app instance + * @param {Object} options + * @param {String} options.apiURL + * @param {String} options.originURL + */ +class MembersAPITestAgent extends Agent { + constructor(app, options) { + super(app, { + baseUrl: options.apiURL, + headers: { + host: options.originURL.replace(/http:\/\//, ''), + origin: options.originURL + } + }); + } +} + +module.exports = MembersAPITestAgent;