mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Cherry-pick of #83128, #82399, and #82878, merged asea6ca2b5db,0c4e56174b, ande34eb3331frespectively. **Explanation**: Currently `test/CMakeLists.txt` can only set `SWIFT_LIT_ARGS` for all tests uniformly. This means that we can't have tests for Embedded Swift with a different set of `lit.py` arguments. Also, create new `check-swift-embedded-wasi` target from `test/CMakeLists.txt`, tweak `lit.cfg` to support WASI Clang resource dir, exclude unsupported tests based on `CPU=wasm32` instead of `OS=wasi`. **Scope**: Limited to Embedded Swift test suite. **Risk**: Low, due to limited scope. **Testing**: #82878 was incubated on `main` for 2 weeks, #82399 for 3 weeks with no disruption, #83128 merged this week, but enables all these tests on CI, which are consistently passing. **Issue**: rdar://156585717 **Reviewer**: @bnbarham
78 lines
2.0 KiB
Swift
78 lines
2.0 KiB
Swift
// RUN: %empty-directory(%t)
|
|
// RUN: %target-build-swift %s -o %t/a.out_Debug -Onone
|
|
// RUN: %target-build-swift %s -o %t/a.out_Release -O
|
|
//
|
|
// RUN: %target-codesign %t/a.out_Debug
|
|
// RUN: %target-codesign %t/a.out_Release
|
|
// RUN: %target-run %t/a.out_Debug
|
|
// RUN: %target-run %t/a.out_Release
|
|
// REQUIRES: executable_test
|
|
// UNSUPPORTED: OS=wasip1
|
|
|
|
import StdlibUnittest
|
|
|
|
let testSuiteSuffix = _isDebugAssertConfiguration() ? "_debug" : "_release"
|
|
|
|
var SetTraps = TestSuite("SetTraps" + testSuiteSuffix)
|
|
|
|
SetTraps.test("RemoveInvalidIndex1")
|
|
.skip(.custom(
|
|
{ _isFastAssertConfiguration() },
|
|
reason: "this trap is not guaranteed to happen in -Ounchecked"))
|
|
.code {
|
|
var s = Set<Int>()
|
|
let index = s.startIndex
|
|
expectCrashLater()
|
|
s.remove(at: index)
|
|
}
|
|
|
|
SetTraps.test("RemoveInvalidIndex2")
|
|
.skip(.custom(
|
|
{ _isFastAssertConfiguration() },
|
|
reason: "this trap is not guaranteed to happen in -Ounchecked"))
|
|
.code {
|
|
var s = Set<Int>()
|
|
let index = s.endIndex
|
|
expectCrashLater()
|
|
s.remove(at: index)
|
|
}
|
|
|
|
SetTraps.test("RemoveInvalidIndex3")
|
|
.skip(.custom(
|
|
{ _isFastAssertConfiguration() },
|
|
reason: "this trap is not guaranteed to happen in -Ounchecked"))
|
|
.code {
|
|
var s: Set<Int> = [ 10, 20, 30 ]
|
|
let index = s.endIndex
|
|
expectCrashLater()
|
|
s.remove(at: index)
|
|
}
|
|
|
|
SetTraps.test("RemoveInvalidIndex4")
|
|
.skip(.custom(
|
|
{ _isFastAssertConfiguration() },
|
|
reason: "this trap is not guaranteed to happen in -Ounchecked"))
|
|
.code {
|
|
var s: Set<Int> = [ 10 ]
|
|
let index = s.firstIndex(of: 10)!
|
|
s.remove(at: index)
|
|
expectFalse(s.contains(10))
|
|
expectCrashLater()
|
|
s.remove(at: index)
|
|
}
|
|
|
|
SetTraps.test("RemoveFirstFromEmpty")
|
|
.skip(.custom(
|
|
{ _isFastAssertConfiguration() },
|
|
reason: "this trap is not guaranteed to happen in -Ounchecked"))
|
|
.crashOutputMatches(_isDebugAssertConfiguration() ?
|
|
"Can't removeFirst from an empty Set" : "")
|
|
.code {
|
|
var s = Set<Int>()
|
|
expectCrashLater()
|
|
s.removeFirst()
|
|
}
|
|
|
|
runAllTests()
|
|
|