2019-05-31 11:56:07 -04:00
|
|
|
/**
|
|
|
|
* @license
|
2020-05-19 15:08:49 -04:00
|
|
|
* Copyright Google LLC All Rights Reserved.
|
2019-05-31 11:56:07 -04:00
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
2020-10-03 23:31:14 -04:00
|
|
|
import './zone.js';
|
2019-05-31 11:56:07 -04:00
|
|
|
const testClosureFunction = () => {
|
|
|
|
const logs: string[] = [];
|
|
|
|
// call all Zone exposed functions
|
|
|
|
const testZoneSpec: ZoneSpec = {
|
|
|
|
name: 'closure',
|
|
|
|
properties: {},
|
2020-04-13 19:40:21 -04:00
|
|
|
onFork:
|
|
|
|
(parentZoneDelegate: ZoneDelegate, currentZone: Zone, targetZone: Zone,
|
|
|
|
zoneSpec: ZoneSpec) => {
|
|
|
|
return parentZoneDelegate.fork(targetZone, zoneSpec);
|
|
|
|
},
|
2019-05-31 11:56:07 -04:00
|
|
|
|
|
|
|
onIntercept:
|
|
|
|
(parentZoneDelegate: ZoneDelegate, currentZone: Zone, targetZone: Zone, delegate: Function,
|
2020-04-13 19:40:21 -04:00
|
|
|
source: string) => {
|
|
|
|
return parentZoneDelegate.intercept(targetZone, delegate, source);
|
|
|
|
},
|
2019-05-31 11:56:07 -04:00
|
|
|
|
|
|
|
onInvoke: function(
|
|
|
|
parentZoneDelegate: ZoneDelegate, currentZone: Zone, targetZone: Zone, delegate: Function,
|
|
|
|
applyThis?: any, applyArgs?: any[], source?: string) {
|
|
|
|
return parentZoneDelegate.invoke(targetZone, delegate, applyThis, applyArgs, source);
|
|
|
|
},
|
|
|
|
|
|
|
|
onHandleError: function(
|
|
|
|
parentZoneDelegate: ZoneDelegate, currentZone: Zone, targetZone: Zone, error: any) {
|
|
|
|
return parentZoneDelegate.handleError(targetZone, error);
|
|
|
|
},
|
|
|
|
|
|
|
|
onScheduleTask: function(
|
|
|
|
parentZoneDelegate: ZoneDelegate, currentZone: Zone, targetZone: Zone, task: Task) {
|
|
|
|
return parentZoneDelegate.scheduleTask(targetZone, task);
|
|
|
|
},
|
|
|
|
|
|
|
|
onInvokeTask: function(
|
|
|
|
parentZoneDelegate: ZoneDelegate, currentZone: Zone, targetZone: Zone, task: Task,
|
|
|
|
applyThis?: any, applyArgs?: any[]) {
|
|
|
|
return parentZoneDelegate.invokeTask(targetZone, task, applyThis, applyArgs);
|
|
|
|
},
|
|
|
|
|
|
|
|
onCancelTask: function(
|
|
|
|
parentZoneDelegate: ZoneDelegate, currentZone: Zone, targetZone: Zone, task: Task) {
|
|
|
|
return parentZoneDelegate.cancelTask(targetZone, task);
|
|
|
|
},
|
|
|
|
|
|
|
|
onHasTask: function(
|
|
|
|
delegate: ZoneDelegate, current: Zone, target: Zone, hasTaskState: HasTaskState) {
|
|
|
|
return delegate.hasTask(target, hasTaskState);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2019-06-29 01:29:29 -04:00
|
|
|
Zone.__load_patch('test_closure_load_patch', function() {});
|
|
|
|
Zone.__symbol__('test_symbol');
|
|
|
|
|
2019-05-31 11:56:07 -04:00
|
|
|
const testZone: Zone = Zone.current.fork(testZoneSpec);
|
|
|
|
testZone.runGuarded(() => {
|
|
|
|
testZone.run(() => {
|
|
|
|
const properties = testZoneSpec.properties;
|
2020-04-13 19:40:21 -04:00
|
|
|
properties!['key'] = 'value';
|
2019-05-31 11:56:07 -04:00
|
|
|
const keyZone = Zone.current.getZoneWith('key');
|
|
|
|
|
|
|
|
logs.push('current' + Zone.current.name);
|
2020-04-13 19:40:21 -04:00
|
|
|
logs.push('parent' + Zone.current.parent!.name);
|
|
|
|
logs.push('getZoneWith' + keyZone!.name);
|
|
|
|
logs.push('get' + keyZone!.get('key'));
|
2019-05-31 11:56:07 -04:00
|
|
|
logs.push('root' + Zone.root.name);
|
2020-10-03 23:31:14 -04:00
|
|
|
const zonePrototypeKeys = [
|
|
|
|
'get',
|
|
|
|
'getZoneWith',
|
|
|
|
'fork',
|
|
|
|
'wrap',
|
|
|
|
'run',
|
|
|
|
'runGuarded',
|
|
|
|
'runTask',
|
|
|
|
'scheduleTask',
|
|
|
|
'scheduleMicroTask',
|
|
|
|
'scheduleMacroTask',
|
|
|
|
'scheduleEventTask',
|
|
|
|
'cancelTask',
|
|
|
|
];
|
|
|
|
zonePrototypeKeys.forEach(key => {
|
|
|
|
if ((Zone as any).prototype.hasOwnProperty(key)) {
|
|
|
|
logs.push(key);
|
|
|
|
}
|
2020-04-13 19:40:21 -04:00
|
|
|
});
|
2020-10-03 23:31:14 -04:00
|
|
|
|
|
|
|
const zoneSpecKeys = [
|
|
|
|
'name',
|
|
|
|
'properties',
|
|
|
|
'onFork',
|
|
|
|
'onIntercept',
|
|
|
|
'onInvoke',
|
|
|
|
'onHandleError',
|
|
|
|
'onScheduleTask',
|
|
|
|
'onInvokeTask',
|
|
|
|
'onCancelTask',
|
|
|
|
'onHasTask',
|
|
|
|
];
|
|
|
|
zoneSpecKeys.forEach(key => {
|
|
|
|
if (testZoneSpec.hasOwnProperty(key)) {
|
|
|
|
logs.push(key);
|
|
|
|
}
|
2020-04-13 19:40:21 -04:00
|
|
|
});
|
2019-05-31 11:56:07 -04:00
|
|
|
|
2020-10-03 23:31:14 -04:00
|
|
|
const zoneTaskKeys = [
|
|
|
|
'onHasTask', 'runCount', 'type', 'source', 'data', 'scheduleFn', 'cancelFn', 'callback',
|
|
|
|
'invoke'
|
|
|
|
];
|
|
|
|
|
2019-05-31 11:56:07 -04:00
|
|
|
const task = Zone.current.scheduleMicroTask('testTask', () => {}, undefined, () => {});
|
2020-10-03 23:31:14 -04:00
|
|
|
zoneTaskKeys.forEach(key => {
|
|
|
|
if (task.hasOwnProperty(key)) {
|
|
|
|
logs.push(key);
|
|
|
|
}
|
2020-04-13 19:40:21 -04:00
|
|
|
});
|
2019-05-31 11:56:07 -04:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
const expectedResult = [
|
|
|
|
'currentclosure',
|
|
|
|
'parent<root>',
|
|
|
|
'getZoneWithclosure',
|
|
|
|
'getvalue',
|
|
|
|
'root<root>',
|
|
|
|
'get',
|
|
|
|
'getZoneWith',
|
|
|
|
'fork',
|
|
|
|
'wrap',
|
|
|
|
'run',
|
|
|
|
'runGuarded',
|
|
|
|
'runTask',
|
|
|
|
'scheduleTask',
|
|
|
|
'scheduleMicroTask',
|
|
|
|
'scheduleMacroTask',
|
|
|
|
'scheduleEventTask',
|
|
|
|
'cancelTask',
|
|
|
|
'name',
|
|
|
|
'properties',
|
|
|
|
'onFork',
|
|
|
|
'onIntercept',
|
|
|
|
'onInvoke',
|
|
|
|
'onHandleError',
|
|
|
|
'onScheduleTask',
|
|
|
|
'onInvokeTask',
|
|
|
|
'onCancelTask',
|
|
|
|
'onHasTask',
|
|
|
|
'runCount',
|
|
|
|
'type',
|
|
|
|
'source',
|
|
|
|
'data',
|
|
|
|
'scheduleFn',
|
|
|
|
'cancelFn',
|
|
|
|
'callback',
|
|
|
|
'invoke'
|
|
|
|
];
|
|
|
|
|
|
|
|
let result: boolean = true;
|
|
|
|
for (let i = 0; i < expectedResult.length; i++) {
|
|
|
|
if (expectedResult[i] !== logs[i]) {
|
|
|
|
console.log('Not Equals', expectedResult[i], logs[i]);
|
|
|
|
result = false;
|
|
|
|
}
|
|
|
|
}
|
2020-10-03 23:31:14 -04:00
|
|
|
if (result) {
|
|
|
|
console.log('All tests passed.');
|
|
|
|
} else {
|
|
|
|
console.error('Test failed, some public APIs cannot be found after closure compiler.');
|
|
|
|
}
|
2019-05-31 11:56:07 -04:00
|
|
|
process['exit'](result ? 0 : 1);
|
|
|
|
};
|
2020-04-13 19:40:21 -04:00
|
|
|
process['on']('uncaughtException', (err: any) => {
|
|
|
|
process['exit'](1);
|
|
|
|
});
|
2019-05-31 11:56:07 -04:00
|
|
|
|
|
|
|
testClosureFunction();
|