Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(68)

Side by Side Diff: dart/tests/html/worker_test.dart

Issue 302813002: Attempted fix for Firefox flakiness. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge
Patch Set: Make sure onError is called. Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « dart/tests/html/html.status ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 library worker_test; 5 library worker_test;
6 import 'package:unittest/unittest.dart'; 6 import 'package:unittest/unittest.dart';
7 import 'package:unittest/html_individual_config.dart'; 7 import 'package:unittest/html_individual_config.dart';
8 import 'dart:html'; 8 import 'dart:html';
9 9
10 main() { 10 main() {
11 useHtmlIndividualConfiguration(); 11 useHtmlIndividualConfiguration();
12 12
13 group('supported', () { 13 group('supported', () {
14 test('supported', () { 14 test('supported', () {
15 expect(Worker.supported, isTrue); 15 expect(Worker.supported, isTrue);
16 }); 16 });
17 }); 17 });
18 18
19 var workerScript = '''postMessage('WorkerMessage');'''; 19 var workerScript = '''postMessage('WorkerMessage');''';
20 20
21 group('functional', () { 21 group('functional', () {
22 22
23 test('unsupported', () { 23 test('unsupported', () {
24 var expectation = Worker.supported ? returnsNormally : throws; 24 if (!Worker.supported) {
25 25 expect(() => new Worker('worker.js'), throws);
26 expect(() { 26 } else {
27 new Worker('worker.js'); 27 new Worker('worker.js').onError.first.then(expectAsync((e) {
28 }, expectation); 28 // This event is expected, "worker.js" doesn't exist. But the event
29 // *sometimes* propagates to window.onerror in Firefox which causes
30 // this test to fail, so let's stop any further propagation:
31 e.preventDefault();
32 e.stopImmediatePropagation();
33 }));
34 }
29 }); 35 });
30 36
31 if (!Worker.supported) { 37 if (!Worker.supported) {
32 return; 38 return;
33 } 39 }
34 40
35 test('works', () { 41 test('works', () {
36 // Use Blob to make a local URL so we don't have to have a separate file. 42 // Use Blob to make a local URL so we don't have to have a separate file.
37 var blob = new Blob([workerScript], 'text/javascript'); 43 var blob = new Blob([workerScript], 'text/javascript');
38 var url = Url.createObjectUrl(blob); 44 var url = Url.createObjectUrl(blob);
39 var worker = new Worker(url); 45 var worker = new Worker(url);
40 var test = expectAsync((e) { 46 var test = expectAsync((e) {
41 expect(e.data, 'WorkerMessage'); 47 expect(e.data, 'WorkerMessage');
42 }); 48 });
43 worker.onMessage.first.then(test); 49 worker.onMessage.first.then(test);
44 }); 50 });
45 }); 51 });
46 } 52 }
47 53
OLDNEW
« no previous file with comments | « dart/tests/html/html.status ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698