DEV: This ensures that teardowns are executed if initializers are run
It does this by creating a new initializer that runs every time the app is booted to track the current test. Then after each test, we see if the app needs to be torn down.
This commit is contained in:
parent
688be607c9
commit
224f0a2655
|
@ -64,6 +64,16 @@ export function currentUser() {
|
||||||
return User.create(sessionFixtures["/session/current.json"].current_user);
|
return User.create(sessionFixtures["/session/current.json"].current_user);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let _initialized = new Set();
|
||||||
|
|
||||||
|
export function testsInitialized() {
|
||||||
|
_initialized.add(QUnit.config.current.testId);
|
||||||
|
}
|
||||||
|
|
||||||
|
export function testsTornDown() {
|
||||||
|
_initialized.delete(QUnit.config.current.testId);
|
||||||
|
}
|
||||||
|
|
||||||
export function updateCurrentUser(properties) {
|
export function updateCurrentUser(properties) {
|
||||||
run(() => {
|
run(() => {
|
||||||
User.current().setProperties(properties);
|
User.current().setProperties(properties);
|
||||||
|
@ -118,7 +128,20 @@ export function applyPretender(name, server, helper) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add clean up code here to run after every test
|
// Add clean up code here to run after every test
|
||||||
function testCleanup() {
|
function testCleanup(container, app) {
|
||||||
|
if (_initialized.has(QUnit.config.current.testId)) {
|
||||||
|
if (!app) {
|
||||||
|
app = getApplication();
|
||||||
|
}
|
||||||
|
app._runInitializer("instanceInitializers", (_, initializer) => {
|
||||||
|
initializer.teardown?.();
|
||||||
|
});
|
||||||
|
|
||||||
|
app._runInitializer("initializers", (_, initializer) => {
|
||||||
|
initializer.teardown?.(container);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
flushMap();
|
flushMap();
|
||||||
localStorage.clear();
|
localStorage.clear();
|
||||||
User.resetCurrent();
|
User.resetCurrent();
|
||||||
|
@ -171,9 +194,7 @@ export function discourseModule(name, options) {
|
||||||
this.siteSettings = currentSettings();
|
this.siteSettings = currentSettings();
|
||||||
clearResolverOptions();
|
clearResolverOptions();
|
||||||
});
|
});
|
||||||
hooks.afterEach(function () {
|
hooks.afterEach(() => testCleanup(this.container));
|
||||||
testCleanup();
|
|
||||||
});
|
|
||||||
|
|
||||||
this.getController = function (controllerName, properties) {
|
this.getController = function (controllerName, properties) {
|
||||||
let controller = this.container.lookup(`controller:${controllerName}`);
|
let controller = this.container.lookup(`controller:${controllerName}`);
|
||||||
|
@ -199,15 +220,11 @@ export function discourseModule(name, options) {
|
||||||
beforeEach() {
|
beforeEach() {
|
||||||
this.container = getOwner(this);
|
this.container = getOwner(this);
|
||||||
this.siteSettings = currentSettings();
|
this.siteSettings = currentSettings();
|
||||||
if (options && options.beforeEach) {
|
options?.beforeEach?.call(this);
|
||||||
options.beforeEach.call(this);
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
afterEach() {
|
afterEach() {
|
||||||
if (options && options.afterEach) {
|
options?.afterEach?.call(this);
|
||||||
options.afterEach.call(this);
|
testCleanup(this.container);
|
||||||
}
|
|
||||||
testCleanup();
|
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -295,18 +312,8 @@ export function acceptance(name, optionsOrCallback) {
|
||||||
afterEach() {
|
afterEach() {
|
||||||
resetMobile();
|
resetMobile();
|
||||||
let app = getApplication();
|
let app = getApplication();
|
||||||
if (options && options.afterEach) {
|
options?.afterEach?.call(this);
|
||||||
options.afterEach.call(this);
|
testCleanup(this.container, app);
|
||||||
}
|
|
||||||
testCleanup();
|
|
||||||
|
|
||||||
app._runInitializer("instanceInitializers", (_, initializer) => {
|
|
||||||
initializer.teardown?.();
|
|
||||||
});
|
|
||||||
|
|
||||||
app._runInitializer("initializers", (_, initializer) => {
|
|
||||||
initializer.teardown?.(this.container);
|
|
||||||
});
|
|
||||||
|
|
||||||
if (LEGACY_ENV) {
|
if (LEGACY_ENV) {
|
||||||
app.__registeredObjects__ = false;
|
app.__registeredObjects__ = false;
|
||||||
|
|
|
@ -2,6 +2,8 @@ import {
|
||||||
applyPretender,
|
applyPretender,
|
||||||
exists,
|
exists,
|
||||||
resetSite,
|
resetSite,
|
||||||
|
testsInitialized,
|
||||||
|
testsTornDown,
|
||||||
} from "discourse/tests/helpers/qunit-helpers";
|
} from "discourse/tests/helpers/qunit-helpers";
|
||||||
import pretender, {
|
import pretender, {
|
||||||
applyDefaultHandlers,
|
applyDefaultHandlers,
|
||||||
|
@ -98,6 +100,12 @@ function createApplication(config, settings) {
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!started) {
|
if (!started) {
|
||||||
|
app.instanceInitializer({
|
||||||
|
name: "test-helper",
|
||||||
|
initialize: testsInitialized,
|
||||||
|
teardown: testsTornDown,
|
||||||
|
});
|
||||||
|
|
||||||
app.start();
|
app.start();
|
||||||
started = true;
|
started = true;
|
||||||
}
|
}
|
||||||
|
@ -407,6 +415,11 @@ export function setupTestsLegacy(application) {
|
||||||
setResolver(buildResolver("discourse").create({ namespace: app }));
|
setResolver(buildResolver("discourse").create({ namespace: app }));
|
||||||
setupTestsCommon(application, app.__container__);
|
setupTestsCommon(application, app.__container__);
|
||||||
|
|
||||||
|
app.instanceInitializer({
|
||||||
|
name: "test-helper",
|
||||||
|
initialize: testsInitialized,
|
||||||
|
teardown: testsTornDown,
|
||||||
|
});
|
||||||
app.SiteSettings = currentSettings();
|
app.SiteSettings = currentSettings();
|
||||||
app.start();
|
app.start();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue