0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Removed duplicate snapshot initialization code

refs https://github.com/TryGhost/Toolbox/issues/158

- Allows for much smaller amount of code to configure a test to work with chai-jest-snapshots. They now work automatically for all regression tests and could be enabled for other suites by adding the "--require=./test/utils/snapshots.js" parameter in respective test:* package script
- Regenerated snapshot for authentication test as the naming structure
changed a little with the snapshot metadata being taken on a higher
level in the test (uses the suite name instead of a specific describe it
used to be called from)
This commit is contained in:
Naz 2021-12-09 17:59:46 +04:00 committed by naz
parent 0fbec65a6e
commit 5a150cc3b6
5 changed files with 85 additions and 83 deletions

View file

@ -32,7 +32,7 @@
"test:unit": "c8 --reporter text-summary --reporter cobertura mocha --require=./test/utils/overrides.js --exit --trace-warnings --recursive --extension=test.js './test/unit' --timeout=2000", "test:unit": "c8 --reporter text-summary --reporter cobertura mocha --require=./test/utils/overrides.js --exit --trace-warnings --recursive --extension=test.js './test/unit' --timeout=2000",
"test:integration": "mocha --require=./test/utils/overrides.js --exit --trace-warnings --recursive --extension=test.js './test/integration' --timeout=5000", "test:integration": "mocha --require=./test/utils/overrides.js --exit --trace-warnings --recursive --extension=test.js './test/integration' --timeout=5000",
"test:e2e": "mocha --require=./test/utils/overrides.js --exit --trace-warnings --recursive --extension=test.js './test/e2e-api' './test/e2e-frontend' './test/e2e-server' --timeout=10000", "test:e2e": "mocha --require=./test/utils/overrides.js --exit --trace-warnings --recursive --extension=test.js './test/e2e-api' './test/e2e-frontend' './test/e2e-server' --timeout=10000",
"test:regression": "mocha --require=./test/utils/overrides.js --exit --trace-warnings --recursive --extension=test.js './test/regression' --timeout=60000", "test:regression": "mocha --require=./test/utils/overrides.js --require=./test/utils/snapshots.js --exit --trace-warnings --recursive --extension=test.js './test/regression' --timeout=60000",
"test:unit:slow": "yarn test:unit --reporter=mocha-slow-test-reporter", "test:unit:slow": "yarn test:unit --reporter=mocha-slow-test-reporter",
"test:int:slow": "yarn test:integration --reporter=mocha-slow-test-reporter", "test:int:slow": "yarn test:integration --reporter=mocha-slow-test-reporter",
"test:e2e:slow": "yarn test:e2e --reporter=mocha-slow-test-reporter", "test:e2e:slow": "yarn test:e2e --reporter=mocha-slow-test-reporter",

View file

@ -1,12 +1,10 @@
const chai = require('chai');
const {expect} = require('chai'); const {expect} = require('chai');
const {any} = require('expect'); const {any} = require('expect');
const chaiJestSnapshot = require('@ethanresnick/chai-jest-snapshot'); const security = require('@tryghost/security');
const testUtils = require('../../../../utils/index'); const testUtils = require('../../../../utils/index');
const framework = require('../../../../utils/e2e-framework'); const framework = require('../../../../utils/e2e-framework');
const models = require('../../../../../core/server/models/index'); const models = require('../../../../../core/server/models/index');
const security = require('@tryghost/security');
const settingsCache = require('../../../../../core/shared/settings-cache'); const settingsCache = require('../../../../../core/shared/settings-cache');
const config = require('../../../../../core/shared/config/index'); const config = require('../../../../../core/shared/config/index');
@ -16,7 +14,6 @@ describe('Authentication API canary', function () {
describe('Blog setup', function () { describe('Blog setup', function () {
before(async function () { before(async function () {
chaiJestSnapshot.resetSnapshotRegistry();
request = await framework.getAgent('/ghost/api/canary/admin/'); request = await framework.getAgent('/ghost/api/canary/admin/');
}); });
@ -25,7 +22,6 @@ describe('Authentication API canary', function () {
}); });
beforeEach(function () { beforeEach(function () {
chaiJestSnapshot.configureUsingMochaContext(this);
emailStub = framework.stubMail(); emailStub = framework.stubMail();
}); });

View file

@ -101,17 +101,7 @@ Object {
} }
`; `;
exports[`Authentication API canary Blog setup update setup 3`] = ` exports[`Authentication API canary Invitation check invalid invite 1`] = `
Object {
"invitation": Array [
Object {
"valid": true,
},
],
}
`;
exports[`Authentication API canary Blog setup update setup 4`] = `
Object { Object {
"invitation": Array [ "invitation": Array [
Object { Object {
@ -121,7 +111,17 @@ Object {
} }
`; `;
exports[`Authentication API canary Blog setup update setup 5`] = ` exports[`Authentication API canary Invitation check valid invite 1`] = `
Object {
"invitation": Array [
Object {
"valid": true,
},
],
}
`;
exports[`Authentication API canary Invitation try to accept with invite 1`] = `
Object { Object {
"invitation": Array [ "invitation": Array [
Object { Object {
@ -131,7 +131,7 @@ Object {
} }
`; `;
exports[`Authentication API canary Blog setup update setup 6`] = ` exports[`Authentication API canary Password reset reset password 1`] = `
Object { Object {
"passwordreset": Array [ "passwordreset": Array [
Object { Object {
@ -141,7 +141,7 @@ Object {
} }
`; `;
exports[`Authentication API canary Blog setup update setup 7`] = ` exports[`Authentication API canary Password reset reset password 2`] = `
Object { Object {
"access-control-allow-origin": "http://127.0.0.1:2369", "access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0", "cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
@ -155,7 +155,7 @@ Object {
} }
`; `;
exports[`Authentication API canary Blog setup update setup 8`] = ` exports[`Authentication API canary Password reset reset password: expired token 1`] = `
Object { Object {
"errors": Array [ "errors": Array [
Object { Object {
@ -165,31 +165,7 @@ Object {
} }
`; `;
exports[`Authentication API canary Blog setup update setup 9`] = ` exports[`Authentication API canary Password reset reset password: expired token 2`] = `
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
"connection": "close",
"content-length": "314",
"content-type": "application/json; charset=utf-8",
"date": Any<String>,
"etag": Any<String>,
"vary": "Origin, Accept-Encoding",
"x-powered-by": "Express",
}
`;
exports[`Authentication API canary Blog setup update setup 10`] = `
Object {
"errors": Array [
Object {
"id": Any<String>,
},
],
}
`;
exports[`Authentication API canary Blog setup update setup 11`] = `
Object { Object {
"access-control-allow-origin": "http://127.0.0.1:2369", "access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0", "cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
@ -203,31 +179,7 @@ Object {
} }
`; `;
exports[`Authentication API canary Blog setup update setup 12`] = ` exports[`Authentication API canary Password reset reset password: generate reset token 1`] = `
Object {
"errors": Array [
Object {
"id": Any<String>,
},
],
}
`;
exports[`Authentication API canary Blog setup update setup 13`] = `
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
"connection": "close",
"content-length": "274",
"content-type": "application/json; charset=utf-8",
"date": Any<String>,
"etag": Any<String>,
"vary": "Origin, Accept-Encoding",
"x-powered-by": "Express",
}
`;
exports[`Authentication API canary Blog setup update setup 14`] = `
Object { Object {
"passwordreset": Array [ "passwordreset": Array [
Object { Object {
@ -237,7 +189,7 @@ Object {
} }
`; `;
exports[`Authentication API canary Blog setup update setup 15`] = ` exports[`Authentication API canary Password reset reset password: generate reset token 2`] = `
Object { Object {
"access-control-allow-origin": "http://127.0.0.1:2369", "access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0", "cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
@ -251,9 +203,57 @@ Object {
} }
`; `;
exports[`Authentication API canary Blog setup update setup 16`] = `Object {}`; exports[`Authentication API canary Password reset reset password: invalid token 1`] = `
Object {
"errors": Array [
Object {
"id": Any<String>,
},
],
}
`;
exports[`Authentication API canary Blog setup update setup 17`] = ` exports[`Authentication API canary Password reset reset password: invalid token 2`] = `
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
"connection": "close",
"content-length": "314",
"content-type": "application/json; charset=utf-8",
"date": Any<String>,
"etag": Any<String>,
"vary": "Origin, Accept-Encoding",
"x-powered-by": "Express",
}
`;
exports[`Authentication API canary Password reset reset password: unmatched token 1`] = `
Object {
"errors": Array [
Object {
"id": Any<String>,
},
],
}
`;
exports[`Authentication API canary Password reset reset password: unmatched token 2`] = `
Object {
"access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
"connection": "close",
"content-length": "274",
"content-type": "application/json; charset=utf-8",
"date": Any<String>,
"etag": Any<String>,
"vary": "Origin, Accept-Encoding",
"x-powered-by": "Express",
}
`;
exports[`Authentication API canary Reset all passwords reset all passwords returns 200 1`] = `Object {}`;
exports[`Authentication API canary Reset all passwords reset all passwords returns 200 2`] = `
Object { Object {
"access-control-allow-origin": "http://127.0.0.1:2369", "access-control-allow-origin": "http://127.0.0.1:2369",
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0", "cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",

View file

@ -1,24 +1,16 @@
const chai = require('chai');
const {expect} = require('chai'); const {expect} = require('chai');
const {any, stringMatching} = require('expect'); const {any, stringMatching} = require('expect');
const chaiJestSnapshot = require('@ethanresnick/chai-jest-snapshot');
const framework = require('../../../../utils/e2e-framework'); const framework = require('../../../../utils/e2e-framework');
const config = require('../../../../../core/shared/config'); const config = require('../../../../../core/shared/config');
chai.use(chaiJestSnapshot);
describe('Config API', function () { describe('Config API', function () {
let request; let request;
before(async function () { before(async function () {
chaiJestSnapshot.resetSnapshotRegistry();
request = await framework.getAgent('/ghost/api/canary/admin/'); request = await framework.getAgent('/ghost/api/canary/admin/');
}); });
beforeEach(function () {
chaiJestSnapshot.configureUsingMochaContext(this);
});
it('can retrieve config and all expected properties', async function () { it('can retrieve config and all expected properties', async function () {
const res = await request const res = await request
.get('site/') .get('site/')

14
test/utils/snapshots.js Normal file
View file

@ -0,0 +1,14 @@
const chai = require('chai');
const chaiJestSnapshot = require('@ethanresnick/chai-jest-snapshot');
chai.use(chaiJestSnapshot);
exports.mochaHooks = {
beforeAll() {
chaiJestSnapshot.resetSnapshotRegistry();
},
beforeEach() {
chaiJestSnapshot.configureUsingMochaContext(this);
}
};