Files
swift-mirror/test/1_stdlib/SetTraps.swift
Chris Lattner 31c01eab73 Change the meaning of "if let x = foo()" back to Xcode 6.4 semantics. The compiler
includes a number of QoI things to help people write the correct code.  I will commit
the testcase for it as the next patch.

The bulk of this patch is moving the stdlib, testsuite and validation testsuite to
the new syntax.  I moved a few uses of "as" patterns back to as? expressions in the 
stdlib as well.



Swift SVN r27959
2015-04-30 04:38:13 +00:00

190 lines
4.1 KiB
Swift

// RUN: rm -rf %t
// RUN: mkdir -p %t
// RUN: %target-build-swift %s -o %t/a.out_Debug
// RUN: %target-build-swift %s -o %t/a.out_Release -O
//
// RUN: %target-run %t/a.out_Debug
// RUN: %target-run %t/a.out_Release
// FIXME: rdar://problem/19648117 Needs splitting objc parts out
// XFAIL: linux
import StdlibUnittest
import Foundation
struct NotBridgedKeyTy : Equatable, Hashable {
init(_ value: Int) {
self.value = value
}
var hashValue: Int {
return value
}
var value: Int
}
func == (lhs: NotBridgedKeyTy, rhs: NotBridgedKeyTy) -> Bool {
return lhs.value == rhs.value
}
assert(!_isBridgedToObjectiveC(NotBridgedKeyTy.self))
struct NotBridgedValueTy {}
assert(!_isBridgedToObjectiveC(NotBridgedValueTy.self))
class BridgedVerbatimRefTy : Equatable, Hashable {
init(_ value: Int) {
self.value = value
}
var hashValue: Int {
return value
}
var value: Int
}
func == (lhs: BridgedVerbatimRefTy, rhs: BridgedVerbatimRefTy) -> Bool {
return lhs.value == rhs.value
}
assert(_isBridgedToObjectiveC(BridgedVerbatimRefTy.self))
assert(_isBridgedVerbatimToObjectiveC(BridgedVerbatimRefTy.self))
var SetTraps = TestSuite("SetTraps")
SetTraps.test("sanity") {
// Sanity checks. This code should not trap.
var s = Set<BridgedVerbatimRefTy>()
var nss = s as NSSet
}
SetTraps.test("RemoveInvalidIndex1") {
var s = Set<Int>()
let index = s.startIndex
expectCrashLater()
s.removeAtIndex(index)
}
SetTraps.test("RemoveInvalidIndex2") {
var s = Set<Int>()
let index = s.endIndex
expectCrashLater()
s.removeAtIndex(index)
}
SetTraps.test("RemoveInvalidIndex3") {
var s: Set<Int> = [ 10, 20, 30 ]
let index = s.endIndex
expectCrashLater()
s.removeAtIndex(index)
}
SetTraps.test("RemoveInvalidIndex4") {
var s: Set<Int> = [ 10 ]
let index = s.indexOf(10)!
s.removeAtIndex(index)
expectFalse(s.contains(10))
expectCrashLater()
s.removeAtIndex(index)
}
SetTraps.test("RemoveFirstFromEmpty")
.crashOutputMatches(_isDebugAssertConfiguration() ?
"can't removeFirst from an empty Set" : "")
.code {
var s = Set<Int>()
expectCrashLater()
s.removeFirst()
}
class TestObjCKeyTy : NSObject {
init(_ value: Int) {
self.value = value
}
override func isEqual(object: AnyObject!) -> Bool {
if let other = object {
if let otherObjcKey = other as? TestObjCKeyTy {
return self.value == otherObjcKey.value
}
}
return false
}
override var hash : Int {
return value
}
var value: Int
}
struct TestBridgedKeyTy : Hashable, _ObjectiveCBridgeable {
static func _isBridgedToObjectiveC() -> Bool {
return true
}
init(_ value: Int) { self.value = value }
var hashValue: Int { return value }
static func _getObjectiveCType() -> Any.Type {
return TestObjCKeyTy.self
}
func _bridgeToObjectiveC() -> TestObjCKeyTy {
return TestObjCKeyTy(value)
}
static func _forceBridgeFromObjectiveC(
x: TestObjCKeyTy,
inout result: TestBridgedKeyTy?
) {
result = TestBridgedKeyTy(x.value)
}
static func _conditionallyBridgeFromObjectiveC(
x: TestObjCKeyTy,
inout result: TestBridgedKeyTy?
) -> Bool {
result = TestBridgedKeyTy(x.value)
return true
}
var value: Int
}
func ==(x: TestBridgedKeyTy, y: TestBridgedKeyTy) -> Bool {
return x.value == y.value
}
SetTraps.test("BridgedKeyIsNotNSCopyable1") {
// This Set is bridged in O(1).
var s: Set<TestObjCKeyTy> = [ TestObjCKeyTy(10) ]
var nss = s as NSSet
// Unlike NSDictionary, NSSet does not require NSCopying from its element
// type.
let copiedSet = nss.mutableCopy() as! NSMutableSet
expectEqual(10, (copiedSet.anyObject() as! TestObjCKeyTy).value)
}
SetTraps.test("Downcast1") {
let s: Set<NSObject> = [ NSObject(), NSObject() ]
let s2: Set<TestObjCKeyTy> = _setDownCast(s)
expectCrashLater()
let v1 = s2.contains(TestObjCKeyTy(10))
let v2 = s2.contains(TestObjCKeyTy(20))
// This triggers failure.
for m in s2 { }
}
SetTraps.test("Downcast2") {
let s: Set<NSObject> = [ TestObjCKeyTy(10), NSObject() ]
expectCrashLater()
let s2: Set<TestBridgedKeyTy> = _setBridgeFromObjectiveC(s)
let v1 = s2.contains(TestBridgedKeyTy(10))
}
runAllTests()