Upgrade ember-qunit

This commit is contained in:
Robin Ward 2016-11-08 14:29:50 -05:00
parent 151597bf0f
commit 6a1c05a268
9 changed files with 341 additions and 75 deletions

View File

@ -1,4 +1,9 @@
import { mapRoutes } from 'discourse/mapping-router';
moduleFor("controller:poll-ui-builder", "controller:poll-ui-builder", { moduleFor("controller:poll-ui-builder", "controller:poll-ui-builder", {
setup() {
this.registry.register('router:main', mapRoutes());
},
needs: ['controller:modal'] needs: ['controller:modal']
}); });

View File

@ -1,6 +1,10 @@
import Badge from 'discourse/models/badge'; import Badge from 'discourse/models/badge';
import { mapRoutes } from 'discourse/mapping-router';
moduleFor('controller:admin-user-badges', { moduleFor('controller:admin-user-badges', {
setup() {
this.registry.register('router:main', mapRoutes());
},
needs: ['controller:adminUser'] needs: ['controller:adminUser']
}); });

View File

@ -4,21 +4,24 @@ import ApiKey from 'admin/models/api-key';
module("model:admin-user"); module("model:admin-user");
test('generate key', function() { test('generate key', function(assert) {
assert.expect(2);
var adminUser = AdminUser.create({id: 333}); var adminUser = AdminUser.create({id: 333});
blank(adminUser.get('api_key'), 'it has no api key by default'); assert.ok(!adminUser.get('api_key'), 'it has no api key by default');
adminUser.generateApiKey().then(function() { return adminUser.generateApiKey().then(function() {
present(adminUser.get('api_key'), 'it has an api_key now'); present(adminUser.get('api_key'), 'it has an api_key now');
}); });
}); });
test('revoke key', function() { test('revoke key', function(assert) {
assert.expect(2);
var apiKey = ApiKey.create({id: 1234, key: 'asdfasdf'}), var apiKey = ApiKey.create({id: 1234, key: 'asdfasdf'}),
adminUser = AdminUser.create({id: 333, api_key: apiKey}); adminUser = AdminUser.create({id: 333, api_key: apiKey});
equal(adminUser.get('api_key'), apiKey, 'it has the api key in the beginning'); assert.equal(adminUser.get('api_key'), apiKey, 'it has the api key in the beginning');
adminUser.revokeApiKey().then(function() { return adminUser.revokeApiKey().then(function() {
blank(adminUser.get('api_key'), 'it cleared the api_key'); blank(adminUser.get('api_key'), 'it cleared the api_key');
}); });
}); });

View File

@ -5,6 +5,7 @@ moduleForComponent('ace-editor', {integration: true});
componentTest('css editor', { componentTest('css editor', {
template: '{{ace-editor mode="css"}}', template: '{{ace-editor mode="css"}}',
test(assert) { test(assert) {
expect(1);
assert.ok(this.$('.ace_editor').length, 'it renders the ace editor'); assert.ok(this.$('.ace_editor').length, 'it renders the ace editor');
} }
}); });
@ -12,6 +13,7 @@ componentTest('css editor', {
componentTest('html editor', { componentTest('html editor', {
template: '{{ace-editor mode="html" content="<b>wat</b>"}}', template: '{{ace-editor mode="html" content="<b>wat</b>"}}',
test(assert) { test(assert) {
expect(1);
assert.ok(this.$('.ace_editor').length, 'it renders the ace editor'); assert.ok(this.$('.ace_editor').length, 'it renders the ace editor');
} }
}); });

View File

@ -1,4 +1,9 @@
import { mapRoutes } from 'discourse/mapping-router';
moduleFor("controller:avatar-selector", "controller:avatar-selector", { moduleFor("controller:avatar-selector", "controller:avatar-selector", {
setup() {
this.registry.register('router:main', mapRoutes());
},
needs: ['controller:modal'] needs: ['controller:modal']
}); });

View File

@ -1,4 +1,9 @@
import { mapRoutes } from 'discourse/mapping-router';
moduleFor("controller:create-account", "controller:create-account", { moduleFor("controller:create-account", "controller:create-account", {
setup() {
this.registry.register('router:main', mapRoutes());
},
needs: ['controller:modal', 'controller:login'] needs: ['controller:modal', 'controller:login']
}); });

View File

@ -1,5 +1,6 @@
import createStore from 'helpers/create-store'; import createStore from 'helpers/create-store';
import AdminUser from 'admin/models/admin-user'; import AdminUser from 'admin/models/admin-user';
import { mapRoutes } from 'discourse/mapping-router';
var buildPost = function(args) { var buildPost = function(args) {
return Discourse.Post.create(_.merge({ return Discourse.Post.create(_.merge({
@ -17,6 +18,9 @@ var buildAdminUser = function(args) {
}; };
moduleFor("controller:flag", "controller:flag", { moduleFor("controller:flag", "controller:flag", {
setup() {
this.registry.register('router:main', mapRoutes());
},
needs: ['controller:modal'] needs: ['controller:modal']
}); });
@ -97,4 +101,4 @@ test("canSendWarning notify_user selected", function(){
sandbox.stub(Discourse.User, 'currentProp').withArgs('staff').returns(true); sandbox.stub(Discourse.User, 'currentProp').withArgs('staff').returns(true);
var flagController = this.subject({ model: buildPost() }); var flagController = this.subject({ model: buildPost() });
canSendWarning(flagController, 'notify_user', true, 'true if current user is staff, selected is notify_user'); canSendWarning(flagController, 'notify_user', true, 'true if current user is staff, selected is notify_user');
}); });

View File

@ -1,8 +1,12 @@
import { blank, present } from 'helpers/qunit-helpers'; import { blank, present } from 'helpers/qunit-helpers';
import { mapRoutes } from 'discourse/mapping-router';
moduleFor('controller:topic', 'controller:topic', { moduleFor('controller:topic', 'controller:topic', {
needs: ['controller:modal', 'controller:composer', 'controller:quote-button', needs: ['controller:modal', 'controller:composer', 'controller:quote-button',
'controller:application'] 'controller:application'],
setup() {
this.registry.register('router:main', mapRoutes());
},
}); });
import Topic from 'discourse/models/topic'; import Topic from 'discourse/models/topic';

View File

@ -111,7 +111,7 @@ var define, requireModule, require, requirejs;
}; };
})(); })();
define('ember-qunit', ['exports', 'ember-qunit/module-for', 'ember-qunit/module-for-component', 'ember-qunit/module-for-model', 'ember-qunit/test', 'ember-test-helpers'], function (exports, moduleFor, moduleForComponent, moduleForModel, test, ember_test_helpers) { define('ember-qunit', ['exports', 'ember-qunit/module-for', 'ember-qunit/module-for-component', 'ember-qunit/module-for-model', 'ember-qunit/test', 'ember-qunit/only', 'ember-test-helpers'], function (exports, moduleFor, moduleForComponent, moduleForModel, test, only, ember_test_helpers) {
'use strict'; 'use strict';
@ -121,6 +121,7 @@ define('ember-qunit', ['exports', 'ember-qunit/module-for', 'ember-qunit/module-
exports.moduleForComponent = moduleForComponent['default']; exports.moduleForComponent = moduleForComponent['default'];
exports.moduleForModel = moduleForModel['default']; exports.moduleForModel = moduleForModel['default'];
exports.test = test['default']; exports.test = test['default'];
exports.only = only['default'];
exports.setResolver = ember_test_helpers.setResolver; exports.setResolver = ember_test_helpers.setResolver;
}); });
@ -153,6 +154,16 @@ define('ember-qunit/module-for', ['exports', 'ember-qunit/qunit-module', 'ember-
} }
exports['default'] = moduleFor; exports['default'] = moduleFor;
});
define('ember-qunit/only', ['exports', 'ember-qunit/test-wrapper', 'qunit'], function (exports, testWrapper, qunit) {
'use strict';
function only(testName, callback) {
testWrapper['default'](testName, callback, qunit.only);
}
exports['default'] = only;
}); });
define('ember-qunit/qunit-module', ['exports', 'qunit'], function (exports, qunit) { define('ember-qunit/qunit-module', ['exports', 'qunit'], function (exports, qunit) {
@ -165,7 +176,7 @@ define('ember-qunit/qunit-module', ['exports', 'qunit'], function (exports, quni
if (!callbacks) { return; } if (!callbacks) { return; }
var beforeEach; var beforeEach;
if (callbacks.setup) { if (callbacks.setup) {
beforeEach = callbacks.setup; beforeEach = callbacks.setup;
delete callbacks.setup; delete callbacks.setup;
@ -207,7 +218,7 @@ define('ember-qunit/qunit-module', ['exports', 'qunit'], function (exports, quni
qunit.module(module.name, { qunit.module(module.name, {
setup: function(assert) { setup: function(assert) {
var done = assert.async(); var done = assert.async();
module.setup().then(function() { return module.setup().then(function() {
if (beforeEach) { if (beforeEach) {
beforeEach.call(module.context, assert); beforeEach.call(module.context, assert);
} }
@ -219,26 +230,31 @@ define('ember-qunit/qunit-module', ['exports', 'qunit'], function (exports, quni
afterEach.call(module.context, assert); afterEach.call(module.context, assert);
} }
var done = assert.async(); var done = assert.async();
module.teardown()['finally'](done); return module.teardown()['finally'](done);
} }
}); });
} }
}); });
define('ember-qunit/test', ['exports', 'ember', 'ember-test-helpers', 'qunit'], function (exports, Ember, ember_test_helpers, qunit) { define('ember-qunit/test-wrapper', ['exports', 'ember', 'ember-test-helpers'], function (exports, Ember, ember_test_helpers) {
'use strict'; 'use strict';
function test(testName, callback) { function testWrapper(testName, callback, qunit) {
function wrapper(assert) { function wrapper() {
var context = ember_test_helpers.getContext(); var context = ember_test_helpers.getContext();
var result = callback.call(context, assert); var result = callback.apply(context, arguments);
function failTestOnPromiseRejection(reason) { function failTestOnPromiseRejection(reason) {
var message; var message;
if (reason instanceof Error) { if (reason instanceof Error) {
message = reason.stack; message = reason.stack;
if (reason.message && message.indexOf(reason.message) < 0) {
// PhantomJS has a `stack` that does not contain the actual
// exception message.
message = Ember['default'].inspect(reason) + "\n" + message;
}
} else { } else {
message = Ember['default'].inspect(reason); message = Ember['default'].inspect(reason);
} }
@ -251,7 +267,17 @@ define('ember-qunit/test', ['exports', 'ember', 'ember-test-helpers', 'qunit'],
}); });
} }
qunit.test(testName, wrapper); qunit(testName, wrapper);
}
exports['default'] = testWrapper;
});
define('ember-qunit/test', ['exports', 'ember-qunit/test-wrapper', 'qunit'], function (exports, testWrapper, qunit) {
'use strict';
function test(testName, callback) {
testWrapper['default'](testName, callback, qunit.test);
} }
exports['default'] = test; exports['default'] = test;
@ -270,7 +296,7 @@ define('ember-test-helpers', ['exports', 'ember', 'ember-test-helpers/test-modul
exports.setResolver = test_resolver.setResolver; exports.setResolver = test_resolver.setResolver;
}); });
define('ember-test-helpers/build-registry', ['exports'], function (exports) { define('ember-test-helpers/build-registry', ['exports', 'ember'], function (exports, Ember) {
'use strict'; 'use strict';
@ -290,9 +316,11 @@ define('ember-test-helpers/build-registry', ['exports'], function (exports) {
]; ];
function exposeRegistryMethod(container, method) { function exposeRegistryMethod(container, method) {
container[method] = function() { if (method in container) {
return container._registry[method].apply(container._registry, arguments); container[method] = function() {
}; return container._registry[method].apply(container._registry, arguments);
};
}
} }
for (var i = 0, l = methods.length; i < l; i++) { for (var i = 0, l = methods.length; i < l; i++) {
@ -300,9 +328,17 @@ define('ember-test-helpers/build-registry', ['exports'], function (exports) {
} }
} }
var Owner = (function() {
if (Ember['default']._RegistryProxyMixin && Ember['default']._ContainerProxyMixin) {
return Ember['default'].Object.extend(Ember['default']._RegistryProxyMixin, Ember['default']._ContainerProxyMixin);
}
return Ember['default'].Object.extend();
})();
exports['default'] = function(resolver) { exports['default'] = function(resolver) {
var registry, container; var fallbackRegistry, registry, container;
var namespace = Ember.Object.create({ var namespace = Ember['default'].Object.create({
Resolver: { create: function() { return resolver; } } Resolver: { create: function() { return resolver; } }
}); });
@ -314,22 +350,50 @@ define('ember-test-helpers/build-registry', ['exports'], function (exports) {
} }
} }
if (Ember.Application.buildRegistry) { if (Ember['default'].Application.buildRegistry) {
registry = Ember.Application.buildRegistry(namespace); fallbackRegistry = Ember['default'].Application.buildRegistry(namespace);
registry.register('component-lookup:main', Ember.ComponentLookup); fallbackRegistry.register('component-lookup:main', Ember['default'].ComponentLookup);
registry = new Ember['default'].Registry({
fallback: fallbackRegistry
});
// these properties are set on the fallback registry by `buildRegistry`
// and on the primary registry within the ApplicationInstance constructor
// but we need to manually recreate them since ApplicationInstance's are not
// exposed externally
registry.normalizeFullName = fallbackRegistry.normalizeFullName;
registry.makeToString = fallbackRegistry.makeToString;
registry.describe = fallbackRegistry.describe;
var owner = Owner.create({
__registry__: registry,
__container__: null
});
container = registry.container({ owner: owner });
owner.__container__ = container;
registry = registry;
container = registry.container();
exposeRegistryMethodsWithoutDeprecations(container); exposeRegistryMethodsWithoutDeprecations(container);
} else { } else {
container = Ember.Application.buildContainer(namespace); container = Ember['default'].Application.buildContainer(namespace);
container.register('component-lookup:main', Ember.ComponentLookup); container.register('component-lookup:main', Ember['default'].ComponentLookup);
} }
// Ember 1.10.0 did not properly add `view:toplevel` or `view:default` // Ember 1.10.0 did not properly add `view:toplevel` or `view:default`
// to the registry in Ember.Application.buildRegistry :( // to the registry in Ember.Application.buildRegistry :(
register('view:toplevel', Ember.View.extend()); //
register('view:default', Ember._MetamorphView); // Ember 2.0.0 removed Ember.View as public API, so only do this when
// Ember.View is present
if (Ember['default'].View) {
register('view:toplevel', Ember['default'].View.extend());
}
// Ember 2.0.0 removed Ember._MetamorphView from the Ember global, so only
// do this when present
if (Ember['default']._MetamorphView) {
register('view:default', Ember['default']._MetamorphView);
}
var globalContext = typeof global === 'object' && global || self; var globalContext = typeof global === 'object' && global || self;
if (globalContext.DS) { if (globalContext.DS) {
@ -354,9 +418,17 @@ define('ember-test-helpers/build-registry', ['exports'], function (exports) {
} }
}); });
define('ember-test-helpers/isolated-container', function () { define('ember-test-helpers/has-ember-version', ['exports', 'ember'], function (exports, Ember) {
'use strict'; 'use strict';
function hasEmberVersion(major, minor) {
var numbers = Ember['default'].VERSION.split('-')[0].split('.');
var actualMajor = parseInt(numbers[0], 10);
var actualMinor = parseInt(numbers[1], 10);
return actualMajor > major || (actualMajor === major && actualMinor >= minor);
}
exports['default'] = hasEmberVersion;
}); });
define('ember-test-helpers/test-context', ['exports'], function (exports) { define('ember-test-helpers/test-context', ['exports'], function (exports) {
@ -365,6 +437,7 @@ define('ember-test-helpers/test-context', ['exports'], function (exports) {
exports.setContext = setContext; exports.setContext = setContext;
exports.getContext = getContext; exports.getContext = getContext;
exports.unsetContext = unsetContext;
var __test_context__; var __test_context__;
@ -376,6 +449,10 @@ define('ember-test-helpers/test-context', ['exports'], function (exports) {
return __test_context__; return __test_context__;
} }
function unsetContext() {
__test_context__ = undefined;
}
}); });
define('ember-test-helpers/test-module-for-component', ['exports', 'ember-test-helpers/test-module', 'ember', 'ember-test-helpers/test-resolver'], function (exports, TestModule, Ember, test_resolver) { define('ember-test-helpers/test-module-for-component', ['exports', 'ember-test-helpers/test-module', 'ember', 'ember-test-helpers/test-resolver'], function (exports, TestModule, Ember, test_resolver) {
@ -398,7 +475,14 @@ define('ember-test-helpers/test-module-for-component', ['exports', 'ember-test-h
} else if (callbacks.integration) { } else if (callbacks.integration) {
this.isUnitTest = false; this.isUnitTest = false;
} else { } else {
Ember['default'].deprecate("the component:" + componentName + " test module is implicitly running in unit test mode, which will change to integration test mode by default in an upcoming version of ember-test-helpers. Add `unit: true` or a `needs:[]` list to explicitly opt in to unit test mode."); Ember['default'].deprecate(
"the component:" + componentName + " test module is implicitly running in unit test mode, " +
"which will change to integration test mode by default in an upcoming version of " +
"ember-test-helpers. Add `unit: true` or a `needs:[]` list to explicitly opt in to unit " +
"test mode.",
false,
{ id: 'ember-test-helpers.test-module-for-component.test-type', until: '0.6.0' }
);
this.isUnitTest = true; this.isUnitTest = true;
} }
@ -419,45 +503,67 @@ define('ember-test-helpers/test-module-for-component', ['exports', 'ember-test-h
throw new Error("component integration tests do not support `subject()`."); throw new Error("component integration tests do not support `subject()`.");
}; };
this.setupSteps.push(this.setupComponentIntegrationTest); this.setupSteps.push(this.setupComponentIntegrationTest);
this.teardownSteps.push(this.teardownComponent); this.teardownSteps.unshift(this.teardownComponent);
} }
if (Ember['default'].View && Ember['default'].View.views) {
this.setupSteps.push(this._aliasViewRegistry);
this.teardownSteps.unshift(this._resetViewRegistry);
}
},
_aliasViewRegistry: function() {
this._originalGlobalViewRegistry = Ember['default'].View.views;
var viewRegistry = this.container.lookup('-view-registry:main');
if (viewRegistry) {
Ember['default'].View.views = viewRegistry;
}
},
_resetViewRegistry: function() {
Ember['default'].View.views = this._originalGlobalViewRegistry;
}, },
setupComponentUnitTest: function() { setupComponentUnitTest: function() {
var _this = this; var _this = this;
var resolver = test_resolver.getResolver(); var resolver = test_resolver.getResolver();
var container = this.container;
var context = this.context; var context = this.context;
var layoutName = 'template:components/' + this.componentName; var layoutName = 'template:components/' + this.componentName;
var layout = resolver.resolve(layoutName); var layout = resolver.resolve(layoutName);
var thingToRegisterWith = this.registry || this.container;
if (layout) { if (layout) {
container.register(layoutName, layout); thingToRegisterWith.register(layoutName, layout);
container.injection(this.subjectName, 'layout', layoutName); thingToRegisterWith.injection(this.subjectName, 'layout', layoutName);
} }
context.dispatcher = Ember['default'].EventDispatcher.create(); context.dispatcher = this.container.lookup('event_dispatcher:main') || Ember['default'].EventDispatcher.create();
context.dispatcher.setup({}, '#ember-testing'); context.dispatcher.setup({}, '#ember-testing');
this.callbacks.render = function() { this.callbacks.render = function() {
var containerView = Ember['default'].ContainerView.create({container: container}); var subject;
Ember['default'].run(function(){ Ember['default'].run(function(){
var subject = context.subject(); subject = context.subject();
containerView.pushObject(subject); subject.appendTo('#ember-testing');
containerView.appendTo('#ember-testing');
}); });
_this.teardownSteps.unshift(function() { _this.teardownSteps.unshift(function() {
Ember['default'].run(function() { Ember['default'].run(function() {
Ember['default'].tryInvoke(containerView, 'destroy'); Ember['default'].tryInvoke(subject, 'destroy');
}); });
}); });
}; };
this.callbacks.append = function() { this.callbacks.append = function() {
Ember['default'].deprecate('this.append() is deprecated. Please use this.render() or this.$() instead.'); Ember['default'].deprecate(
'this.append() is deprecated. Please use this.render() or this.$() instead.',
false,
{ id: 'ember-test-helpers.test-module-for-component.append', until: '0.6.0' }
);
return context.$(); return context.$();
}; };
@ -472,10 +578,15 @@ define('ember-test-helpers/test-module-for-component', ['exports', 'ember-test-h
setupComponentIntegrationTest: function() { setupComponentIntegrationTest: function() {
var module = this; var module = this;
var context = this.context; var context = this.context;
context.dispatcher = Ember['default'].EventDispatcher.create();
context.dispatcher.setup({}, '#ember-testing');
this.actionHooks = {}; this.actionHooks = {};
context.dispatcher = this.container.lookup('event_dispatcher:main') || Ember['default'].EventDispatcher.create();
context.dispatcher.setup({}, '#ember-testing');
context.actions = module.actionHooks;
(this.registry || this.container).register('component:-test-holder', Ember['default'].Component.extend());
context.render = function(template) { context.render = function(template) {
if (!template) { if (!template) {
throw new Error("in a component integration test you must pass a template to `render()`"); throw new Error("in a component integration test you must pass a template to `render()`");
@ -486,12 +597,12 @@ define('ember-test-helpers/test-module-for-component', ['exports', 'ember-test-h
if (typeof template === 'string') { if (typeof template === 'string') {
template = Ember['default'].Handlebars.compile(template); template = Ember['default'].Handlebars.compile(template);
} }
module.component = Ember['default'].Component.create({ module.component = module.container.lookupFactory('component:-test-holder').create({
layout: template, layout: template
container: module.container
}); });
module.component.set('context' ,context); module.component.set('context' ,context);
module.component.set('controller', module); module.component.set('controller', context);
Ember['default'].run(function() { Ember['default'].run(function() {
module.component.appendTo('#ember-testing'); module.component.appendTo('#ember-testing');
@ -508,32 +619,47 @@ define('ember-test-helpers/test-module-for-component', ['exports', 'ember-test-h
}); });
}; };
context.setProperties = function(hash) {
Ember['default'].run(function() {
Ember['default'].setProperties(context, hash);
});
};
context.get = function(key) { context.get = function(key) {
return Ember['default'].get(context, key); return Ember['default'].get(context, key);
}; };
context.getProperties = function() {
var args = Array.prototype.slice.call(arguments);
return Ember['default'].getProperties(context, args);
};
context.on = function(actionName, handler) { context.on = function(actionName, handler) {
module.actionHooks[actionName] = handler; module.actionHooks[actionName] = handler;
}; };
context.send = function(actionName) {
var hook = module.actionHooks[actionName];
if (!hook) {
throw new Error("integration testing template received unexpected action " + actionName);
}
hook.apply(module, Array.prototype.slice.call(arguments, 1));
};
}, },
setupContext: function() { setupContext: function() {
this._super.call(this); this._super.call(this);
// only setup the injection if we are running against a version
// of Ember that has `-view-registry:main` (Ember >= 1.12)
if (this.container.lookupFactory('-view-registry:main')) {
(this.registry || this.container).injection('component', '_viewRegistry', '-view-registry:main');
}
if (!this.isUnitTest) { if (!this.isUnitTest) {
this.context.factory = function() {}; this.context.factory = function() {};
} }
}, },
send: function(actionName) {
var hook = this.actionHooks[actionName];
if (!hook) {
throw new Error("integration testing template received unexpected action " + actionName);
}
hook.apply(this, Array.prototype.slice.call(arguments, 1));
},
teardownComponent: function() { teardownComponent: function() {
var component = this.component; var component = this.component;
if (component) { if (component) {
@ -542,8 +668,6 @@ define('ember-test-helpers/test-module-for-component', ['exports', 'ember-test-h
}); });
} }
} }
}); });
}); });
@ -568,7 +692,10 @@ define('ember-test-helpers/test-module-for-model', ['exports', 'ember-test-helpe
var adapterFactory = container.lookupFactory('adapter:application'); var adapterFactory = container.lookupFactory('adapter:application');
if (!adapterFactory) { if (!adapterFactory) {
container.register('adapter:application', DS.FixtureAdapter); adapterFactory = DS.JSONAPIAdapter || DS.FixtureAdapter;
var thingToRegisterWith = this.registry || this.container;
thingToRegisterWith.register('adapter:application', adapterFactory);
} }
callbacks.store = function(){ callbacks.store = function(){
@ -591,7 +718,7 @@ define('ember-test-helpers/test-module-for-model', ['exports', 'ember-test-helpe
}); });
}); });
define('ember-test-helpers/test-module', ['exports', 'ember', 'ember-test-helpers/test-context', 'klassy', 'ember-test-helpers/test-resolver', 'ember-test-helpers/build-registry'], function (exports, Ember, test_context, klassy, test_resolver, buildRegistry) { define('ember-test-helpers/test-module', ['exports', 'ember', 'ember-test-helpers/test-context', 'klassy', 'ember-test-helpers/test-resolver', 'ember-test-helpers/build-registry', 'ember-test-helpers/has-ember-version', 'ember-test-helpers/wait'], function (exports, Ember, test_context, klassy, test_resolver, buildRegistry, hasEmberVersion, wait) {
'use strict'; 'use strict';
@ -609,6 +736,10 @@ define('ember-test-helpers/test-module', ['exports', 'ember', 'ember-test-helper
this.name = description || subjectName; this.name = description || subjectName;
this.callbacks = callbacks || {}; this.callbacks = callbacks || {};
if (this.callbacks.integration && this.callbacks.needs) {
throw new Error("cannot declare 'integration: true' and 'needs' in the same module");
}
if (this.callbacks.integration) { if (this.callbacks.integration) {
this.isIntegration = callbacks.integration; this.isIntegration = callbacks.integration;
delete callbacks.integration; delete callbacks.integration;
@ -644,6 +775,7 @@ define('ember-test-helpers/test-module', ['exports', 'ember', 'ember-test-helper
this.setupSteps.push(this.setupContainer); this.setupSteps.push(this.setupContainer);
this.setupSteps.push(this.setupContext); this.setupSteps.push(this.setupContext);
this.setupSteps.push(this.setupTestElements); this.setupSteps.push(this.setupTestElements);
this.setupSteps.push(this.setupAJAXListeners);
if (this.callbacks.setup) { if (this.callbacks.setup) {
this.contextualizedSetupSteps.push( this.callbacks.setup ); this.contextualizedSetupSteps.push( this.callbacks.setup );
@ -664,6 +796,7 @@ define('ember-test-helpers/test-module', ['exports', 'ember', 'ember-test-helper
this.teardownSteps.push(this.teardownContainer); this.teardownSteps.push(this.teardownContainer);
this.teardownSteps.push(this.teardownContext); this.teardownSteps.push(this.teardownContext);
this.teardownSteps.push(this.teardownTestElements); this.teardownSteps.push(this.teardownTestElements);
this.teardownSteps.push(this.teardownAJAXListeners);
if (this.callbacks.afterTeardown) { if (this.callbacks.afterTeardown) {
this.teardownSteps.push( this.callbacks.afterTeardown ); this.teardownSteps.push( this.callbacks.afterTeardown );
@ -729,10 +862,29 @@ define('ember-test-helpers/test-module', ['exports', 'ember', 'ember-test-helper
container: this.container, container: this.container,
registry: this.registry, registry: this.registry,
factory: factory, factory: factory,
dispatcher: null dispatcher: null,
register: function() {
var target = this.registry || this.container;
return target.register.apply(target, arguments);
},
inject: {}
}); });
this.context = test_context.getContext(); var context = this.context = test_context.getContext();
if (Ember['default'].setOwner) {
Ember['default'].setOwner(context, this.container.owner);
}
if (Ember['default'].inject) {
var keys = (Object.keys || Ember['default'].keys)(Ember['default'].inject);
keys.forEach(function(typeName) {
context.inject[typeName] = function(name, opts) {
var alias = (opts && opts.as) || name;
Ember['default'].set(context, alias, context.container.lookup(typeName + ':' + name));
};
});
}
}, },
setupTestElements: function() { setupTestElements: function() {
@ -741,6 +893,10 @@ define('ember-test-helpers/test-module', ['exports', 'ember', 'ember-test-helper
} }
}, },
setupAJAXListeners: function() {
wait._setupAJAXHooks();
},
teardownSubject: function() { teardownSubject: function() {
var subject = this.cache.subject; var subject = this.cache.subject;
@ -760,7 +916,10 @@ define('ember-test-helpers/test-module', ['exports', 'ember', 'ember-test-helper
teardownContext: function() { teardownContext: function() {
var context = this.context; var context = this.context;
if (context.dispatcher) { this.context = undefined;
test_context.unsetContext();
if (context.dispatcher && !context.dispatcher.isDestroyed) {
Ember['default'].run(function() { Ember['default'].run(function() {
context.dispatcher.destroy(); context.dispatcher.destroy();
}); });
@ -769,7 +928,16 @@ define('ember-test-helpers/test-module', ['exports', 'ember', 'ember-test-helper
teardownTestElements: function() { teardownTestElements: function() {
Ember['default'].$('#ember-testing').empty(); Ember['default'].$('#ember-testing').empty();
Ember['default'].View.views = {};
// Ember 2.0.0 removed Ember.View as public API, so only do this when
// Ember.View is present
if (Ember['default'].View && Ember['default'].View.views) {
Ember['default'].View.views = {};
}
},
teardownAJAXListeners: function() {
wait._teardownAJAXHooks();
}, },
defaultSubject: function(options, factory) { defaultSubject: function(options, factory) {
@ -813,10 +981,12 @@ define('ember-test-helpers/test-module', ['exports', 'ember', 'ember-test-helper
this.container = items.container; this.container = items.container;
this.registry = items.registry; this.registry = items.registry;
var thingToRegisterWith = this.registry || this.container; if (hasEmberVersion['default'](1, 13)) {
var router = resolver.resolve('router:main'); var thingToRegisterWith = this.registry || this.container;
router = router || Ember['default'].Router.extend(); var router = resolver.resolve('router:main');
thingToRegisterWith.register('router:main', router); router = router || Ember['default'].Router.extend();
thingToRegisterWith.register('router:main', router);
}
}, },
_setupIsolatedContainer: function() { _setupIsolatedContainer: function() {
@ -831,7 +1001,11 @@ define('ember-test-helpers/test-module', ['exports', 'ember', 'ember-test-helper
thingToRegisterWith.register(fullName, resolver.resolve(normalizedFullName)); thingToRegisterWith.register(fullName, resolver.resolve(normalizedFullName));
} }
thingToRegisterWith.resolver = function() { }; if (this.registry) {
this.registry.fallback.resolver = function() {};
} else {
this.container.resolver = function() {};
}
}, },
_setupIntegratedContainer: function() { _setupIntegratedContainer: function() {
@ -859,6 +1033,64 @@ define('ember-test-helpers/test-resolver', ['exports'], function (exports) {
return __resolver__; return __resolver__;
} }
});
define('ember-test-helpers/wait', ['exports', 'ember'], function (exports, Ember) {
'use strict';
exports._teardownAJAXHooks = _teardownAJAXHooks;
exports._setupAJAXHooks = _setupAJAXHooks;
var requests;
function incrementAjaxPendingRequests(_, xhr) {
requests.push(xhr);
}
function decrementAjaxPendingRequests(_, xhr) {
for (var i = 0;i < requests.length;i++) {
if (xhr === requests[i]) {
requests.splice(i, 1);
}
}
}
function _teardownAJAXHooks() {
jQuery(document).off('ajaxSend', incrementAjaxPendingRequests);
jQuery(document).off('ajaxComplete', decrementAjaxPendingRequests);
}
function _setupAJAXHooks() {
requests = [];
jQuery(document).on('ajaxSend', incrementAjaxPendingRequests);
jQuery(document).on('ajaxComplete', decrementAjaxPendingRequests);
}
function wait(_options) {
var options = _options || {};
var waitForTimers = options.hasOwnProperty('waitForTimers') ? options.waitForTimers : true;
var waitForAJAX = options.hasOwnProperty('waitForAJAX') ? options.waitForAJAX : true;
return new Ember['default'].RSVP.Promise(function(resolve) {
var watcher = self.setInterval(function() {
if (waitForTimers && (Ember['default'].run.hasScheduledTimers() || Ember['default'].run.currentRunLoop)) {
return;
}
if (waitForAJAX && requests && requests.length > 0) {
return;
}
// Stop polling
self.clearInterval(watcher);
// Synchronously resolve the promise
Ember['default'].run(null, resolve);
}, 10);
});
}
exports['default'] = wait;
}); });
define('klassy', ['exports'], function (exports) { define('klassy', ['exports'], function (exports) {
@ -1022,12 +1254,14 @@ define('qunit', ['exports'], function (exports) {
var module = QUnit.module; var module = QUnit.module;
var test = QUnit.test; var test = QUnit.test;
var skip = QUnit.skip; var skip = QUnit.skip;
var only = QUnit.only;
exports['default'] = QUnit; exports['default'] = QUnit;
exports.module = module; exports.module = module;
exports.test = test; exports.test = test;
exports.skip = skip; exports.skip = skip;
exports.only = only;
}); });
define("ember", ["exports"], function(__exports__) { define("ember", ["exports"], function(__exports__) {