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

Side by Side Diff: tests/compiler/dart2js/gvn_dynamic_field_get_test.dart

Issue 11783009: Big merge from experimental to bleeding edge. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 11 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 | « tests/compiler/dart2js/dart_backend_test.dart ('k') | tests/compiler/dart2js/gvn_test.dart » ('j') | 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) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, 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 // Test that dart2js gvns dynamic getters that don't have side 4 // Test that dart2js gvns dynamic getters that don't have side
5 // effects. 5 // effects.
6 6
7 import 'compiler_helper.dart'; 7 import 'compiler_helper.dart';
8 import 'parser_helper.dart'; 8 import 'parser_helper.dart';
9 import 'dart:uri'; 9 import 'dart:uri';
10 10
11 const String TEST = r""" 11 const String TEST = r"""
12 class A { 12 class A {
13 var foo; 13 var foo;
14 bar(a) { 14 bar(a) {
15 return a.foo + a.foo; 15 return a.foo + a.foo;
16 } 16 }
17 } 17 }
18 18
19 main() { 19 main() {
20 new A().bar(new Object()); 20 new A().bar(new Object());
21 } 21 }
22 """; 22 """;
23 23
24 main() { 24 main() {
25 Uri uri = new Uri.fromComponents(scheme: 'source'); 25 Uri uri = new Uri.fromComponents(scheme: 'source');
26 var compiler = compilerFor(TEST, uri); 26 var compiler = compilerFor(TEST, uri);
27 compiler.runCompiler(uri); 27 compiler.runCompiler(uri);
28 String generated = compiler.assembledCode; 28 String generated = compiler.assembledCode;
29 RegExp regexp = new RegExp(r"get\$foo"); 29 RegExp regexp = new RegExp(r"get\$foo");
30 Iterator matches = regexp.allMatches(generated).iterator(); 30 Iterator matches = regexp.allMatches(generated).iterator;
31 checkNumberOfMatches(matches, 1); 31 checkNumberOfMatches(matches, 1);
32 var cls = findElement(compiler, 'A'); 32 var cls = findElement(compiler, 'A');
33 Expect.isNotNull(cls); 33 Expect.isNotNull(cls);
34 var element = cls.lookupLocalMember(buildSourceString('foo')); 34 var element = cls.lookupLocalMember(buildSourceString('foo'));
35 Expect.isNotNull(element); 35 Expect.isNotNull(element);
36 Expect.isFalse(compiler.world.userDefinedGetters.contains(element)); 36 Expect.isFalse(compiler.world.userDefinedGetters.contains(element));
37 } 37 }
OLDNEW
« no previous file with comments | « tests/compiler/dart2js/dart_backend_test.dart ('k') | tests/compiler/dart2js/gvn_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698