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

Unified Diff: packages/analyzer/test/src/task/options_work_manager_test.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/task/options_work_manager_test.dart
diff --git a/packages/analyzer/test/src/task/html_work_manager_test.dart b/packages/analyzer/test/src/task/options_work_manager_test.dart
similarity index 52%
copy from packages/analyzer/test/src/task/html_work_manager_test.dart
copy to packages/analyzer/test/src/task/options_work_manager_test.dart
index 0785f97c324973d54452be67ee01cfe9e14f4119..d52286be72b591a80bbc6915cd82db72a5a1fe2c 100644
--- a/packages/analyzer/test/src/task/html_work_manager_test.dart
+++ b/packages/analyzer/test/src/task/options_work_manager_test.dart
@@ -2,9 +2,12 @@
// 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.html_work_manager_test;
+library analyzer.test.src.task.options_work_manager_test;
+import 'package:analyzer/error/error.dart' show AnalysisError;
+import 'package:analyzer/exception/exception.dart';
import 'package:analyzer/src/context/cache.dart';
+import 'package:analyzer/src/error/codes.dart' show AnalysisOptionsErrorCode;
import 'package:analyzer/src/generated/engine.dart'
show
AnalysisEngine,
@@ -13,44 +16,52 @@ import 'package:analyzer/src/generated/engine.dart'
CacheState,
ChangeNoticeImpl,
InternalAnalysisContext;
-import 'package:analyzer/src/generated/error.dart'
- show AnalysisError, HtmlErrorCode;
-import 'package:analyzer/src/generated/java_engine.dart' show CaughtException;
import 'package:analyzer/src/generated/source.dart';
-import 'package:analyzer/src/task/html.dart';
-import 'package:analyzer/src/task/html_work_manager.dart';
+import 'package:analyzer/src/task/options.dart';
+import 'package:analyzer/src/task/options_work_manager.dart';
import 'package:analyzer/task/dart.dart';
import 'package:analyzer/task/general.dart';
-import 'package:analyzer/task/html.dart';
import 'package:analyzer/task/model.dart';
+import 'package:test_reflective_loader/test_reflective_loader.dart';
import 'package:typed_mock/typed_mock.dart';
import 'package:unittest/unittest.dart';
import '../../generated/test_support.dart';
-import '../../reflective_tests.dart';
import '../../utils.dart';
main() {
initializeTestEnvironment();
- runReflectiveTests(HtmlWorkManagerTest);
+ defineReflectiveTests(OptionsWorkManagerNewFileTest);
+ defineReflectiveTests(OptionsWorkManagerOldFileTest);
}
@reflectiveTest
-class HtmlWorkManagerTest {
+class OptionsWorkManagerNewFileTest extends OptionsWorkManagerTest {
+ String get optionsFile => AnalysisEngine.ANALYSIS_OPTIONS_YAML_FILE;
+}
+
+@reflectiveTest
+class OptionsWorkManagerOldFileTest extends OptionsWorkManagerTest {
+ String get optionsFile => AnalysisEngine.ANALYSIS_OPTIONS_FILE;
+}
+
+abstract class OptionsWorkManagerTest {
InternalAnalysisContext context = new _InternalAnalysisContextMock();
AnalysisCache cache;
- HtmlWorkManager manager;
+ OptionsWorkManager manager;
CaughtException caughtException = new CaughtException(null, null);
- Source source1 = new TestSource('1.html');
- Source source2 = new TestSource('2.html');
- Source source3 = new TestSource('3.html');
- Source source4 = new TestSource('4.html');
+ Source source1;
+
+ Source source2;
+ Source source3;
+ Source source4;
CacheEntry entry1;
CacheEntry entry2;
CacheEntry entry3;
CacheEntry entry4;
+ String get optionsFile;
void expect_sourceQueue(List<Source> sources) {
expect(manager.sourceQueue, unorderedEquals(sources));
@@ -58,7 +69,11 @@ class HtmlWorkManagerTest {
void setUp() {
cache = context.analysisCache;
- manager = new HtmlWorkManager(context);
+ manager = new OptionsWorkManager(context);
+ source1 = new TestSource('test1/$optionsFile');
+ source2 = new TestSource('test2/$optionsFile');
+ source3 = new TestSource('test3/$optionsFile');
+ source4 = new TestSource('test4/$optionsFile');
entry1 = context.getCacheEntry(source1);
entry2 = context.getCacheEntry(source2);
entry3 = context.getCacheEntry(source3);
@@ -110,112 +125,99 @@ class HtmlWorkManagerTest {
}
void test_applyPriorityTargets() {
- when(context.shouldErrorsBeAnalyzed(source2, null)).thenReturn(true);
- when(context.shouldErrorsBeAnalyzed(source3, null)).thenReturn(true);
- manager.priorityResultQueue.add(new TargetedResult(source1, HTML_ERRORS));
- manager.priorityResultQueue.add(new TargetedResult(source2, HTML_ERRORS));
+ when(context.shouldErrorsBeAnalyzed(source2)).thenReturn(true);
+ when(context.shouldErrorsBeAnalyzed(source3)).thenReturn(true);
+ manager.priorityResultQueue
+ .add(new TargetedResult(source1, ANALYSIS_OPTIONS_ERRORS));
+ manager.priorityResultQueue
+ .add(new TargetedResult(source2, ANALYSIS_OPTIONS_ERRORS));
// -source1 +source3
manager.applyPriorityTargets([source2, source3]);
expect(
manager.priorityResultQueue,
unorderedEquals([
- new TargetedResult(source2, HTML_ERRORS),
- new TargetedResult(source3, HTML_ERRORS)
+ new TargetedResult(source2, ANALYSIS_OPTIONS_ERRORS),
+ new TargetedResult(source3, ANALYSIS_OPTIONS_ERRORS)
]));
// get next request
TargetedResult request = manager.getNextResult();
expect(request.target, source2);
- expect(request.result, HTML_ERRORS);
+ expect(request.result, ANALYSIS_OPTIONS_ERRORS);
}
- void test_getErrors_fullList() {
- AnalysisError error1 =
- new AnalysisError(source1, 1, 0, HtmlErrorCode.PARSE_ERROR, ['']);
- AnalysisError error2 =
- new AnalysisError(source1, 2, 0, HtmlErrorCode.PARSE_ERROR, ['']);
- entry1.setValue(HTML_DOCUMENT_ERRORS, <AnalysisError>[error1], []);
-
- DartScript script = new DartScript(source1, []);
- entry1.setValue(DART_SCRIPTS, [script], []);
- CacheEntry scriptEntry = context.getCacheEntry(script);
- scriptEntry.setValue(DART_ERRORS, [error2], []);
-
- List<AnalysisError> errors = manager.getErrors(source1);
- expect(errors, unorderedEquals([error1, error2]));
- }
-
- void test_getErrors_partialList() {
- AnalysisError error1 =
- new AnalysisError(source1, 1, 0, HtmlErrorCode.PARSE_ERROR, ['']);
- AnalysisError error2 =
- new AnalysisError(source1, 2, 0, HtmlErrorCode.PARSE_ERROR, ['']);
- entry1.setValue(HTML_DOCUMENT_ERRORS, <AnalysisError>[error1, error2], []);
+ void test_getErrors() {
+ AnalysisError error1 = new AnalysisError(
+ source1, 1, 0, AnalysisOptionsErrorCode.PARSE_ERROR, ['']);
+ AnalysisError error2 = new AnalysisError(
+ source1, 2, 0, AnalysisOptionsErrorCode.PARSE_ERROR, ['']);
+ entry1
+ .setValue(ANALYSIS_OPTIONS_ERRORS, <AnalysisError>[error1, error2], []);
List<AnalysisError> errors = manager.getErrors(source1);
expect(errors, unorderedEquals([error1, error2]));
}
void test_getNextResult_hasNormal_firstIsError() {
- entry1.setErrorState(caughtException, [HTML_ERRORS]);
+ entry1.setErrorState(caughtException, [ANALYSIS_OPTIONS_ERRORS]);
manager.sourceQueue.addAll([source1, source2]);
TargetedResult request = manager.getNextResult();
expect(request.target, source2);
- expect(request.result, HTML_ERRORS);
+ expect(request.result, ANALYSIS_OPTIONS_ERRORS);
// source1 is out, source2 is waiting
expect_sourceQueue([source2]);
}
void test_getNextResult_hasNormal_firstIsInvalid() {
- entry1.setState(HTML_ERRORS, CacheState.INVALID);
+ entry1.setState(ANALYSIS_OPTIONS_ERRORS, CacheState.INVALID);
manager.sourceQueue.addAll([source1, source2]);
TargetedResult request = manager.getNextResult();
expect(request.target, source1);
- expect(request.result, HTML_ERRORS);
+ expect(request.result, ANALYSIS_OPTIONS_ERRORS);
// no changes until computed
expect_sourceQueue([source1, source2]);
}
void test_getNextResult_hasNormal_firstIsValid() {
- entry1.setValue(HTML_ERRORS, [], []);
+ entry1.setValue(ANALYSIS_OPTIONS_ERRORS, [], []);
manager.sourceQueue.addAll([source1, source2]);
TargetedResult request = manager.getNextResult();
expect(request.target, source2);
- expect(request.result, HTML_ERRORS);
+ expect(request.result, ANALYSIS_OPTIONS_ERRORS);
// source1 is out, source2 is waiting
expect_sourceQueue([source2]);
}
void test_getNextResult_hasNormalAndPriority() {
- entry1.setState(HTML_ERRORS, CacheState.INVALID);
+ entry1.setState(ANALYSIS_OPTIONS_ERRORS, CacheState.INVALID);
manager.sourceQueue.addAll([source1, source2]);
- manager.addPriorityResult(source3, HTML_ERRORS);
+ manager.addPriorityResult(source3, ANALYSIS_OPTIONS_ERRORS);
TargetedResult request = manager.getNextResult();
expect(request.target, source3);
- expect(request.result, HTML_ERRORS);
+ expect(request.result, ANALYSIS_OPTIONS_ERRORS);
// no changes until computed
expect_sourceQueue([source1, source2]);
}
void test_getNextResult_hasPriority() {
- manager.addPriorityResult(source1, HTML_ERRORS);
- manager.addPriorityResult(source2, HTML_ERRORS);
+ manager.addPriorityResult(source1, ANALYSIS_OPTIONS_ERRORS);
+ manager.addPriorityResult(source2, ANALYSIS_OPTIONS_ERRORS);
expect(
manager.priorityResultQueue,
unorderedEquals([
- new TargetedResult(source1, HTML_ERRORS),
- new TargetedResult(source2, HTML_ERRORS)
+ new TargetedResult(source1, ANALYSIS_OPTIONS_ERRORS),
+ new TargetedResult(source2, ANALYSIS_OPTIONS_ERRORS)
]));
TargetedResult request = manager.getNextResult();
expect(request.target, source1);
- expect(request.result, HTML_ERRORS);
+ expect(request.result, ANALYSIS_OPTIONS_ERRORS);
// no changes until computed
expect(
manager.priorityResultQueue,
unorderedEquals([
- new TargetedResult(source1, HTML_ERRORS),
- new TargetedResult(source2, HTML_ERRORS)
+ new TargetedResult(source1, ANALYSIS_OPTIONS_ERRORS),
+ new TargetedResult(source2, ANALYSIS_OPTIONS_ERRORS)
]));
}
@@ -238,64 +240,17 @@ class HtmlWorkManagerTest {
expect(manager.getNextResultPriority(), WorkOrderPriority.NONE);
}
- void test_onAnalysisOptionsChanged() {
- when(context.exists(anyObject)).thenReturn(true);
- // set cache values
- entry1.setValue(DART_SCRIPTS, [], []);
- entry1.setValue(HTML_DOCUMENT, null, []);
- entry1.setValue(HTML_DOCUMENT_ERRORS, [], []);
- entry1.setValue(HTML_ERRORS, [], []);
- entry1.setValue(REFERENCED_LIBRARIES, [], []);
- // notify
- manager.onAnalysisOptionsChanged();
- // Only resolution-based values are invalidated.
- expect(entry1.getState(DART_SCRIPTS), CacheState.VALID);
- expect(entry1.getState(HTML_DOCUMENT), CacheState.VALID);
- expect(entry1.getState(HTML_DOCUMENT_ERRORS), CacheState.VALID);
- expect(entry1.getState(HTML_ERRORS), CacheState.INVALID);
- expect(entry1.getState(REFERENCED_LIBRARIES), CacheState.VALID);
- }
-
- void test_onResultInvalidated_scheduleInvalidatedLibraries() {
- // set HTML_ERRORS for source1 and source3
- entry1.setValue(HTML_ERRORS, [], []);
- entry3.setValue(HTML_ERRORS, [], []);
- // invalidate HTML_ERRORS for source1, schedule it
- entry1.setState(HTML_ERRORS, CacheState.INVALID);
- expect_sourceQueue([source1]);
- // invalidate HTML_ERRORS for source3, schedule it
- entry3.setState(HTML_ERRORS, CacheState.INVALID);
- expect_sourceQueue([source1, source3]);
- }
-
- void test_onSourceFactoryChanged() {
- when(context.exists(anyObject)).thenReturn(true);
- // set cache values
- entry1.setValue(DART_SCRIPTS, [], []);
- entry1.setValue(HTML_DOCUMENT, null, []);
- entry1.setValue(HTML_DOCUMENT_ERRORS, [], []);
- entry1.setValue(HTML_ERRORS, [], []);
- entry1.setValue(REFERENCED_LIBRARIES, [], []);
- // notify
- manager.onSourceFactoryChanged();
- // Only resolution-based values are invalidated.
- expect(entry1.getState(DART_SCRIPTS), CacheState.VALID);
- expect(entry1.getState(HTML_DOCUMENT), CacheState.VALID);
- expect(entry1.getState(HTML_DOCUMENT_ERRORS), CacheState.VALID);
- expect(entry1.getState(HTML_ERRORS), CacheState.INVALID);
- expect(entry1.getState(REFERENCED_LIBRARIES), CacheState.INVALID);
- }
-
void test_resultsComputed_errors() {
- AnalysisError error1 =
- new AnalysisError(source1, 1, 0, HtmlErrorCode.PARSE_ERROR, ['']);
- AnalysisError error2 =
- new AnalysisError(source1, 2, 0, HtmlErrorCode.PARSE_ERROR, ['']);
+ AnalysisError error1 = new AnalysisError(
+ source1, 1, 0, AnalysisOptionsErrorCode.PARSE_ERROR, ['']);
+ AnalysisError error2 = new AnalysisError(
+ source1, 2, 0, AnalysisOptionsErrorCode.PARSE_ERROR, ['']);
LineInfo lineInfo = new LineInfo([0]);
entry1.setValue(LINE_INFO, lineInfo, []);
- entry1.setValue(HTML_ERRORS, <AnalysisError>[error1, error2], []);
+ entry1
+ .setValue(ANALYSIS_OPTIONS_ERRORS, <AnalysisError>[error1, error2], []);
// RESOLVED_UNIT is ready, set errors
- manager.resultsComputed(source1, {HTML_ERRORS: null});
+ manager.resultsComputed(source1, {ANALYSIS_OPTIONS_ERRORS: null});
// all of the errors are included
ChangeNoticeImpl notice = context.getNotice(source1);
expect(notice.errors, unorderedEquals([error1, error2]));
@@ -330,22 +285,15 @@ class _InternalAnalysisContextMock extends TypedMock
@override
AnalysisErrorInfo getErrors(Source source) {
- String name = source.shortName;
List<AnalysisError> errors = AnalysisError.NO_ERRORS;
- if (AnalysisEngine.isDartFileName(name) || source is DartScript) {
- errors = getCacheEntry(source).getValue(DART_ERRORS);
- } else if (AnalysisEngine.isHtmlFileName(name)) {
- errors = getCacheEntry(source).getValue(HTML_ERRORS);
+ if (AnalysisEngine.isAnalysisOptionsFileName(source.shortName)) {
+ errors = getCacheEntry(source).getValue(ANALYSIS_OPTIONS_ERRORS);
}
return new AnalysisErrorInfoImpl(
errors, getCacheEntry(source).getValue(LINE_INFO));
}
@override
- ChangeNoticeImpl getNotice(Source source) {
- return _pendingNotices.putIfAbsent(
- source, () => new ChangeNoticeImpl(source));
- }
-
- noSuchMethod(Invocation invocation) => super.noSuchMethod(invocation);
+ ChangeNoticeImpl getNotice(Source source) =>
+ _pendingNotices.putIfAbsent(source, () => new ChangeNoticeImpl(source));
}
« no previous file with comments | « packages/analyzer/test/src/task/options_test.dart ('k') | packages/analyzer/test/src/task/strong/checker_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698