blob: cf7b681994d688be600fa8516965715f4bb3563a [file] [log] [blame]
// 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.
import 'package:analysis_server/protocol/protocol_generated.dart';
import 'package:analyzer_plugin/protocol/protocol_common.dart';
import 'package:test/test.dart';
import 'package:test_reflective_loader/test_reflective_loader.dart';
import '../support/integration_tests.dart';
void main() {
defineReflectiveSuite(() {
defineReflectiveTests(AnalysisErrorIntegrationTest);
});
}
@reflectiveTest
class AnalysisErrorIntegrationTest
extends AbstractAnalysisServerIntegrationTest {
Future<void> test_analysisRootDoesNotExist() async {
var packagePath = sourcePath('package');
var filePath = sourcePath('package/lib/test.dart');
var content = '''
void f() {
print(null) // parse error: missing ';'
}''';
await sendServerSetSubscriptions([ServerService.STATUS]);
await sendAnalysisUpdateContent({filePath: AddContentOverlay(content)});
// Usually we get `server.status` pair of `true/false` here.
await sendAnalysisSetAnalysisRoots([packagePath], []);
// Usually we get `server.status` pair of `true/false` here.
// There is no guarantee how many times `server.status` will switch.
// So, we just wait for the errors.
// We should received them, eventually.
while (currentAnalysisErrors[filePath] == null) {
await pumpEventQueue();
}
expect(currentAnalysisErrors[filePath], isList);
var errors = existingErrorsForFile(filePath);
expect(errors, hasLength(1));
expect(errors[0].location.file, equals(filePath));
}
@SkippedTest(
reason:
'Analysis roots created after watchers are set up are not '
'currently detected',
)
Future<void> test_analysisRootDoesNotExist_createdLater() async {
var packagePath = sourcePath('package');
var filePath = sourcePath('package/lib/test.dart');
var content = 'invalidCode';
await sendServerSetSubscriptions([ServerService.STATUS]);
await sendAnalysisSetAnalysisRoots([packagePath], []);
await analysisFinished;
// Expect no errors because folder/file do not exist.
expect(currentAnalysisErrors[filePath], isNull);
// Create folder/file and wait for analysis to complete.
writeFile(filePath, content);
await analysisFinished;
// Expect errors from the invalid code.
expect(currentAnalysisErrors[filePath], isNotNull);
}
@SkippedTest(
reason:
'Analysis roots created after watchers are set up are not '
'currently detected',
)
Future<void> test_analysisRootDoesNotExist_deletedAndRecreated() async {
// To simplify testing, use two analysis roots. When we delete one of them
// we can use the notification of diagnostics sent for the other as
// validation that contexts were rebuilt.
var rootToKeepPath = sourcePath('packageKeep');
var filetoKeepPath = sourcePath('packageKeep/lib/test.dart');
var rootToDeletePath = sourcePath('packageDelete');
var fileToDeletePath = sourcePath('packageDelete/lib/test.dart');
var content = 'invalidCode';
// Create the folders/files up-front.
writeFile(filetoKeepPath, content);
writeFile(fileToDeletePath, content);
await sendServerSetSubscriptions([ServerService.STATUS]);
await sendAnalysisSetAnalysisRoots([rootToKeepPath, rootToDeletePath], []);
await analysisFinished;
// Expect errors from the invalid code.
expect(currentAnalysisErrors[fileToDeletePath], isNotNull);
// Start listening for the kept root being re-analyzed as a signal that
// the original rebuild has completed.
var keptFileDiagnostics = onAnalysisErrors.firstWhere(
(params) => params.file == filetoKeepPath,
);
// Delete the folder.
deleteFolder(rootToDeletePath);
await analysisFinished;
await keptFileDiagnostics;
// Expect the errors were removed.
expect(currentAnalysisErrors[fileToDeletePath], isNull);
// Re-create the folder/file.
writeFile(fileToDeletePath, content);
await analysisFinished;
// Expect errors returned.
expect(currentAnalysisErrors[fileToDeletePath], isNotNull);
}
Future<void> test_detect_simple_error() async {
var pathname = sourcePath('test.dart');
writeFile(pathname, '''
void f() {
print(null) // parse error: missing ';'
}''');
await standardAnalysisSetup();
await analysisFinished;
expect(currentAnalysisErrors[pathname], isList);
var errors = existingErrorsForFile(pathname);
expect(errors, hasLength(1));
expect(errors[0].location.file, equals(pathname));
}
}