angular2
Version:
Angular 2 - a web framework for modern web apps
244 lines • 26 kB
JavaScript
;/**
* Public Test Library for unit testing Angular2 Applications. Uses the
* Jasmine framework.
*/
var lang_1 = require('angular2/src/facade/lang');
var test_injector_1 = require('./test_injector');
var test_injector_2 = require('./test_injector');
exports.inject = test_injector_2.inject;
exports.injectAsync = test_injector_2.injectAsync;
var matchers_1 = require('./matchers');
exports.expect = matchers_1.expect;
var _global = (typeof window === 'undefined' ? lang_1.global : window);
/**
* Run a function (with an optional asynchronous callback) after each test case.
*
* See http://jasmine.github.io/ for more details.
*
* ## Example:
*
* {@example testing/ts/testing.ts region='afterEach'}
*/
exports.afterEach = _global.afterEach;
/**
* Group test cases together under a common description prefix.
*
* See http://jasmine.github.io/ for more details.
*
* ## Example:
*
* {@example testing/ts/testing.ts region='describeIt'}
*/
exports.describe = _global.describe;
/**
* See {@link fdescribe}.
*/
exports.ddescribe = _global.fdescribe;
/**
* Like {@link describe}, but instructs the test runner to only run
* the test cases in this group. This is useful for debugging.
*
* See http://jasmine.github.io/ for more details.
*
* ## Example:
*
* {@example testing/ts/testing.ts region='fdescribe'}
*/
exports.fdescribe = _global.fdescribe;
/**
* Like {@link describe}, but instructs the test runner to exclude
* this group of test cases from execution. This is useful for
* debugging, or for excluding broken tests until they can be fixed.
*
* See http://jasmine.github.io/ for more details.
*
* ## Example:
*
* {@example testing/ts/testing.ts region='xdescribe'}
*/
exports.xdescribe = _global.xdescribe;
var jsmBeforeEach = _global.beforeEach;
var jsmIt = _global.it;
var jsmIIt = _global.fit;
var jsmXIt = _global.xit;
var testInjector = test_injector_1.getTestInjector();
// Reset the test providers before each test.
jsmBeforeEach(function () { testInjector.reset(); });
/**
* Allows overriding default providers of the test injector,
* which are defined in test_injector.js.
*
* The given function must return a list of DI providers.
*
* ## Example:
*
* {@example testing/ts/testing.ts region='beforeEachProviders'}
*/
function beforeEachProviders(fn) {
jsmBeforeEach(function () {
var providers = fn();
if (!providers)
return;
try {
testInjector.addProviders(providers);
}
catch (e) {
throw new Error('beforeEachProviders was called after the injector had ' +
'been used in a beforeEach or it block. This invalidates the ' +
'test injector');
}
});
}
exports.beforeEachProviders = beforeEachProviders;
function _isPromiseLike(input) {
return input && !!(input.then);
}
function _it(jsmFn, name, testFn, testTimeOut) {
var timeOut = testTimeOut;
if (testFn instanceof test_injector_1.FunctionWithParamTokens) {
jsmFn(name, function (done) {
var returnedTestValue;
try {
returnedTestValue = testInjector.execute(testFn);
}
catch (err) {
done.fail(err);
return;
}
if (testFn.isAsync) {
if (_isPromiseLike(returnedTestValue)) {
returnedTestValue.then(function () { done(); }, function (err) { done.fail(err); });
}
else {
done.fail('Error: injectAsync was expected to return a promise, but the ' +
' returned value was: ' + returnedTestValue);
}
}
else {
if (!(returnedTestValue === undefined)) {
done.fail('Error: inject returned a value. Did you mean to use injectAsync? Returned ' +
'value was: ' + returnedTestValue);
}
done();
}
}, timeOut);
}
else {
// The test case doesn't use inject(). ie `it('test', (done) => { ... }));`
jsmFn(name, testFn, timeOut);
}
}
/**
* Wrapper around Jasmine beforeEach function.
*
* beforeEach may be used with the `inject` function to fetch dependencies.
* The test will automatically wait for any asynchronous calls inside the
* injected test function to complete.
*
* See http://jasmine.github.io/ for more details.
*
* ## Example:
*
* {@example testing/ts/testing.ts region='beforeEach'}
*/
function beforeEach(fn) {
if (fn instanceof test_injector_1.FunctionWithParamTokens) {
// The test case uses inject(). ie `beforeEach(inject([ClassA], (a) => { ...
// }));`
jsmBeforeEach(function (done) {
var returnedTestValue;
try {
returnedTestValue = testInjector.execute(fn);
}
catch (err) {
done.fail(err);
return;
}
if (fn.isAsync) {
if (_isPromiseLike(returnedTestValue)) {
returnedTestValue.then(function () { done(); }, function (err) { done.fail(err); });
}
else {
done.fail('Error: injectAsync was expected to return a promise, but the ' +
' returned value was: ' + returnedTestValue);
}
}
else {
if (!(returnedTestValue === undefined)) {
done.fail('Error: inject returned a value. Did you mean to use injectAsync? Returned ' +
'value was: ' + returnedTestValue);
}
done();
}
});
}
else {
// The test case doesn't use inject(). ie `beforeEach((done) => { ... }));`
if (fn.length === 0) {
jsmBeforeEach(function () { fn(); });
}
else {
jsmBeforeEach(function (done) { fn(done); });
}
}
}
exports.beforeEach = beforeEach;
/**
* Define a single test case with the given test name and execution function.
*
* The test function can be either a synchronous function, an asynchronous function
* that takes a completion callback, or an injected function created via {@link inject}
* or {@link injectAsync}. The test will automatically wait for any asynchronous calls
* inside the injected test function to complete.
*
* Wrapper around Jasmine it function. See http://jasmine.github.io/ for more details.
*
* ## Example:
*
* {@example testing/ts/testing.ts region='describeIt'}
*/
function it(name, fn, timeOut) {
if (timeOut === void 0) { timeOut = null; }
return _it(jsmIt, name, fn, timeOut);
}
exports.it = it;
/**
* Like {@link it}, but instructs the test runner to exclude this test
* entirely. Useful for debugging or for excluding broken tests until
* they can be fixed.
*
* Wrapper around Jasmine xit function. See http://jasmine.github.io/ for more details.
*
* ## Example:
*
* {@example testing/ts/testing.ts region='xit'}
*/
function xit(name, fn, timeOut) {
if (timeOut === void 0) { timeOut = null; }
return _it(jsmXIt, name, fn, timeOut);
}
exports.xit = xit;
/**
* See {@link fit}.
*/
function iit(name, fn, timeOut) {
if (timeOut === void 0) { timeOut = null; }
return _it(jsmIIt, name, fn, timeOut);
}
exports.iit = iit;
/**
* Like {@link it}, but instructs the test runner to only run this test.
* Useful for debugging.
*
* Wrapper around Jasmine fit function. See http://jasmine.github.io/ for more details.
*
* ## Example:
*
* {@example testing/ts/testing.ts region='fit'}
*/
function fit(name, fn, timeOut) {
if (timeOut === void 0) { timeOut = null; }
return _it(jsmIIt, name, fn, timeOut);
}
exports.fit = fit;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"testing.js","sourceRoot":"","sources":["angular2/src/testing/testing.ts"],"names":["beforeEachProviders","_isPromiseLike","_it","beforeEach","it","xit","iit","fit"],"mappings":"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CA;gBACDA,IAAIA,EAAEA,CAACA;YACTA,CAACA;QACHA,CAACA,EAAEA,OAAOA,CAACA,CAACA;IACdA,CAACA;IAACA,IAAIA,CAACA,CAACA;QACNA,2EAA2EA;QAC3EA,KAAKA,CAACA,IAAIA,EAAEA,MAAMA,EAAEA,OAAOA,CAACA,CAACA;IAC/BA,CAACA;AACHA,CAACA;AAED;;;;;;;;;;;;GAYG;AACH,oBAA2B,EAAuC;IAChEC,EAAEA,CAACA,CAACA,EAAEA,YAAYA,uCAAuBA,CAACA,CAACA,CAACA;QAC1CA,4EAA4EA;QAC5EA,QAAQA;QACRA,aAAaA,CAACA,UAACA,IAAIA;YAEjBA,IAAIA,iBAAiBA,CAACA;YACtBA,IAAIA,CAACA;gBACHA,iBAAiBA,GAAGA,YAAYA,CAACA,OAAOA,CAACA,EAAEA,CAACA,CAACA;YAC/CA,CAAEA;YAAAA,KAAKA,CAACA,CAACA,GAAGA,CAACA,CAACA,CAACA;gBACbA,IAAIA,CAACA,IAAIA,CAACA,GAAGA,CAACA,CAACA;gBACfA,MAAMA,CAACA;YACTA,CAACA;YACDA,EAAEA,CAACA,CAACA,EAAEA,CAACA,OAAOA,CAACA,CAACA,CAACA;gBACfA,EAAEA,CAACA,CAACA,cAAcA,CAACA,iBAAiBA,CAACA,CAACA,CAACA,CAACA;oBACvBA,iBAAkBA,CAACA,IAAIA,CAACA,cAAQA,IAAIA,EAAEA,CAACA,CAACA,CAACA,EAAEA,UAACA,GAAGA,IAAOA,IAAIA,CAACA,IAAIA,CAACA,GAAGA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;gBAC1FA,CAACA;gBAACA,IAAIA,CAACA,CAACA;oBACNA,IAAIA,CAACA,IAAIA,CAACA,+DAA+DA;wBAC/DA,uBAAuBA,GAAGA,iBAAiBA,CAACA,CAACA;gBACzDA,CAACA;YACHA,CAACA;YAACA,IAAIA,CAACA,CAACA;gBACNA,EAAEA,CAACA,CAACA,CAACA,CAACA,iBAAiBA,KAAKA,SAASA,CAACA,CAACA,CAACA,CAACA;oBACvCA,IAAIA,CAACA,IAAIA,CAACA,4EAA4EA;wBAC5EA,aAAaA,GAAGA,iBAAiBA,CAACA,CAACA;gBAC/CA,CAACA;gBACDA,IAAIA,EAAEA,CAACA;YACTA,CAACA;QACHA,CAACA,CAACA,CAACA;IACLA,CAACA;IAACA,IAAIA,CAACA,CAACA;QACNA,2EAA2EA;QAC3EA,EAAEA,CAACA,CAAOA,EAAGA,CAACA,MAAMA,KAAKA,CAACA,CAACA,CAACA,CAACA;YAC3BA,aAAaA,CAACA,cAAqBA,EAAGA,EAAEA,CAACA,CAACA,CAACA,CAACA,CAACA;QAC/CA,CAACA;QAACA,IAAIA,CAACA,CAACA;YACNA,aAAaA,CAACA,UAACA,IAAIA,IAAqBA,EAAGA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;QACxDA,CAACA;IACHA,CAACA;AACHA,CAACA;AApCe,kBAAU,aAoCzB,CAAA;AAED;;;;;;;;;;;;;GAaG;AACH,YAAmB,IAAY,EAAE,EAAuC,EACrD,OAAsB;IAAtBC,uBAAsBA,GAAtBA,cAAsBA;IACvCA,MAAMA,CAACA,GAAGA,CAACA,KAAKA,EAAEA,IAAIA,EAAEA,EAAEA,EAAEA,OAAOA,CAACA,CAACA;AACvCA,CAACA;AAHe,UAAE,KAGjB,CAAA;AAED;;;;;;;;;;GAUG;AACH,aAAoB,IAAY,EAAE,EAAuC,EACrD,OAAsB;IAAtBC,uBAAsBA,GAAtBA,cAAsBA;IACxCA,MAAMA,CAACA,GAAGA,CAACA,MAAMA,EAAEA,IAAIA,EAAEA,EAAEA,EAAEA,OAAOA,CAACA,CAACA;AACxCA,CAACA;AAHe,WAAG,MAGlB,CAAA;AAED;;GAEG;AACH,aAAoB,IAAY,EAAE,EAAuC,EACrD,OAAsB;IAAtBC,uBAAsBA,GAAtBA,cAAsBA;IACxCA,MAAMA,CAACA,GAAGA,CAACA,MAAMA,EAAEA,IAAIA,EAAEA,EAAEA,EAAEA,OAAOA,CAACA,CAACA;AACxCA,CAACA;AAHe,WAAG,MAGlB,CAAA;AAED;;;;;;;;;GASG;AACH,aAAoB,IAAY,EAAE,EAAuC,EACrD,OAAsB;IAAtBC,uBAAsBA,GAAtBA,cAAsBA;IACxCA,MAAMA,CAACA,GAAGA,CAACA,MAAMA,EAAEA,IAAIA,EAAEA,EAAEA,EAAEA,OAAOA,CAACA,CAACA;AACxCA,CAACA;AAHe,WAAG,MAGlB,CAAA","sourcesContent":["/**\n * Public Test Library for unit testing Angular2 Applications. Uses the\n * Jasmine framework.\n */\nimport {global} from 'angular2/src/facade/lang';\nimport {ListWrapper} from 'angular2/src/facade/collection';\nimport {bind} from 'angular2/core';\n\nimport {\n  FunctionWithParamTokens,\n  inject,\n  injectAsync,\n  TestInjector,\n  getTestInjector\n} from './test_injector';\n\nexport {inject, injectAsync} from './test_injector';\n\nexport {expect, NgMatchers} from './matchers';\n\nvar _global = <any>(typeof window === 'undefined' ? global : window);\n\n/**\n * Run a function (with an optional asynchronous callback) after each test case.\n *\n * See http://jasmine.github.io/ for more details.\n *\n * ## Example:\n *\n * {@example testing/ts/testing.ts region='afterEach'}\n */\nexport var afterEach: Function = _global.afterEach;\n\n/**\n * Group test cases together under a common description prefix.\n *\n * See http://jasmine.github.io/ for more details.\n *\n * ## Example:\n *\n * {@example testing/ts/testing.ts region='describeIt'}\n */\nexport var describe: Function = _global.describe;\n\n/**\n * See {@link fdescribe}.\n */\nexport var ddescribe: Function = _global.fdescribe;\n\n/**\n * Like {@link describe}, but instructs the test runner to only run\n * the test cases in this group. This is useful for debugging.\n *\n * See http://jasmine.github.io/ for more details.\n *\n * ## Example:\n *\n * {@example testing/ts/testing.ts region='fdescribe'}\n */\nexport var fdescribe: Function = _global.fdescribe;\n\n/**\n * Like {@link describe}, but instructs the test runner to exclude\n * this group of test cases from execution. This is useful for\n * debugging, or for excluding broken tests until they can be fixed.\n *\n * See http://jasmine.github.io/ for more details.\n *\n * ## Example:\n *\n * {@example testing/ts/testing.ts region='xdescribe'}\n */\nexport var xdescribe: Function = _global.xdescribe;\n\n/**\n * Signature for a synchronous test function (no arguments).\n */\nexport type SyncTestFn = () => void;\n\n/**\n * Signature for an asynchronous test function which takes a\n * `done` callback.\n */\nexport type AsyncTestFn = (done: () => void) => void;\n\n/**\n * Signature for any simple testing function.\n */\nexport type AnyTestFn = SyncTestFn | AsyncTestFn;\n\nvar jsmBeforeEach = _global.beforeEach;\nvar jsmIt = _global.it;\nvar jsmIIt = _global.fit;\nvar jsmXIt = _global.xit;\n\nvar testInjector: TestInjector = getTestInjector();\n\n// Reset the test providers before each test.\njsmBeforeEach(() => { testInjector.reset(); });\n\n/**\n * Allows overriding default providers of the test injector,\n * which are defined in test_injector.js.\n *\n * The given function must return a list of DI providers.\n *\n * ## Example:\n *\n * {@example testing/ts/testing.ts region='beforeEachProviders'}\n */\nexport function beforeEachProviders(fn): void {\n  jsmBeforeEach(() => {\n    var providers = fn();\n    if (!providers) return;\n    try {\n      testInjector.addProviders(providers);\n    } catch (e) {\n      throw new Error('beforeEachProviders was called after the injector had ' +\n                      'been used in a beforeEach or it block. This invalidates the ' +\n                      'test injector');\n    }\n  });\n}\n\nfunction _isPromiseLike(input): boolean {\n  return input && !!(input.then);\n}\n\nfunction _it(jsmFn: Function, name: string, testFn: FunctionWithParamTokens | AnyTestFn,\n             testTimeOut: number): void {\n  var timeOut = testTimeOut;\n\n  if (testFn instanceof FunctionWithParamTokens) {\n    jsmFn(name, (done) => {\n      var returnedTestValue;\n      try {\n        returnedTestValue = testInjector.execute(testFn);\n      } catch (err) {\n        done.fail(err);\n        return;\n      }\n\n      if (testFn.isAsync) {\n        if (_isPromiseLike(returnedTestValue)) {\n          (<Promise<any>>returnedTestValue).then(() => { done(); }, (err) => { done.fail(err); });\n        } else {\n          done.fail('Error: injectAsync was expected to return a promise, but the ' +\n                    ' returned value was: ' + returnedTestValue);\n        }\n      } else {\n        if (!(returnedTestValue === undefined)) {\n          done.fail('Error: inject returned a value. Did you mean to use injectAsync? Returned ' +\n                    'value was: ' + returnedTestValue);\n        }\n        done();\n      }\n    }, timeOut);\n  } else {\n    // The test case doesn't use inject(). ie `it('test', (done) => { ... }));`\n    jsmFn(name, testFn, timeOut);\n  }\n}\n\n/**\n * Wrapper around Jasmine beforeEach function.\n *\n * beforeEach may be used with the `inject` function to fetch dependencies.\n * The test will automatically wait for any asynchronous calls inside the\n * injected test function to complete.\n *\n * See http://jasmine.github.io/ for more details.\n *\n * ## Example:\n *\n * {@example testing/ts/testing.ts region='beforeEach'}\n */\nexport function beforeEach(fn: FunctionWithParamTokens | AnyTestFn): void {\n  if (fn instanceof FunctionWithParamTokens) {\n    // The test case uses inject(). ie `beforeEach(inject([ClassA], (a) => { ...\n    // }));`\n    jsmBeforeEach((done) => {\n\n      var returnedTestValue;\n      try {\n        returnedTestValue = testInjector.execute(fn);\n      } catch (err) {\n        done.fail(err);\n        return;\n      }\n      if (fn.isAsync) {\n        if (_isPromiseLike(returnedTestValue)) {\n          (<Promise<any>>returnedTestValue).then(() => { done(); }, (err) => { done.fail(err); });\n        } else {\n          done.fail('Error: injectAsync was expected to return a promise, but the ' +\n                    ' returned value was: ' + returnedTestValue);\n        }\n      } else {\n        if (!(returnedTestValue === undefined)) {\n          done.fail('Error: inject returned a value. Did you mean to use injectAsync? Returned ' +\n                    'value was: ' + returnedTestValue);\n        }\n        done();\n      }\n    });\n  } else {\n    // The test case doesn't use inject(). ie `beforeEach((done) => { ... }));`\n    if ((<any>fn).length === 0) {\n      jsmBeforeEach(() => { (<SyncTestFn>fn)(); });\n    } else {\n      jsmBeforeEach((done) => { (<AsyncTestFn>fn)(done); });\n    }\n  }\n}\n\n/**\n * Define a single test case with the given test name and execution function.\n *\n * The test function can be either a synchronous function, an asynchronous function\n * that takes a completion callback, or an injected function created via {@link inject}\n * or {@link injectAsync}. The test will automatically wait for any asynchronous calls\n * inside the injected test function to complete.\n *\n * Wrapper around Jasmine it function. See http://jasmine.github.io/ for more details.\n *\n * ## Example:\n *\n * {@example testing/ts/testing.ts region='describeIt'}\n */\nexport function it(name: string, fn: FunctionWithParamTokens | AnyTestFn,\n                   timeOut: number = null): void {\n  return _it(jsmIt, name, fn, timeOut);\n}\n\n/**\n * Like {@link it}, but instructs the test runner to exclude this test\n * entirely. Useful for debugging or for excluding broken tests until\n * they can be fixed.\n *\n * Wrapper around Jasmine xit function. See http://jasmine.github.io/ for more details.\n *\n * ## Example:\n *\n * {@example testing/ts/testing.ts region='xit'}\n */\nexport function xit(name: string, fn: FunctionWithParamTokens | AnyTestFn,\n                    timeOut: number = null): void {\n  return _it(jsmXIt, name, fn, timeOut);\n}\n\n/**\n * See {@link fit}.\n */\nexport function iit(name: string, fn: FunctionWithParamTokens | AnyTestFn,\n                    timeOut: number = null): void {\n  return _it(jsmIIt, name, fn, timeOut);\n}\n\n/**\n * Like {@link it}, but instructs the test runner to only run this test.\n * Useful for debugging.\n *\n * Wrapper around Jasmine fit function. See http://jasmine.github.io/ for more details.\n *\n * ## Example:\n *\n * {@example testing/ts/testing.ts region='fit'}\n */\nexport function fit(name: string, fn: FunctionWithParamTokens | AnyTestFn,\n                    timeOut: number = null): void {\n  return _it(jsmIIt, name, fn, timeOut);\n}\n"]}