Files
swift-mirror/test/stdlib/DictionaryTraps.swift
Max Desiatov ab7cd238fd [6.2] test/CMakeLists.txt: run Embedded Swift for Wasm tests (#83287)
Cherry-pick of #83128, #82399, and #82878, merged as ea6ca2b5db, 0c4e56174b, and e34eb3331f respectively.

**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
2025-07-26 09:48:47 +01:00

97 lines
2.5 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 DictionaryTraps = TestSuite("DictionaryTraps" + testSuiteSuffix)
DictionaryTraps.test("DuplicateKeys1")
.skip(.custom(
{ _isFastAssertConfiguration() },
reason: "this trap is not guaranteed to happen in -Ounchecked"))
.code {
expectCrashLater()
let d = Dictionary(dictionaryLiteral:
(10, 1010), (20, 1020), (30, 1030), (10, 0))
_blackHole(d)
}
DictionaryTraps.test("DuplicateKeys2")
.skip(.custom(
{ _isFastAssertConfiguration() },
reason: "this trap is not guaranteed to happen in -Ounchecked"))
.code {
expectCrashLater()
let d = Dictionary(dictionaryLiteral:
(10, 1010), (20, 1020), (30, 1030), (10, 1010))
_blackHole(d)
}
DictionaryTraps.test("DuplicateKeys3")
.skip(.custom(
{ _isFastAssertConfiguration() },
reason: "this trap is not guaranteed to happen in -Ounchecked"))
.code {
expectCrashLater()
let d = [ 10: 1010, 10: 0 ]
_blackHole(d)
}
DictionaryTraps.test("RemoveInvalidIndex1")
.skip(.custom(
{ _isFastAssertConfiguration() },
reason: "this trap is not guaranteed to happen in -Ounchecked"))
.code {
var d = Dictionary<Int, Int>()
let index = d.startIndex
expectCrashLater()
d.remove(at: index)
}
DictionaryTraps.test("RemoveInvalidIndex2")
.skip(.custom(
{ _isFastAssertConfiguration() },
reason: "this trap is not guaranteed to happen in -Ounchecked"))
.code {
var d = Dictionary<Int, Int>()
let index = d.endIndex
expectCrashLater()
d.remove(at: index)
}
DictionaryTraps.test("RemoveInvalidIndex3")
.skip(.custom(
{ _isFastAssertConfiguration() },
reason: "this trap is not guaranteed to happen in -Ounchecked"))
.code {
var d = [ 10: 1010, 20: 1020, 30: 1030 ]
let index = d.endIndex
expectCrashLater()
d.remove(at: index)
}
DictionaryTraps.test("RemoveInvalidIndex4")
.skip(.custom(
{ _isFastAssertConfiguration() },
reason: "this trap is not guaranteed to happen in -Ounchecked"))
.code {
var d = [ 10: 1010 ]
let index = d.index(forKey: 10)!
d.remove(at: index)
expectNil(d[10])
expectCrashLater()
d.remove(at: index)
}
runAllTests()