DEV: Destroy application instance after each test (#14455)
Under Ember CLI, we create a new application instance for each test. We were not correctly destroying it after the test, causing many references to be maintaned (e.g. at the end of a test run, `Ember.Namespace.NAMESPACES` would have an entry for each application instance). Calling `destroy` on the application instance tidies up these references, and is one step towards fixing our test memory leak problem. Unfortunately there still seem to be other references being held to the application, so this commit is not a total fix.
This commit is contained in:
parent
9d5da2b383
commit
7fa2eb52f7
|
@ -31,6 +31,7 @@ import { flushMap } from "discourse/models/store";
|
||||||
import { registerObjects } from "discourse/pre-initializers/inject-discourse-objects";
|
import { registerObjects } from "discourse/pre-initializers/inject-discourse-objects";
|
||||||
import { setupApplicationTest } from "ember-qunit";
|
import { setupApplicationTest } from "ember-qunit";
|
||||||
import sinon from "sinon";
|
import sinon from "sinon";
|
||||||
|
import { run } from "@ember/runloop";
|
||||||
|
|
||||||
const Plugin = $.fn.modal;
|
const Plugin = $.fn.modal;
|
||||||
const Modal = Plugin.Constructor;
|
const Modal = Plugin.Constructor;
|
||||||
|
@ -63,6 +64,10 @@ let app;
|
||||||
let started = false;
|
let started = false;
|
||||||
|
|
||||||
function createApplication(config, settings) {
|
function createApplication(config, settings) {
|
||||||
|
if (app) {
|
||||||
|
run(app, "destroy");
|
||||||
|
}
|
||||||
|
|
||||||
app = Application.create(config);
|
app = Application.create(config);
|
||||||
setApplication(app);
|
setApplication(app);
|
||||||
setResolver(buildResolver("discourse").create({ namespace: app }));
|
setResolver(buildResolver("discourse").create({ namespace: app }));
|
||||||
|
|
Loading…
Reference in New Issue