1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
/**
* @license
* Copyright Google Inc. All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
/// <reference types="jasmine"/>
'use strict';
Zone.__load_patch('jasmine', function (global, Zone, api) {
var __extends = function (d, b) {
for (var p in b)
if (b.hasOwnProperty(p))
d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : ((__.prototype = b.prototype), new __());
};
// Patch jasmine's describe/it/beforeEach/afterEach functions so test code always runs
// in a testZone (ProxyZone). (See: angular/zone.js#91 & angular/angular#10503)
if (!Zone)
throw new Error('Missing: zone.js');
if (typeof jest !== 'undefined') {
// return if jasmine is a light implementation inside jest
// in this case, we are running inside jest not jasmine
return;
}
if (typeof jasmine == 'undefined' || jasmine['__zone_patch__']) {
return;
}
jasmine['__zone_patch__'] = true;
var SyncTestZoneSpec = Zone['SyncTestZoneSpec'];
var ProxyZoneSpec = Zone['ProxyZoneSpec'];
if (!SyncTestZoneSpec)
throw new Error('Missing: SyncTestZoneSpec');
if (!ProxyZoneSpec)
throw new Error('Missing: ProxyZoneSpec');
var ambientZone = Zone.current;
// Create a synchronous-only zone in which to run `describe` blocks in order to raise an
// error if any asynchronous operations are attempted inside of a `describe` but outside of
// a `beforeEach` or `it`.
var syncZone = ambientZone.fork(new SyncTestZoneSpec('jasmine.describe'));
var symbol = Zone.__symbol__;
// whether patch jasmine clock when in fakeAsync
var disablePatchingJasmineClock = global[symbol('fakeAsyncDisablePatchingClock')] === true;
// the original variable name fakeAsyncPatchLock is not accurate, so the name will be
// fakeAsyncAutoFakeAsyncWhenClockPatched and if this enablePatchingJasmineClock is false, we also
// automatically disable the auto jump into fakeAsync feature
var enableAutoFakeAsyncWhenClockPatched = !disablePatchingJasmineClock &&
((global[symbol('fakeAsyncPatchLock')] === true) ||
(global[symbol('fakeAsyncAutoFakeAsyncWhenClockPatched')] === true));
var ignoreUnhandledRejection = global[symbol('ignoreUnhandledRejection')] === true;
if (!ignoreUnhandledRejection) {
var globalErrors_1 = jasmine.GlobalErrors;
if (globalErrors_1 && !jasmine[symbol('GlobalErrors')]) {
jasmine[symbol('GlobalErrors')] = globalErrors_1;
jasmine.GlobalErrors = function () {
var instance = new globalErrors_1();
var originalInstall = instance.install;
if (originalInstall && !instance[symbol('install')]) {
instance[symbol('install')] = originalInstall;
instance.install = function () {
var originalHandlers = process.listeners('unhandledRejection');
var r = originalInstall.apply(this, arguments);
process.removeAllListeners('unhandledRejection');
if (originalHandlers) {
originalHandlers.forEach(function (h) { return process.on('unhandledRejection', h); });
}
return r;
};
}
return instance;
};
}
}
// Monkey patch all of the jasmine DSL so that each function runs in appropriate zone.
var jasmineEnv = jasmine.getEnv();
['describe', 'xdescribe', 'fdescribe'].forEach(function (methodName) {
var originalJasmineFn = jasmineEnv[methodName];
jasmineEnv[methodName] = function (description, specDefinitions) {
return originalJasmineFn.call(this, description, wrapDescribeInZone(specDefinitions));
};
});
['it', 'xit', 'fit'].forEach(function (methodName) {
var originalJasmineFn = jasmineEnv[methodName];
jasmineEnv[symbol(methodName)] = originalJasmineFn;
jasmineEnv[methodName] = function (description, specDefinitions, timeout) {
arguments[1] = wrapTestInZone(specDefinitions);
return originalJasmineFn.apply(this, arguments);
};
});
['beforeEach', 'afterEach', 'beforeAll', 'afterAll'].forEach(function (methodName) {
var originalJasmineFn = jasmineEnv[methodName];
jasmineEnv[symbol(methodName)] = originalJasmineFn;
jasmineEnv[methodName] = function (specDefinitions, timeout) {
arguments[0] = wrapTestInZone(specDefinitions);
return originalJasmineFn.apply(this, arguments);
};
});
if (!disablePatchingJasmineClock) {
// need to patch jasmine.clock().mockDate and jasmine.clock().tick() so
// they can work properly in FakeAsyncTest
var originalClockFn_1 = (jasmine[symbol('clock')] = jasmine['clock']);
jasmine['clock'] = function () {
var clock = originalClockFn_1.apply(this, arguments);
if (!clock[symbol('patched')]) {
clock[symbol('patched')] = symbol('patched');
var originalTick_1 = (clock[symbol('tick')] = clock.tick);
clock.tick = function () {
var fakeAsyncZoneSpec = Zone.current.get('FakeAsyncTestZoneSpec');
if (fakeAsyncZoneSpec) {
return fakeAsyncZoneSpec.tick.apply(fakeAsyncZoneSpec, arguments);
}
return originalTick_1.apply(this, arguments);
};
var originalMockDate_1 = (clock[symbol('mockDate')] = clock.mockDate);
clock.mockDate = function () {
var fakeAsyncZoneSpec = Zone.current.get('FakeAsyncTestZoneSpec');
if (fakeAsyncZoneSpec) {
var dateTime = arguments.length > 0 ? arguments[0] : new Date();
return fakeAsyncZoneSpec.setCurrentRealTime.apply(fakeAsyncZoneSpec, dateTime && typeof dateTime.getTime === 'function' ?
[dateTime.getTime()] :
arguments);
}
return originalMockDate_1.apply(this, arguments);
};
// for auto go into fakeAsync feature, we need the flag to enable it
if (enableAutoFakeAsyncWhenClockPatched) {
['install', 'uninstall'].forEach(function (methodName) {
var originalClockFn = (clock[symbol(methodName)] = clock[methodName]);
clock[methodName] = function () {
var FakeAsyncTestZoneSpec = Zone['FakeAsyncTestZoneSpec'];
if (FakeAsyncTestZoneSpec) {
jasmine[symbol('clockInstalled')] = 'install' === methodName;
return;
}
return originalClockFn.apply(this, arguments);
};
});
}
}
return clock;
};
}
/**
* Gets a function wrapping the body of a Jasmine `describe` block to execute in a
* synchronous-only zone.
*/
function wrapDescribeInZone(describeBody) {
return function () {
return syncZone.run(describeBody, this, arguments);
};
}
function runInTestZone(testBody, applyThis, queueRunner, done) {
var isClockInstalled = !!jasmine[symbol('clockInstalled')];
var testProxyZoneSpec = queueRunner.testProxyZoneSpec;
var testProxyZone = queueRunner.testProxyZone;
var lastDelegate;
if (isClockInstalled && enableAutoFakeAsyncWhenClockPatched) {
// auto run a fakeAsync
var fakeAsyncModule = Zone[Zone.__symbol__('fakeAsyncTest')];
if (fakeAsyncModule && typeof fakeAsyncModule.fakeAsync === 'function') {
testBody = fakeAsyncModule.fakeAsync(testBody);
}
}
if (done) {
return testProxyZone.run(testBody, applyThis, [done]);
}
else {
return testProxyZone.run(testBody, applyThis);
}
}
/**
* Gets a function wrapping the body of a Jasmine `it/beforeEach/afterEach` block to
* execute in a ProxyZone zone.
* This will run in `testProxyZone`. The `testProxyZone` will be reset by the `ZoneQueueRunner`
*/
function wrapTestInZone(testBody) {
// The `done` callback is only passed through if the function expects at least one argument.
// Note we have to make a function with correct number of arguments, otherwise jasmine will
// think that all functions are sync or async.
return (testBody && (testBody.length ? function (done) {
return runInTestZone(testBody, this, this.queueRunner, done);
} : function () {
return runInTestZone(testBody, this, this.queueRunner);
}));
}
var QueueRunner = jasmine.QueueRunner;
jasmine.QueueRunner = (function (_super) {
__extends(ZoneQueueRunner, _super);
function ZoneQueueRunner(attrs) {
var _this = this;
if (attrs.onComplete) {
attrs.onComplete = (function (fn) { return function () {
// All functions are done, clear the test zone.
_this.testProxyZone = null;
_this.testProxyZoneSpec = null;
ambientZone.scheduleMicroTask('jasmine.onComplete', fn);
}; })(attrs.onComplete);
}
var nativeSetTimeout = global[Zone.__symbol__('setTimeout')];
var nativeClearTimeout = global[Zone.__symbol__('clearTimeout')];
if (nativeSetTimeout) {
// should run setTimeout inside jasmine outside of zone
attrs.timeout = {
setTimeout: nativeSetTimeout ? nativeSetTimeout : global.setTimeout,
clearTimeout: nativeClearTimeout ? nativeClearTimeout : global.clearTimeout
};
}
// create a userContext to hold the queueRunner itself
// so we can access the testProxy in it/xit/beforeEach ...
if (jasmine.UserContext) {
if (!attrs.userContext) {
attrs.userContext = new jasmine.UserContext();
}
attrs.userContext.queueRunner = this;
}
else {
if (!attrs.userContext) {
attrs.userContext = {};
}
attrs.userContext.queueRunner = this;
}
// patch attrs.onException
var onException = attrs.onException;
attrs.onException = function (error) {
if (error &&
error.message ===
'Timeout - Async callback was not invoked within timeout specified by jasmine.DEFAULT_TIMEOUT_INTERVAL.') {
// jasmine timeout, we can make the error message more
// reasonable to tell what tasks are pending
var proxyZoneSpec = this && this.testProxyZoneSpec;
if (proxyZoneSpec) {
var pendingTasksInfo = proxyZoneSpec.getAndClearPendingTasksInfo();
try {
// try catch here in case error.message is not writable
error.message += pendingTasksInfo;
}
catch (err) {
}
}
}
if (onException) {
onException.call(this, error);
}
};
_super.call(this, attrs);
}
ZoneQueueRunner.prototype.execute = function () {
var _this = this;
var zone = Zone.current;
var isChildOfAmbientZone = false;
while (zone) {
if (zone === ambientZone) {
isChildOfAmbientZone = true;
break;
}
zone = zone.parent;
}
if (!isChildOfAmbientZone)
throw new Error('Unexpected Zone: ' + Zone.current.name);
// This is the zone which will be used for running individual tests.
// It will be a proxy zone, so that the tests function can retroactively install
// different zones.
// Example:
// - In beforeEach() do childZone = Zone.current.fork(...);
// - In it() try to do fakeAsync(). The issue is that because the beforeEach forked the
// zone outside of fakeAsync it will be able to escape the fakeAsync rules.
// - Because ProxyZone is parent fo `childZone` fakeAsync can retroactively add
// fakeAsync behavior to the childZone.
this.testProxyZoneSpec = new ProxyZoneSpec();
this.testProxyZone = ambientZone.fork(this.testProxyZoneSpec);
if (!Zone.currentTask) {
// if we are not running in a task then if someone would register a
// element.addEventListener and then calling element.click() the
// addEventListener callback would think that it is the top most task and would
// drain the microtask queue on element.click() which would be incorrect.
// For this reason we always force a task when running jasmine tests.
Zone.current.scheduleMicroTask('jasmine.execute().forceTask', function () { return QueueRunner.prototype.execute.call(_this); });
}
else {
_super.prototype.execute.call(this);
}
};
return ZoneQueueRunner;
})(QueueRunner);
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"jasmine.js","sourceRoot":"","sources":["../../../../../../../packages/zone.js/lib/jasmine/jasmine.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/// <reference types=\"jasmine\"/>\n\n'use strict';\ndeclare let jest: any;\nZone.__load_patch('jasmine', (global: any, Zone: ZoneType, api: _ZonePrivate) => {\n  const __extends = function(d: any, b: any) {\n    for (const p in b)\n      if (b.hasOwnProperty(p)) d[p] = b[p];\n    function __(this: Object) { this.constructor = d; }\n    d.prototype = b === null ? Object.create(b) : ((__.prototype = b.prototype), new (__ as any)());\n  };\n  // Patch jasmine's describe/it/beforeEach/afterEach functions so test code always runs\n  // in a testZone (ProxyZone). (See: angular/zone.js#91 & angular/angular#10503)\n  if (!Zone) throw new Error('Missing: zone.js');\n  if (typeof jest !== 'undefined') {\n    // return if jasmine is a light implementation inside jest\n    // in this case, we are running inside jest not jasmine\n    return;\n  }\n  if (typeof jasmine == 'undefined' || (jasmine as any)['__zone_patch__']) {\n    return;\n  }\n  (jasmine as any)['__zone_patch__'] = true;\n\n  const SyncTestZoneSpec: {new (name: string): ZoneSpec} = (Zone as any)['SyncTestZoneSpec'];\n  const ProxyZoneSpec: {new (): ZoneSpec} = (Zone as any)['ProxyZoneSpec'];\n  if (!SyncTestZoneSpec) throw new Error('Missing: SyncTestZoneSpec');\n  if (!ProxyZoneSpec) throw new Error('Missing: ProxyZoneSpec');\n\n  const ambientZone = Zone.current;\n  // Create a synchronous-only zone in which to run `describe` blocks in order to raise an\n  // error if any asynchronous operations are attempted inside of a `describe` but outside of\n  // a `beforeEach` or `it`.\n  const syncZone = ambientZone.fork(new SyncTestZoneSpec('jasmine.describe'));\n\n  const symbol = Zone.__symbol__;\n\n  // whether patch jasmine clock when in fakeAsync\n  const disablePatchingJasmineClock = global[symbol('fakeAsyncDisablePatchingClock')] === true;\n  // the original variable name fakeAsyncPatchLock is not accurate, so the name will be\n  // fakeAsyncAutoFakeAsyncWhenClockPatched and if this enablePatchingJasmineClock is false, we also\n  // automatically disable the auto jump into fakeAsync feature\n  const enableAutoFakeAsyncWhenClockPatched = !disablePatchingJasmineClock &&\n      ((global[symbol('fakeAsyncPatchLock')] === true) ||\n       (global[symbol('fakeAsyncAutoFakeAsyncWhenClockPatched')] === true));\n\n  const ignoreUnhandledRejection = global[symbol('ignoreUnhandledRejection')] === true;\n\n  if (!ignoreUnhandledRejection) {\n    const globalErrors = (jasmine as any).GlobalErrors;\n    if (globalErrors && !(jasmine as any)[symbol('GlobalErrors')]) {\n      (jasmine as any)[symbol('GlobalErrors')] = globalErrors;\n      (jasmine as any).GlobalErrors = function() {\n        const instance = new globalErrors();\n        const originalInstall = instance.install;\n        if (originalInstall && !instance[symbol('install')]) {\n          instance[symbol('install')] = originalInstall;\n          instance.install = function() {\n            const originalHandlers = process.listeners('unhandledRejection');\n            const r = originalInstall.apply(this, arguments);\n            process.removeAllListeners('unhandledRejection');\n            if (originalHandlers) {\n              originalHandlers.forEach(h => process.on('unhandledRejection', h));\n            }\n            return r;\n          };\n        }\n        return instance;\n      };\n    }\n  }\n\n  // Monkey patch all of the jasmine DSL so that each function runs in appropriate zone.\n  const jasmineEnv: any = jasmine.getEnv();\n  ['describe', 'xdescribe', 'fdescribe'].forEach(methodName => {\n    let originalJasmineFn: Function = jasmineEnv[methodName];\n    jasmineEnv[methodName] = function(description: string, specDefinitions: Function) {\n      return originalJasmineFn.call(this, description, wrapDescribeInZone(specDefinitions));\n    };\n  });\n  ['it', 'xit', 'fit'].forEach(methodName => {\n    let originalJasmineFn: Function = jasmineEnv[methodName];\n    jasmineEnv[symbol(methodName)] = originalJasmineFn;\n    jasmineEnv[methodName] = function(\n        description: string, specDefinitions: Function, timeout: number) {\n      arguments[1] = wrapTestInZone(specDefinitions);\n      return originalJasmineFn.apply(this, arguments);\n    };\n  });\n  ['beforeEach', 'afterEach', 'beforeAll', 'afterAll'].forEach(methodName => {\n    let originalJasmineFn: Function = jasmineEnv[methodName];\n    jasmineEnv[symbol(methodName)] = originalJasmineFn;\n    jasmineEnv[methodName] = function(specDefinitions: Function, timeout: number) {\n      arguments[0] = wrapTestInZone(specDefinitions);\n      return originalJasmineFn.apply(this, arguments);\n    };\n  });\n\n  if (!disablePatchingJasmineClock) {\n    // need to patch jasmine.clock().mockDate and jasmine.clock().tick() so\n    // they can work properly in FakeAsyncTest\n    const originalClockFn: Function = ((jasmine as any)[symbol('clock')] = jasmine['clock']);\n    (jasmine as any)['clock'] = function() {\n      const clock = originalClockFn.apply(this, arguments);\n      if (!clock[symbol('patched')]) {\n        clock[symbol('patched')] = symbol('patched');\n        const originalTick = (clock[symbol('tick')] = clock.tick);\n        clock.tick = function() {\n          const fakeAsyncZoneSpec = Zone.current.get('FakeAsyncTestZoneSpec');\n          if (fakeAsyncZoneSpec) {\n            return fakeAsyncZoneSpec.tick.apply(fakeAsyncZoneSpec, arguments);\n          }\n          return originalTick.apply(this, arguments);\n        };\n        const originalMockDate = (clock[symbol('mockDate')] = clock.mockDate);\n        clock.mockDate = function() {\n          const fakeAsyncZoneSpec = Zone.current.get('FakeAsyncTestZoneSpec');\n          if (fakeAsyncZoneSpec) {\n            const dateTime = arguments.length > 0 ? arguments[0] : new Date();\n            return fakeAsyncZoneSpec.setCurrentRealTime.apply(\n                fakeAsyncZoneSpec, dateTime && typeof dateTime.getTime === 'function' ?\n                    [dateTime.getTime()] :\n                    arguments);\n          }\n          return originalMockDate.apply(this, arguments);\n        };\n        // for auto go into fakeAsync feature, we need the flag to enable it\n        if (enableAutoFakeAsyncWhenClockPatched) {\n          ['install', 'uninstall'].forEach(methodName => {\n            const originalClockFn: Function = (clock[symbol(methodName)] = clock[methodName]);\n            clock[methodName] = function() {\n              const FakeAsyncTestZoneSpec = (Zone as any)['FakeAsyncTestZoneSpec'];\n              if (FakeAsyncTestZoneSpec) {\n                (jasmine as any)[symbol('clockInstalled')] = 'install' === methodName;\n                return;\n              }\n              return originalClockFn.apply(this, arguments);\n            };\n          });\n        }\n      }\n      return clock;\n    };\n  }\n  /**\n   * Gets a function wrapping the body of a Jasmine `describe` block to execute in a\n   * synchronous-only zone.\n   */\n  function wrapDescribeInZone(describeBody: Function): Function {\n    return function(this: unknown) {\n      return syncZone.run(describeBody, this, (arguments as any) as any[]);\n    };\n  }\n\n  function runInTestZone(\n      testBody: Function, applyThis: any, queueRunner: QueueRunner, done?: Function) {\n    const isClockInstalled = !!(jasmine as any)[symbol('clockInstalled')];\n    const testProxyZoneSpec = queueRunner.testProxyZoneSpec !;\n    const testProxyZone = queueRunner.testProxyZone !;\n    let lastDelegate;\n    if (isClockInstalled && enableAutoFakeAsyncWhenClockPatched) {\n      // auto run a fakeAsync\n      const fakeAsyncModule = (Zone as any)[Zone.__symbol__('fakeAsyncTest')];\n      if (fakeAsyncModule && typeof fakeAsyncModule.fakeAsync === 'function') {\n        testBody = fakeAsyncModule.fakeAsync(testBody);\n      }\n    }\n    if (done) {\n      return testProxyZone.run(testBody, applyThis, [done]);\n    } else {\n      return testProxyZone.run(testBody, applyThis);\n    }\n  }\n\n  /**\n   * Gets a function wrapping the body of a Jasmine `it/beforeEach/afterEach` block to\n   * execute in a ProxyZone zone.\n   * This will run in `testProxyZone`. The `testProxyZone` will be reset by the `ZoneQueueRunner`\n   */\n  function wrapTestInZone(testBody: Function): Function {\n    // The `done` callback is only passed through if the function expects at least one argument.\n    // Note we have to make a function with correct number of arguments, otherwise jasmine will\n    // think that all functions are sync or async.\n    return (testBody && (testBody.length ? function(this: QueueRunnerUserContext, done: Function) {\n              return runInTestZone(testBody, this, this.queueRunner !, done);\n            } : function(this: QueueRunnerUserContext) {\n              return runInTestZone(testBody, this, this.queueRunner !);\n            }));\n  }\n  interface QueueRunner {\n    execute(): void;\n    testProxyZoneSpec: ZoneSpec|null;\n    testProxyZone: Zone|null;\n  }\n  interface QueueRunnerAttrs {\n    queueableFns: {fn: Function}[];\n    clearStack: (fn: any) => void;\n    catchException: () => boolean;\n    fail: () => void;\n    onComplete: () => void;\n    onException: (error: any) => void;\n    userContext: QueueRunnerUserContext;\n    timeout: {setTimeout: Function; clearTimeout: Function};\n  }\n  type QueueRunnerUserContext = {queueRunner?: QueueRunner};\n  const QueueRunner = (jasmine as any).QueueRunner as {\n    new (attrs: QueueRunnerAttrs): QueueRunner;\n  };\n  (jasmine as any).QueueRunner = (function(_super) {\n    __extends(ZoneQueueRunner, _super);\n    function ZoneQueueRunner(this: QueueRunner, attrs: QueueRunnerAttrs) {\n      if (attrs.onComplete) {\n        attrs.onComplete = (fn => () => {\n          // All functions are done, clear the test zone.\n          this.testProxyZone = null;\n          this.testProxyZoneSpec = null;\n          ambientZone.scheduleMicroTask('jasmine.onComplete', fn);\n        })(attrs.onComplete);\n      }\n\n      const nativeSetTimeout = global[Zone.__symbol__('setTimeout')];\n      const nativeClearTimeout = global[Zone.__symbol__('clearTimeout')];\n      if (nativeSetTimeout) {\n        // should run setTimeout inside jasmine outside of zone\n        attrs.timeout = {\n          setTimeout: nativeSetTimeout ? nativeSetTimeout : global.setTimeout,\n          clearTimeout: nativeClearTimeout ? nativeClearTimeout : global.clearTimeout\n        };\n      }\n\n      // create a userContext to hold the queueRunner itself\n      // so we can access the testProxy in it/xit/beforeEach ...\n      if ((jasmine as any).UserContext) {\n        if (!attrs.userContext) {\n          attrs.userContext = new (jasmine as any).UserContext();\n        }\n        attrs.userContext.queueRunner = this;\n      } else {\n        if (!attrs.userContext) {\n          attrs.userContext = {};\n        }\n        attrs.userContext.queueRunner = this;\n      }\n\n      // patch attrs.onException\n      const onException = attrs.onException;\n      attrs.onException = function(this: undefined|QueueRunner, error: any) {\n        if (error &&\n            error.message ===\n                'Timeout - Async callback was not invoked within timeout specified by jasmine.DEFAULT_TIMEOUT_INTERVAL.') {\n          // jasmine timeout, we can make the error message more\n          // reasonable to tell what tasks are pending\n          const proxyZoneSpec: any = this && this.testProxyZoneSpec;\n          if (proxyZoneSpec) {\n            const pendingTasksInfo = proxyZoneSpec.getAndClearPendingTasksInfo();\n            try {\n              // try catch here in case error.message is not writable\n              error.message += pendingTasksInfo;\n            } catch (err) {\n            }\n          }\n        }\n        if (onException) {\n          onException.call(this, error);\n        }\n      };\n\n      _super.call(this, attrs);\n    }\n    ZoneQueueRunner.prototype.execute = function() {\n      let zone: Zone|null = Zone.current;\n      let isChildOfAmbientZone = false;\n      while (zone) {\n        if (zone === ambientZone) {\n          isChildOfAmbientZone = true;\n          break;\n        }\n        zone = zone.parent;\n      }\n\n      if (!isChildOfAmbientZone) throw new Error('Unexpected Zone: ' + Zone.current.name);\n\n      // This is the zone which will be used for running individual tests.\n      // It will be a proxy zone, so that the tests function can retroactively install\n      // different zones.\n      // Example:\n      //   - In beforeEach() do childZone = Zone.current.fork(...);\n      //   - In it() try to do fakeAsync(). The issue is that because the beforeEach forked the\n      //     zone outside of fakeAsync it will be able to escape the fakeAsync rules.\n      //   - Because ProxyZone is parent fo `childZone` fakeAsync can retroactively add\n      //     fakeAsync behavior to the childZone.\n\n      this.testProxyZoneSpec = new ProxyZoneSpec();\n      this.testProxyZone = ambientZone.fork(this.testProxyZoneSpec);\n      if (!Zone.currentTask) {\n        // if we are not running in a task then if someone would register a\n        // element.addEventListener and then calling element.click() the\n        // addEventListener callback would think that it is the top most task and would\n        // drain the microtask queue on element.click() which would be incorrect.\n        // For this reason we always force a task when running jasmine tests.\n        Zone.current.scheduleMicroTask(\n            'jasmine.execute().forceTask', () => QueueRunner.prototype.execute.call(this));\n      } else {\n        _super.prototype.execute.call(this);\n      }\n    };\n    return ZoneQueueRunner;\n  })(QueueRunner);\n});\n"]}