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

Side by Side Diff: test/codegen/lib/html/hidden_dom_1_test.dart

Issue 1930043002: Add all dart:html tests from the sdk to test/codegen. (Closed) Base URL: git@github.com:dart-lang/dev_compiler.git@master
Patch Set: Created 4 years, 7 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
OLDNEW
(Empty)
1 library HiddenDom1Test;
2 import 'package:unittest/unittest.dart';
3 import 'package:unittest/html_config.dart';
4 import 'dart:html';
5
6 // Test that the dart:html API does not leak native jsdom methods:
7 // onfocus setter.
8
9 main() {
10 useHtmlConfiguration();
11
12 test('test1', () {
13 document.body.children.add(new Element.html(r'''
14 <div id='div1'>
15 Hello World!
16 </div>'''));
17 Element e = document.query('#div1');
18 expect(e, isNotNull);
19
20 checkNoSuchMethod(() { confuse(e).onfocus = null; });
21 });
22
23 }
24
25 class Decoy {
26 void set onfocus(x) { throw 'dead code'; }
27 }
28
29 confuse(x) => opaqueTrue() ? x : (opaqueTrue() ? new Object() : new Decoy());
30
31 /** Returns [:true:], but in a way that confuses the compiler. */
32 opaqueTrue() => true; // Expand as needed.
33
34 checkNoSuchMethod(action()) {
35 var ex = null;
36 try {
37 action();
38 } catch (e) {
39 ex = e;
40 }
41 if (ex == null)
42 expect(false, isTrue, reason: 'Action should have thrown exception');
43
44 expect(ex, isNoSuchMethodError);
45 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698