| // Copyright (c) 2025, 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 'dart:async'; |
| |
| /// A common interface that can be implemented by a set of base classes to |
| /// allow tests to be written to run in different configurations |
| /// (LSP and LSP-over-Legacy, and in-process and out-of-process). |
| /// |
| /// Implementations should use the appropriate APIs for the given server, for |
| /// example a test running against LSP will send a `textDocument/didOpen` |
| /// notification from [openFile] whereas when using the legacy server (even for |
| /// LSP-over-Legacy tests) will send an `analysis.updateContent` request. |
| abstract interface class SharedTestInterface { |
| /// A future that completes when the current analysis completes. |
| /// |
| /// If there is no analysis in progress, completes immediately. |
| Future<void> get currentAnalysis; |
| |
| /// Sets whether the test should fail if error diagnostics are generated. |
| /// |
| /// This is used to avoid accidentally including invalid code in tests but can |
| /// be overridden for tests that are deliberately testing invalid code. |
| set failTestOnErrorDiagnostic(bool value); |
| |
| /// Gets the full normalized path of the test project folder. |
| String get projectFolderPath; |
| |
| /// Gets the full normalized file path of the `pubspec.yaml` in the test |
| /// project. |
| String get pubspecFilePath; |
| |
| /// Gets a file:/// URI for [pubspecFilePath]. |
| Uri get pubspecFileUri; |
| |
| /// Gets the full normalized file path of a file named "test.dart" in the test |
| /// project. |
| String get testFilePath; |
| |
| /// Gets a file:/// URI for [testFilePath]; |
| Uri get testFileUri; |
| |
| /// Tells the server that file with [uri] has been closed and any overlay |
| /// should be removed. |
| Future<void> closeFile(Uri uri); |
| |
| /// Creates a file at [filePath] with the given [content]. |
| void createFile(String filePath, String content); |
| |
| /// Performs standard initialization of the server, including starting |
| /// the server (an external process for integration tests) and sending any |
| /// initialization/analysis roots, and waiting for initial analysis to |
| /// complete. |
| Future<void> initializeServer(); |
| |
| /// Tells the server that the file with [uri] has been opened and has the |
| /// given [content]. |
| Future<void> openFile(Uri uri, String content, {int version = 1}); |
| |
| /// Tells the server that the file with [uri] has had it's content replaced |
| /// with [content]. |
| Future<void> replaceFile(int newVersion, Uri uri, String content); |
| |
| FutureOr<void> setUp(); |
| } |