| OLD | NEW |
| 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 reexport_handled_test; | 5 library reexport_handled_test; |
| 6 | 6 |
| 7 import "package:expect/expect.dart"; | 7 import "package:expect/expect.dart"; |
| 8 import "package:async_helper/async_helper.dart"; | 8 import "package:async_helper/async_helper.dart"; |
| 9 import 'mock_compiler.dart'; | 9 import 'mock_compiler.dart'; |
| 10 import 'package:compiler/src/elements/elements.dart' | 10 import 'package:compiler/src/elements/elements.dart' |
| 11 show Element, | 11 show Element, LibraryElement; |
| 12 LibraryElement; | |
| 13 | 12 |
| 14 final exportingLibraryUri = Uri.parse('exporting.dart'); | 13 final exportingLibraryUri = Uri.parse('exporting.dart'); |
| 15 const String EXPORTING_LIBRARY_SOURCE = ''' | 14 const String EXPORTING_LIBRARY_SOURCE = ''' |
| 16 library exporting; | 15 library exporting; |
| 17 var foo; | 16 var foo; |
| 18 '''; | 17 '''; |
| 19 | 18 |
| 20 final reexportingLibraryUri = Uri.parse('reexporting.dart'); | 19 final reexportingLibraryUri = Uri.parse('reexporting.dart'); |
| 21 const String REEXPORTING_LIBRARY_SOURCE = ''' | 20 const String REEXPORTING_LIBRARY_SOURCE = ''' |
| 22 library reexporting; | 21 library reexporting; |
| 23 export 'exporting.dart'; | 22 export 'exporting.dart'; |
| 24 '''; | 23 '''; |
| 25 | 24 |
| 26 void main() { | 25 void main() { |
| 27 MockCompiler compiler; | 26 MockCompiler compiler; |
| 28 asyncTest(() => MockCompiler.create((MockCompiler c) { | 27 asyncTest(() => MockCompiler.create((MockCompiler c) { |
| 29 compiler = c; | 28 compiler = c; |
| 30 compiler.registerSource(exportingLibraryUri, EXPORTING_LIBRARY_SOURCE); | 29 compiler.registerSource(exportingLibraryUri, EXPORTING_LIBRARY_SOURCE); |
| 31 compiler.registerSource(reexportingLibraryUri, REEXPORTING_LIBRARY_SOURCE); | 30 compiler.registerSource( |
| 32 return compiler.libraryLoader.loadLibrary(exportingLibraryUri); | 31 reexportingLibraryUri, REEXPORTING_LIBRARY_SOURCE); |
| 33 }).then((exportingLibrary) { | 32 return compiler.libraryLoader.loadLibrary(exportingLibraryUri); |
| 34 Expect.isTrue(exportingLibrary.exportsHandled); | 33 }).then((exportingLibrary) { |
| 35 var foo = exportingLibrary.findExported('foo'); | 34 Expect.isTrue(exportingLibrary.exportsHandled); |
| 36 Expect.isNotNull(foo); | 35 var foo = exportingLibrary.findExported('foo'); |
| 37 Expect.isTrue(foo.isField); | 36 Expect.isNotNull(foo); |
| 37 Expect.isTrue(foo.isField); |
| 38 | 38 |
| 39 // Load reexporting library when exports are handled on the exporting librar
y. | 39 // Load reexporting library when exports are handled on the exporting li
brary. |
| 40 return compiler.libraryLoader.loadLibrary(reexportingLibraryUri); | 40 return compiler.libraryLoader.loadLibrary(reexportingLibraryUri); |
| 41 }).then((reexportingLibrary) { | 41 }).then((reexportingLibrary) { |
| 42 var foo = reexportingLibrary.findExported('foo'); | 42 var foo = reexportingLibrary.findExported('foo'); |
| 43 Expect.isNotNull(foo); | 43 Expect.isNotNull(foo); |
| 44 Expect.isTrue(foo.isField); | 44 Expect.isTrue(foo.isField); |
| 45 })); | 45 })); |
| 46 } | 46 } |
| OLD | NEW |