blob: 909d206c115384fa808db5da6f2158b1e45c4a7a [file] [log] [blame]
// RUN: rm -rf %t && mkdir -p %t
// RUN: %target-build-swift -emit-library -Xfrontend -enable-resilience -c %S/../Inputs/resilient_protocol.swift -o %t/resilient_protocol.o
// RUN: %target-build-swift -emit-module -Xfrontend -enable-resilience -c %S/../Inputs/resilient_protocol.swift -o %t/resilient_protocol.o
// RUN: %target-build-swift %s -Xlinker %t/resilient_protocol.o -I %t -L %t -o %t/main
// RUN: %target-run %t/main
// REQUIRES: executable_test
//
// Note: protocol resilience in the sense of resiliently adding new
// requirements with default implementations is actually tested in
// validation-test/Evolution/test_protocol_*.
//
import StdlibUnittest
import resilient_protocol
var ResilientProtocolTestSuite = TestSuite("ResilientProtocol")
func increment(_ x: inout Int, by: Int) {
x += by
}
struct OtherConformingType : OtherResilientProtocol { }
// Ensure we can call materializeForSet defined in a protocol extension
// from a different resilience domain.
ResilientProtocolTestSuite.test("PropertyInProtocolExtension") {
var o = OtherConformingType()
increment(&o.propertyInExtension, by: 5)
increment(&OtherConformingType.staticPropertyInExtension, by: 7)
expectEqual(OtherConformingType.staticPropertyInExtension, 12)
}
struct DerivedConformingType : ResilientDerivedProtocol {
func requirement() -> Int { return 42 }
}
// Ensure dynamic casts to resilient types work.
func callBaseRequirement(t: ResilientBaseProtocol) -> Int {
return t.requirement()
}
@_semantics("optimize.sil.never")
func castToDerivedProtocol<T>(t: T) -> Int {
return callBaseRequirement(t: t as! ResilientDerivedProtocol)
}
ResilientProtocolTestSuite.test("DynamicCastToResilientProtocol") {
expectEqual(castToDerivedProtocol(t: DerivedConformingType()), 42)
}
runAllTests()