1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
|
//===----------------------------------------------------------------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2018 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
import LanguageServerProtocol
import SKTestSupport
import XCTest
final class DependencyTrackingTests: XCTestCase {
func testDependenciesUpdatedSwift() async throws {
let project = try await SwiftPMTestProject(
files: [
"LibA/LibA.swift": """
public func aaa() {}
""",
"LibB/LibB.swift": """
import LibA
public func bbb() {
aaa()
}
""",
],
manifest: """
let package = Package(
name: "MyLibrary",
targets: [
.target(name: "LibA"),
.target(name: "LibB", dependencies: ["LibA"]),
]
)
""",
usePullDiagnostics: false
)
let (libBUri, _) = try project.openDocument("LibB.swift")
let initialDiags = try await project.testClient.nextDiagnosticsNotification()
// Semantic analysis: expect module import error.
XCTAssertEqual(initialDiags.diagnostics.count, 1)
if let diagnostic = initialDiags.diagnostics.first {
#if compiler(>=6.1)
#warning("When we drop support for Swift 5.10 we no longer need to check for the Objective-C error message")
#endif
XCTAssert(
diagnostic.message.contains("Could not build Objective-C module")
|| diagnostic.message.contains("No such module"),
"expected module import error but found \"\(diagnostic.message)\""
)
}
try await SwiftPMTestProject.build(at: project.scratchDirectory)
await project.testClient.server.filesDependenciesUpdated([libBUri])
let updatedDiags = try await project.testClient.nextDiagnosticsNotification()
// Semantic analysis: no more errors expected, import should resolve since we built.
XCTAssertEqual(updatedDiags.diagnostics.count, 0)
}
func testDependenciesUpdatedCXX() async throws {
let project = try await MultiFileTestProject(
files: [
"lib.c": """
int libX(int value) {
return value ? 22 : 0;
}
""",
"main.c": """
#include "lib-generated.h"
int main(int argc, const char *argv[]) {
return libX(argc);
}
""",
"compile_flags.txt": "",
],
usePullDiagnostics: false
)
let generatedHeaderURL = try project.uri(for: "main.c").fileURL!.deletingLastPathComponent()
.appendingPathComponent("lib-generated.h", isDirectory: false)
// Write an empty header file first since clangd doesn't handle missing header
// files without a recently upstreamed extension.
try "".write(to: generatedHeaderURL, atomically: true, encoding: .utf8)
let (mainUri, _) = try project.openDocument("main.c")
let openDiags = try await project.testClient.nextDiagnosticsNotification()
// Expect one error:
// - Implicit declaration of function invalid
XCTAssertEqual(openDiags.diagnostics.count, 1)
// Update the header file to have the proper contents for our code to build.
let contents = "int libX(int value);"
try contents.write(to: generatedHeaderURL, atomically: true, encoding: .utf8)
await project.testClient.server.filesDependenciesUpdated([mainUri])
let updatedDiags = try await project.testClient.nextDiagnosticsNotification()
// No more errors expected, import should resolve since we the generated header file
// now has the proper contents.
XCTAssertEqual(updatedDiags.diagnostics.count, 0)
}
}
|