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

Unified Diff: packages/analyzer/test/src/context/abstract_context.dart

Issue 2990843002: Removed fixed dependencies (Closed)
Patch Set: Created 3 years, 5 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: packages/analyzer/test/src/context/abstract_context.dart
diff --git a/packages/analyzer/test/src/context/abstract_context.dart b/packages/analyzer/test/src/context/abstract_context.dart
index 09c30b28de587d8e1b21e48974a608a5dab0c444..ba11f84eaa45ce88aa72eb021aea82228fb6b5b4 100644
--- a/packages/analyzer/test/src/context/abstract_context.dart
+++ b/packages/analyzer/test/src/context/abstract_context.dart
@@ -2,32 +2,63 @@
// 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.src.task.abstract_context_test;
+library analyzer.test.src.context.abstract_context;
+import 'package:analyzer/dart/ast/ast.dart';
+import 'package:analyzer/dart/element/element.dart';
+import 'package:analyzer/dart/element/visitor.dart';
import 'package:analyzer/file_system/file_system.dart';
import 'package:analyzer/file_system/memory_file_system.dart';
import 'package:analyzer/src/context/cache.dart';
import 'package:analyzer/src/context/context.dart';
-import 'package:analyzer/src/generated/element.dart';
-import 'package:analyzer/src/generated/engine.dart'
- hide AnalysisCache, AnalysisContextImpl, AnalysisTask;
+import 'package:analyzer/src/generated/engine.dart';
import 'package:analyzer/src/generated/sdk.dart';
import 'package:analyzer/src/generated/source.dart';
import 'package:analyzer/src/task/driver.dart';
import 'package:analyzer/task/model.dart';
+import 'package:plugin/manager.dart';
+import 'package:plugin/plugin.dart';
import 'package:unittest/unittest.dart';
import 'mock_sdk.dart';
+/**
+ * Finds an [Element] with the given [name].
+ */
+Element findChildElement(Element root, String name, [ElementKind kind]) {
+ Element result = null;
+ root.accept(new _ElementVisitorFunctionWrapper((Element element) {
+ if (element.name != name) {
+ return;
+ }
+ if (kind != null && element.kind != kind) {
+ return;
+ }
+ result = element;
+ }));
+ return result;
+}
+
+/**
+ * A function to be called for every [Element].
+ */
+typedef void _ElementVisitorFunction(Element element);
+
class AbstractContextTest {
+ static final MockSdk SHARED_MOCK_SDK = new MockSdk();
+ static final MockSdk SHARED_STRONG_MOCK_SDK = new MockSdk();
+
MemoryResourceProvider resourceProvider = new MemoryResourceProvider();
- DartSdk sdk = new MockSdk();
+ DartSdk sdk;
SourceFactory sourceFactory;
AnalysisContextImpl context;
AnalysisCache analysisCache;
AnalysisDriver analysisDriver;
+ UriResolver sdkResolver;
+ UriResolver resourceResolver;
+
AnalysisTask task;
Map<ResultDescriptor<dynamic>, dynamic> oldOutputs;
Map<ResultDescriptor<dynamic>, dynamic> outputs;
@@ -92,6 +123,8 @@ class AbstractContextTest {
return new AnalysisContextImpl();
}
+ DartSdk createDartSdk() => new MockSdk(resourceProvider: resourceProvider);
+
Source newSource(String path, [String content = '']) {
File file = resourceProvider.newFile(path, content);
return file.createSource();
@@ -107,10 +140,11 @@ class AbstractContextTest {
}
void prepareAnalysisContext([AnalysisOptions options]) {
- sourceFactory = new SourceFactory(<UriResolver>[
- new DartUriResolver(sdk),
- new ResourceUriResolver(resourceProvider)
- ]);
+ sdk = createDartSdk();
+ sdkResolver = new DartUriResolver(sdk);
+ resourceResolver = new ResourceUriResolver(resourceProvider);
+ sourceFactory = new SourceFactory(
+ <UriResolver>[sdkResolver, resourceResolver], null, resourceProvider);
context = createAnalysisContext();
if (options != null) {
context.analysisOptions = options;
@@ -120,9 +154,36 @@ class AbstractContextTest {
analysisDriver = context.driver;
}
+ CompilationUnit resolveLibraryUnit(Source source) {
+ return context.resolveCompilationUnit2(source, source);
+ }
+
void setUp() {
+ List<Plugin> plugins = <Plugin>[];
+ plugins.addAll(AnalysisEngine.instance.requiredPlugins);
+ plugins.add(AnalysisEngine.instance.commandLinePlugin);
+ plugins.add(AnalysisEngine.instance.optionsPlugin);
+
+ ExtensionManager manager = new ExtensionManager();
+ manager.processPlugins(plugins);
+
prepareAnalysisContext();
}
void tearDown() {}
}
+
+/**
+ * Wraps the given [_ElementVisitorFunction] into an instance of
+ * [GeneralizingElementVisitor].
+ */
+class _ElementVisitorFunctionWrapper extends GeneralizingElementVisitor {
+ final _ElementVisitorFunction function;
+
+ _ElementVisitorFunctionWrapper(this.function);
+
+ visitElement(Element element) {
+ function(element);
+ super.visitElement(element);
+ }
+}
« no previous file with comments | « packages/analyzer/test/src/abstract_single_unit.dart ('k') | packages/analyzer/test/src/context/builder_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698