angular/packages/zone.js/test/browser/FileReader.spec.ts
Paul Gschwendtner 6fed377140 test: update tests to not run jasmine done function in sync-test zone from describe block
There are some ZoneJS tests that fork the zone from the `describe` block
for testing the zone patching. This does cause the Jasmine `done`
function later in `it` specs to be invoked in the sync-test zone from
the original `describe` block. The `done` implementation now has
changed with the Karma Jasmine update and breaks because it now causes
tasks to be scheduled.

It is conceptually incorrect/invalid to take the describe sync zone and
run test logic with that sync zone.

```
 An error was thrown in afterAll
  error properties: Object({ originalStack: 'Error: Cannot call jasmine.execute().forceTask from within a sync test (syncTestZone for jasmine.describe#FileReader).
      at new ZoneAwareError (packages/zone.js/test/browser_test_rollup.umd.js:98:37)
      at e.onScheduleTask (packages/zone.js/bundles/zone-testing-bundle.umd.min.js:158:196)
      at e.scheduleTask (packages/zone.js/bundles/zone-testing-bundle.umd.min.js:14:7529)
      at t.scheduleTask (packages/zone.js/bundles/zone-testing-bundle.umd.min.js:14:3539)
      at t.scheduleMicroTask (packages/zone.js/bundles/zone-testing-bundle.umd.min.js:14:3791)
      at r.execute (packages/zone.js/bundles/zone-testing-bundle.umd.min.js:166:4312)
      at queueRunnerFa ...
      at <Jasmine>
```
2022-07-18 19:19:00 +02:00

109 lines
4 KiB
TypeScript

/**
* @license
* Copyright Google LLC 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
*/
import {ifEnvSupports} from '../test-util';
declare const global: any;
describe('FileReader', ifEnvSupports('FileReader', function() {
let fileReader: FileReader;
let blob: Blob;
const data = 'Hello, World!';
// Android 4.3's native browser doesn't implement add/RemoveEventListener for FileReader
function supportsEventTargetFns() {
return !!FileReader.prototype.addEventListener &&
!!FileReader.prototype.removeEventListener;
}
(<any>supportsEventTargetFns).message =
'FileReader#addEventListener and FileReader#removeEventListener';
beforeEach(function() {
fileReader = new FileReader();
try {
blob = new Blob([data]);
} catch (e) {
// For hosts that don't support the Blob ctor (e.g. Android 4.3's native browser)
const blobBuilder = new global['WebKitBlobBuilder']();
blobBuilder.append(data);
blob = blobBuilder.getBlob();
}
});
describe('EventTarget methods', ifEnvSupports(supportsEventTargetFns, function() {
it('should bind addEventListener listeners', function(done) {
const testZone = Zone.current.fork({name: 'TestZone'});
testZone.run(function() {
fileReader.addEventListener('load', function() {
expect(Zone.current).toBe(testZone);
expect(fileReader.result).toEqual(data);
done();
});
});
fileReader.readAsText(blob);
});
it('should remove listeners via removeEventListener', function(done) {
const testZone = Zone.current.fork({name: 'TestZone'});
const listenerSpy = jasmine.createSpy('listener');
testZone.run(function() {
fileReader.addEventListener('loadstart', listenerSpy);
fileReader.addEventListener('loadend', function() {
expect(listenerSpy).not.toHaveBeenCalled();
done();
});
});
fileReader.removeEventListener('loadstart', listenerSpy);
fileReader.readAsText(blob);
});
}));
it('should bind onEventType listeners', function(done) {
const testZone = Zone.current.fork({name: 'TestZone'});
let listenersCalled = 0;
testZone.run(function() {
fileReader.onloadstart = function() {
listenersCalled++;
expect(Zone.current).toBe(testZone);
};
fileReader.onload = function() {
listenersCalled++;
expect(Zone.current).toBe(testZone);
};
fileReader.onloadend = function() {
listenersCalled++;
expect(Zone.current).toBe(testZone);
expect(fileReader.result).toEqual(data);
expect(listenersCalled).toBe(3);
done();
};
});
fileReader.readAsText(blob);
});
it('should have correct readyState', function(done) {
fileReader.onloadend = function() {
expect(fileReader.readyState).toBe((<any>FileReader).DONE);
done();
};
expect(fileReader.readyState).toBe((<any>FileReader).EMPTY);
fileReader.readAsText(blob);
});
}));