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:
parent
0fbec65a6e
commit
5a150cc3b6
5 changed files with 85 additions and 83 deletions
|
@ -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",
|
||||||
|
|
|
@ -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();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -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",
|
||||||
|
|
|
@ -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
14
test/utils/snapshots.js
Normal 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);
|
||||||
|
}
|
||||||
|
};
|
Loading…
Add table
Reference in a new issue