Skip to content

Commit b9a7034

Browse files
committed
[Tests] Update swiftinterface imports Swift 6 test
Update the test for imports defaulting to internal by adding the explicit `public` modifier on all imports and the expected warnings. Modernized a test somehow as it can't use previously shared files. This revealed an issue with the warning about superfluous imports on imports of submodules. I've marked one of them as a FIXME as it will require a fix in the diagnostic.
1 parent d9af387 commit b9a7034

File tree

1 file changed

+34
-11
lines changed

1 file changed

+34
-11
lines changed

test/ModuleInterface/imports-swift6.swift

Lines changed: 34 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -3,23 +3,47 @@
33
// REQUIRES: asserts
44

55
// RUN: %empty-directory(%t)
6-
// RUN: %target-swift-frontend -disable-implicit-concurrency-module-import -disable-implicit-string-processing-module-import -emit-module -o %t/empty.swiftmodule %S/../Inputs/empty.swift
7-
// RUN: %target-swift-frontend -disable-implicit-concurrency-module-import -disable-implicit-string-processing-module-import -emit-module -o %t/emptyButWithLibraryEvolution.swiftmodule %S/../Inputs/empty.swift -enable-library-evolution
6+
// RUN: split-file --leading-lines %s %t
7+
// RUN: %target-swift-frontend -disable-implicit-concurrency-module-import -disable-implicit-string-processing-module-import -emit-module -o %t/nonResilient.swiftmodule %t/empty.swift
8+
// RUN: %target-swift-frontend -disable-implicit-concurrency-module-import -disable-implicit-string-processing-module-import -emit-module -o %t/resilient.swiftmodule %t/empty.swift -enable-library-evolution
89

9-
/// Swift 6 variant.
10-
// RUN: %target-swift-emit-module-interface(%t.swiftinterface) %s %S/Inputs/imports-other.swift -disable-implicit-concurrency-module-import -disable-implicit-string-processing-module-import -I %S/Inputs/imports-clang-modules/ -I %t -verify -swift-version 6
10+
/// Check errors.
11+
// RUN: %target-swift-emit-module-interface(%t.swiftinterface) %t/clientWithError.swift -disable-implicit-concurrency-module-import -disable-implicit-string-processing-module-import -I %t -verify -swift-version 6
12+
13+
/// Check Swift 6 imports printed in swiftinterface from 2 source files.
14+
// RUN: %target-swift-emit-module-interface(%t.swiftinterface) %t/main.swift %t/main-other.swift -disable-implicit-concurrency-module-import -disable-implicit-string-processing-module-import -I %S/Inputs/imports-clang-modules/ -I %t -verify -swift-version 6
1115
// RUN: %target-swift-typecheck-module-from-interface(%t.swiftinterface) -I %S/Inputs/imports-clang-modules/ -I %t
1216
// RUN: %FileCheck -implicit-check-not BAD -check-prefix CHECK-6 %s < %t.swiftinterface
1317

14-
@_exported import empty // expected-warning {{module 'empty' was not compiled with library evolution support; using it means binary compatibility for 'main' can't be guaranteed}}
15-
@_exported import emptyButWithLibraryEvolution
16-
import B.B2
17-
import func C.c // expected-warning {{scoped imports are not yet supported in module interfaces}}
18+
//--- empty.swift
19+
20+
//--- main.swift
21+
@_exported public import resilient // expected-warning {{public import of 'resilient' was not used in public declarations or inlinable code}}
22+
public import B.B2 // expected-warning {{public import of 'B2' was not used in public declarations or inlinable code}}
23+
// expected-warning @-1 {{public import of 'B' was not used in public declarations or inlinable code}}
24+
// FIXME: We don't want this last warning.
25+
26+
public import func C.c // expected-warning {{public import of 'C' was not used in public declarations or inlinable code}}
27+
// expected-warning @-1 {{scoped imports are not yet supported in module interfaces}}
1828
import D
1929
@_implementationOnly import Secret_BAD
2030

2131
@_implementationOnly import NotSoSecret // expected-note {{imported as implementation-only here}}
22-
import NotSoSecret2 // expected-warning {{'NotSoSecret2' inconsistently imported as implementation-only}}
32+
public import NotSoSecret2 // expected-warning {{'NotSoSecret2' inconsistently imported as implementation-only}}
33+
// expected-warning @-1 {{public import of 'NotSoSecret2' was not used in public declarations or inlinable code}}
34+
35+
//--- main-other.swift
36+
public import A // expected-warning {{public import of 'A' was not used in public declarations or inlinable code}}
37+
public import B.B3 // expected-warning {{public import of 'B3' was not used in public declarations or inlinable code}}
38+
// expected-warning @-1 {{public import of 'B' was not used in public declarations or inlinable code}}
39+
public import D // expected-warning {{public import of 'D' was not used in public declarations or inlinable code}}
40+
41+
public import NotSoSecret // expected-warning {{'NotSoSecret' inconsistently imported as implementation-only}}
42+
// expected-warning @-1 {{public import of 'NotSoSecret' was not used in public declarations or inlinable code}}
43+
@_implementationOnly import NotSoSecret2 // expected-note {{imported as implementation-only here}}
44+
//--- clientWithError.swift
45+
@_exported public import nonResilient // expected-error {{module 'nonResilient' was not compiled with library evolution support; using it means binary compatibility for 'clientWithError' can't be guaranteed}}
46+
// expected-warning @-1 {{public import of 'nonResilient' was not used in public declarations or inlinable code}}
2347

2448
// CHECK-6-NOT: import
2549
// CHECK-6: {{^}}public import A{{$}}
@@ -31,6 +55,5 @@ import NotSoSecret2 // expected-warning {{'NotSoSecret2' inconsistently imported
3155
// CHECK-6-NEXT: {{^}}public import NotSoSecret{{$}}
3256
// CHECK-6-NEXT: {{^}}public import NotSoSecret2{{$}}
3357
// CHECK-6-NEXT: {{^}}public import Swift{{$}}
34-
// CHECK-6-NEXT: {{^}}@_exported public import empty{{$}}
35-
// CHECK-6-NEXT: {{^}}@_exported public import emptyButWithLibraryEvolution{{$}}
58+
// CHECK-6-NEXT: {{^}}@_exported public import resilient{{$}}
3659
// CHECK-6-NOT: import

0 commit comments

Comments
 (0)