From 4e82cc08611571af6f373ef2207a8d0a5b842ba1 Mon Sep 17 00:00:00 2001 From: Tim Blasi Date: Wed, 18 Mar 2015 11:17:13 -0700 Subject: [PATCH] refactor(dart/transform): Test `directive_linker` as a unit Formerly, it was tested only as a piece of the transformer pipeline. Add its own directory and test the linker on its own. --- .../transform/directive_linker/all_tests.dart | 52 +++++++++++++++++++ .../simple_export_files/bar.ng_deps.dart | 17 ++++++ .../expected/bar.ng_deps.dart | 20 +++++++ .../expected/foo.ng_deps.dart | 0 .../expected/index.ng_deps.dart | 2 +- .../simple_export_files/foo.ng_deps.dart | 16 ++++++ .../simple_export_files/index.ng_deps.dart} | 7 +-- .../simple_files/bar.ng_deps.dart | 20 +++++++ .../simple_files}/expected/bar.ng_deps.dart | 0 .../simple_files/expected/foo.ng_deps.dart | 16 ++++++ .../simple_files/expected/index.ng_deps.dart | 13 +++++ .../simple_files/foo.ng_deps.dart | 16 ++++++ .../simple_files/index.ng_deps.dart | 11 ++++ .../test/transform/integration/all_tests.dart | 11 ---- .../integration/chained_deps_files/bar.dart | 9 ---- .../integration/chained_deps_files/foo.dart | 8 --- .../test/transform/transform.server.spec.dart | 2 + 17 files changed, 188 insertions(+), 32 deletions(-) create mode 100644 modules/angular2/test/transform/directive_linker/all_tests.dart create mode 100644 modules/angular2/test/transform/directive_linker/simple_export_files/bar.ng_deps.dart create mode 100644 modules/angular2/test/transform/directive_linker/simple_export_files/expected/bar.ng_deps.dart rename modules/angular2/test/transform/{integration/chained_deps_files => directive_linker/simple_export_files}/expected/foo.ng_deps.dart (100%) rename modules/angular2/test/transform/{integration/chained_deps_files => directive_linker/simple_export_files}/expected/index.ng_deps.dart (88%) create mode 100644 modules/angular2/test/transform/directive_linker/simple_export_files/foo.ng_deps.dart rename modules/angular2/test/transform/{integration/chained_deps_files/index.dart => directive_linker/simple_export_files/index.ng_deps.dart} (60%) create mode 100644 modules/angular2/test/transform/directive_linker/simple_files/bar.ng_deps.dart rename modules/angular2/test/transform/{integration/chained_deps_files => directive_linker/simple_files}/expected/bar.ng_deps.dart (100%) create mode 100644 modules/angular2/test/transform/directive_linker/simple_files/expected/foo.ng_deps.dart create mode 100644 modules/angular2/test/transform/directive_linker/simple_files/expected/index.ng_deps.dart create mode 100644 modules/angular2/test/transform/directive_linker/simple_files/foo.ng_deps.dart create mode 100644 modules/angular2/test/transform/directive_linker/simple_files/index.ng_deps.dart delete mode 100644 modules/angular2/test/transform/integration/chained_deps_files/bar.dart delete mode 100644 modules/angular2/test/transform/integration/chained_deps_files/foo.dart diff --git a/modules/angular2/test/transform/directive_linker/all_tests.dart b/modules/angular2/test/transform/directive_linker/all_tests.dart new file mode 100644 index 0000000000..98b9fa0cf9 --- /dev/null +++ b/modules/angular2/test/transform/directive_linker/all_tests.dart @@ -0,0 +1,52 @@ +library angular2.test.transform.directive_linker.all_tests; + +import 'package:barback/barback.dart'; +import 'package:angular2/src/transform/common/logging.dart' hide init; +import 'package:angular2/src/transform/common/formatter.dart' hide init; +import 'package:angular2/src/transform/directive_linker/linker.dart'; +import 'package:code_transformers/tests.dart'; +import 'package:dart_style/dart_style.dart'; +import 'package:path/path.dart' as path; +import 'package:unittest/unittest.dart'; +import 'package:unittest/vm_config.dart'; + +import '../common/logger.dart'; +import '../common/read_file.dart'; + +var formatter = new DartFormatter(); + +void allTests() { + var reader = new TestAssetReader(); + setLogger(new NullLogger()); + + test('should ensure that dependencies are property chained.', () async { + for (var inputPath in [ + 'bar.ng_deps.dart', + 'foo.ng_deps.dart', + 'index.ng_deps.dart' + ]) { + var expected = + readFile('directive_linker/simple_files/expected/$inputPath'); + inputPath = 'directive_linker/simple_files/$inputPath'; + var actual = formatter + .format(await linkNgDeps(reader, new AssetId('a', inputPath))); + expect(actual, equals(expected)); + } + }); + + test('should ensure that exported dependencies are property chained.', + () async { + for (var inputPath in [ + 'bar.ng_deps.dart', + 'foo.ng_deps.dart', + 'index.ng_deps.dart' + ]) { + var expected = + readFile('directive_linker/simple_export_files/expected/$inputPath'); + inputPath = 'directive_linker/simple_export_files/$inputPath'; + var actual = formatter + .format(await linkNgDeps(reader, new AssetId('a', inputPath))); + expect(actual, equals(expected)); + } + }); +} diff --git a/modules/angular2/test/transform/directive_linker/simple_export_files/bar.ng_deps.dart b/modules/angular2/test/transform/directive_linker/simple_export_files/bar.ng_deps.dart new file mode 100644 index 0000000000..881119381a --- /dev/null +++ b/modules/angular2/test/transform/directive_linker/simple_export_files/bar.ng_deps.dart @@ -0,0 +1,17 @@ +library bar; + +import 'bar.dart'; +import 'package:angular2/src/core/annotations/annotations.dart'; +export 'foo.dart'; + +bool _visited = false; +void setupReflection(reflector) { + if (_visited) return; + _visited = true; + reflector + ..registerType(MyComponent, { + 'factory': () => new MyComponent(), + 'parameters': const [], + 'annotations': const [const Component(selector: '[soup]')] + }); +} diff --git a/modules/angular2/test/transform/directive_linker/simple_export_files/expected/bar.ng_deps.dart b/modules/angular2/test/transform/directive_linker/simple_export_files/expected/bar.ng_deps.dart new file mode 100644 index 0000000000..e5d0dc5cc9 --- /dev/null +++ b/modules/angular2/test/transform/directive_linker/simple_export_files/expected/bar.ng_deps.dart @@ -0,0 +1,20 @@ +library bar; + +import 'bar.dart'; +import 'package:angular2/src/core/annotations/annotations.dart'; +import 'foo.ng_deps.dart' as i0; + +export 'foo.dart'; + +bool _visited = false; +void setupReflection(reflector) { + if (_visited) return; + _visited = true; + reflector + ..registerType(MyComponent, { + 'factory': () => new MyComponent(), + 'parameters': const [], + 'annotations': const [const Component(selector: '[soup]')] + }); + i0.setupReflection(reflector); +} diff --git a/modules/angular2/test/transform/integration/chained_deps_files/expected/foo.ng_deps.dart b/modules/angular2/test/transform/directive_linker/simple_export_files/expected/foo.ng_deps.dart similarity index 100% rename from modules/angular2/test/transform/integration/chained_deps_files/expected/foo.ng_deps.dart rename to modules/angular2/test/transform/directive_linker/simple_export_files/expected/foo.ng_deps.dart diff --git a/modules/angular2/test/transform/integration/chained_deps_files/expected/index.ng_deps.dart b/modules/angular2/test/transform/directive_linker/simple_export_files/expected/index.ng_deps.dart similarity index 88% rename from modules/angular2/test/transform/integration/chained_deps_files/expected/index.ng_deps.dart rename to modules/angular2/test/transform/directive_linker/simple_export_files/expected/index.ng_deps.dart index b4c8d7c607..fa287f41d3 100644 --- a/modules/angular2/test/transform/integration/chained_deps_files/expected/index.ng_deps.dart +++ b/modules/angular2/test/transform/directive_linker/simple_export_files/expected/index.ng_deps.dart @@ -3,7 +3,7 @@ library web_foo; import 'package:angular2/src/core/application.dart'; import 'package:angular2/src/reflection/reflection_capabilities.dart'; import 'bar.dart'; -import 'a:web/bar.ng_deps.dart' as i0; +import 'bar.ng_deps.dart' as i0; bool _visited = false; void setupReflection(reflector) { diff --git a/modules/angular2/test/transform/directive_linker/simple_export_files/foo.ng_deps.dart b/modules/angular2/test/transform/directive_linker/simple_export_files/foo.ng_deps.dart new file mode 100644 index 0000000000..db192c6a6f --- /dev/null +++ b/modules/angular2/test/transform/directive_linker/simple_export_files/foo.ng_deps.dart @@ -0,0 +1,16 @@ +library foo; + +import 'foo.dart'; +import 'package:angular2/src/core/annotations/annotations.dart'; + +bool _visited = false; +void setupReflection(reflector) { + if (_visited) return; + _visited = true; + reflector + ..registerType(DependencyComponent, { + 'factory': () => new DependencyComponent(), + 'parameters': const [], + 'annotations': const [const Component(selector: '[salad]')] + }); +} diff --git a/modules/angular2/test/transform/integration/chained_deps_files/index.dart b/modules/angular2/test/transform/directive_linker/simple_export_files/index.ng_deps.dart similarity index 60% rename from modules/angular2/test/transform/integration/chained_deps_files/index.dart rename to modules/angular2/test/transform/directive_linker/simple_export_files/index.ng_deps.dart index 505e371e0e..28bdfe8924 100644 --- a/modules/angular2/test/transform/integration/chained_deps_files/index.dart +++ b/modules/angular2/test/transform/directive_linker/simple_export_files/index.ng_deps.dart @@ -4,7 +4,8 @@ import 'package:angular2/src/core/application.dart'; import 'package:angular2/src/reflection/reflection_capabilities.dart'; import 'bar.dart'; -void main() { - reflector.reflectionCapabilities = new ReflectionCapabilities(); - bootstrap(MyComponent); +bool _visited = false; +void setupReflection(reflector) { + if (_visited) return; + _visited = true; } diff --git a/modules/angular2/test/transform/directive_linker/simple_files/bar.ng_deps.dart b/modules/angular2/test/transform/directive_linker/simple_files/bar.ng_deps.dart new file mode 100644 index 0000000000..b8c53e00d3 --- /dev/null +++ b/modules/angular2/test/transform/directive_linker/simple_files/bar.ng_deps.dart @@ -0,0 +1,20 @@ +library bar; + +import 'bar.dart'; +import 'package:angular2/src/core/annotations/annotations.dart'; +import 'foo.dart' as dep; + +bool _visited = false; +void setupReflection(reflector) { + if (_visited) return; + _visited = true; + reflector + ..registerType(MyComponent, { + 'factory': () => new MyComponent(), + 'parameters': const [], + 'annotations': const [ + const Component( + selector: '[soup]', services: const [dep.DependencyComponent]) + ] + }); +} diff --git a/modules/angular2/test/transform/integration/chained_deps_files/expected/bar.ng_deps.dart b/modules/angular2/test/transform/directive_linker/simple_files/expected/bar.ng_deps.dart similarity index 100% rename from modules/angular2/test/transform/integration/chained_deps_files/expected/bar.ng_deps.dart rename to modules/angular2/test/transform/directive_linker/simple_files/expected/bar.ng_deps.dart diff --git a/modules/angular2/test/transform/directive_linker/simple_files/expected/foo.ng_deps.dart b/modules/angular2/test/transform/directive_linker/simple_files/expected/foo.ng_deps.dart new file mode 100644 index 0000000000..db192c6a6f --- /dev/null +++ b/modules/angular2/test/transform/directive_linker/simple_files/expected/foo.ng_deps.dart @@ -0,0 +1,16 @@ +library foo; + +import 'foo.dart'; +import 'package:angular2/src/core/annotations/annotations.dart'; + +bool _visited = false; +void setupReflection(reflector) { + if (_visited) return; + _visited = true; + reflector + ..registerType(DependencyComponent, { + 'factory': () => new DependencyComponent(), + 'parameters': const [], + 'annotations': const [const Component(selector: '[salad]')] + }); +} diff --git a/modules/angular2/test/transform/directive_linker/simple_files/expected/index.ng_deps.dart b/modules/angular2/test/transform/directive_linker/simple_files/expected/index.ng_deps.dart new file mode 100644 index 0000000000..fa287f41d3 --- /dev/null +++ b/modules/angular2/test/transform/directive_linker/simple_files/expected/index.ng_deps.dart @@ -0,0 +1,13 @@ +library web_foo; + +import 'package:angular2/src/core/application.dart'; +import 'package:angular2/src/reflection/reflection_capabilities.dart'; +import 'bar.dart'; +import 'bar.ng_deps.dart' as i0; + +bool _visited = false; +void setupReflection(reflector) { + if (_visited) return; + _visited = true; + i0.setupReflection(reflector); +} diff --git a/modules/angular2/test/transform/directive_linker/simple_files/foo.ng_deps.dart b/modules/angular2/test/transform/directive_linker/simple_files/foo.ng_deps.dart new file mode 100644 index 0000000000..db192c6a6f --- /dev/null +++ b/modules/angular2/test/transform/directive_linker/simple_files/foo.ng_deps.dart @@ -0,0 +1,16 @@ +library foo; + +import 'foo.dart'; +import 'package:angular2/src/core/annotations/annotations.dart'; + +bool _visited = false; +void setupReflection(reflector) { + if (_visited) return; + _visited = true; + reflector + ..registerType(DependencyComponent, { + 'factory': () => new DependencyComponent(), + 'parameters': const [], + 'annotations': const [const Component(selector: '[salad]')] + }); +} diff --git a/modules/angular2/test/transform/directive_linker/simple_files/index.ng_deps.dart b/modules/angular2/test/transform/directive_linker/simple_files/index.ng_deps.dart new file mode 100644 index 0000000000..28bdfe8924 --- /dev/null +++ b/modules/angular2/test/transform/directive_linker/simple_files/index.ng_deps.dart @@ -0,0 +1,11 @@ +library web_foo; + +import 'package:angular2/src/core/application.dart'; +import 'package:angular2/src/reflection/reflection_capabilities.dart'; +import 'bar.dart'; + +bool _visited = false; +void setupReflection(reflector) { + if (_visited) return; + _visited = true; +} diff --git a/modules/angular2/test/transform/integration/all_tests.dart b/modules/angular2/test/transform/integration/all_tests.dart index 7d891cc115..358255f1b1 100644 --- a/modules/angular2/test/transform/integration/all_tests.dart +++ b/modules/angular2/test/transform/integration/all_tests.dart @@ -96,17 +96,6 @@ void allTests() { outputs: { 'a|web/bar.ng_deps.dart': 'two_annotations_files/expected/bar.ng_deps.dart' - }), - new IntegrationTestConfig( - 'should ensure that dependencies are property chained.', - inputs: { - 'a|web/index.dart': 'chained_deps_files/index.dart', - 'a|web/foo.dart': 'chained_deps_files/foo.dart', - 'a|web/bar.dart': 'chained_deps_files/bar.dart' - }, - outputs: { - 'a|web/bar.ng_deps.dart': 'chained_deps_files/expected/bar.ng_deps.dart', - 'a|web/foo.ng_deps.dart': 'chained_deps_files/expected/foo.ng_deps.dart' }) ]; diff --git a/modules/angular2/test/transform/integration/chained_deps_files/bar.dart b/modules/angular2/test/transform/integration/chained_deps_files/bar.dart deleted file mode 100644 index 19f0b341c0..0000000000 --- a/modules/angular2/test/transform/integration/chained_deps_files/bar.dart +++ /dev/null @@ -1,9 +0,0 @@ -library bar; - -import 'package:angular2/src/core/annotations/annotations.dart'; -import 'foo.dart' as dep; - -@Component(selector: '[soup]', services: const [dep.DependencyComponent]) -class MyComponent { - MyComponent(); -} diff --git a/modules/angular2/test/transform/integration/chained_deps_files/foo.dart b/modules/angular2/test/transform/integration/chained_deps_files/foo.dart deleted file mode 100644 index 446f981fde..0000000000 --- a/modules/angular2/test/transform/integration/chained_deps_files/foo.dart +++ /dev/null @@ -1,8 +0,0 @@ -library foo; - -import 'package:angular2/src/core/annotations/annotations.dart'; - -@Component(selector: '[salad]') -class DependencyComponent { - DependencyComponent(); -} diff --git a/modules/angular2/test/transform/transform.server.spec.dart b/modules/angular2/test/transform/transform.server.spec.dart index 89436f6d1c..3fbb97976a 100644 --- a/modules/angular2/test/transform/transform.server.spec.dart +++ b/modules/angular2/test/transform/transform.server.spec.dart @@ -4,6 +4,7 @@ import 'package:unittest/unittest.dart'; import 'package:unittest/vm_config.dart'; import 'bind_generator/all_tests.dart' as bindGenerator; +import 'directive_linker/all_tests.dart' as directiveLinker; import 'directive_processor/all_tests.dart' as directiveProcessor; import 'integration/all_tests.dart' as integration; import 'reflection_remover/all_tests.dart' as reflectionRemover; @@ -12,6 +13,7 @@ import 'template_compiler/all_tests.dart' as templateCompiler; main() { useVMConfiguration(); group('Bind Generator', bindGenerator.allTests); + group('Directive Linker', directiveLinker.allTests); group('Directive Processor', directiveProcessor.allTests); group('Reflection Remover', reflectionRemover.allTests); group('Template Compiler', templateCompiler.allTests);