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

Unified Diff: pkg/analysis_server/test/integration/analysis/package_root.dart

Issue 679763002: Add package root support to analysis server. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 2 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 side-by-side diff with in-line comments
Download patch
Index: pkg/analysis_server/test/integration/analysis/package_root.dart
diff --git a/pkg/analysis_server/test/integration/analysis/package_root.dart b/pkg/analysis_server/test/integration/analysis/package_root.dart
new file mode 100644
index 0000000000000000000000000000000000000000..df26ee9d38a8eb487cc901663594c1af71cbf9ba
--- /dev/null
+++ b/pkg/analysis_server/test/integration/analysis/package_root.dart
@@ -0,0 +1,67 @@
+// Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
+// for details. All rights reserved. Use of this source code is governed by a
+// BSD-style license that can be found in the LICENSE file.
+
+library test.integration.analysis.packageRoot;
+
+import 'package:analysis_server/src/protocol.dart';
+import 'package:path/path.dart';
+import 'package:unittest/unittest.dart';
+
+import '../../reflective_tests.dart';
+import '../integration_tests.dart';
+
+@ReflectiveTestCase()
+class Test extends AbstractAnalysisServerIntegrationTest {
+ test_package_root() {
+ String projPath = sourcePath('project');
+ String mainPath = join(projPath, 'main.dart');
+ String packagesPath = sourcePath('packages');
+ String fooBarPath = join(packagesPath, 'foo', 'bar.dart');
+ String mainText = """
+library main;
+
+import 'package:foo/bar.dart'
+
+main() {
+ f();
+}
+""";
+ String fooBarText = """
+library foo.bar;
+
+f() {}
+""";
+ writeFile(mainPath, mainText);
+ String normalizedFooBarPath = writeFile(fooBarPath, fooBarText);
+ sendServerSetSubscriptions([ServerService.STATUS]);
+ sendAnalysisSetSubscriptions({AnalysisService.NAVIGATION: [mainPath]});
+ List<NavigationRegion> navigationRegions;
+ onAnalysisNavigation.listen((AnalysisNavigationParams params) {
+ expect(params.file, equals(mainPath));
+ navigationRegions = params.regions;
+ });
+ sendAnalysisSetAnalysisRoots([projPath], [],
+ packageRoots: {projPath: packagesPath});
+ return analysisFinished.then((_) {
+ // Verify that fooBarPath was properly resolved by checking that f()
+ // refers to it.
+ bool found = false;
+ for (NavigationRegion region in navigationRegions) {
+ String navigationSource =
+ mainText.substring(region.offset, region.offset + region.length);
+ if (navigationSource == 'f') {
+ found = true;
+ expect(region.targets, hasLength(1));
+ Location location = region.targets[0].location;
+ expect(location.file, equals(normalizedFooBarPath));
+ }
+ }
+ expect(found, isTrue);
+ });
+ }
+}
+
+main() {
+ runReflectiveTests(Test);
+}

Powered by Google App Engine
This is Rietveld 408576698