File: objc_class_resilience_stubs.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (80 lines) | stat: -rw-r--r-- 2,698 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
// RUN: %empty-directory(%t)

// RUN: %target-build-swift-dylib(%t/%target-library-name(resilient_struct)) -enable-library-evolution %S/../Inputs/resilient_struct.swift -emit-module -emit-module-path %t/resilient_struct.swiftmodule
// RUN: %target-codesign %t/%target-library-name(resilient_struct)

// RUN: %target-build-swift-dylib(%t/%target-library-name(resilient_objc_class)) -I %t -L %t -lresilient_struct -enable-library-evolution %S/../Inputs/resilient_objc_class.swift -emit-module -emit-module-path %t/resilient_objc_class.swiftmodule
// RUN: %target-codesign %t/%target-library-name(resilient_objc_class)

// RUN: %target-build-swift %s -L %t -I %t -lresilient_struct -lresilient_objc_class -o %t/main %target-rpath(%t) -target %target-next-stable-abi-triple
// RUN: %target-codesign %t/main

// RUN: %target-run %t/main %t/%target-library-name(resilient_struct) %t/%target-library-name(resilient_objc_class)

// REQUIRES: executable_test
// REQUIRES: objc_interop
// REQUIRES: swift_stable_abi

import StdlibUnittest
import Foundation
import resilient_objc_class

// Old OS versions do not have this hook.
let loadClassrefMissing = {
  nil == dlsym(UnsafeMutableRawPointer(bitPattern: -2),
               "objc_loadClassref")
}()

var ResilientClassTestSuite = TestSuite("ResilientClass")

class ResilientNSObjectSubclass : ResilientNSObjectOutsideParent {}

@_optimize(none) func blackHole<T>(_: T) {}

@_optimize(none) func forceMetadata() {
  blackHole(ResilientNSObjectSubclass())
}

// This should not crash on older runtimes because we check before
// attempting to register the class stub.
ResilientClassTestSuite.test("RealizeResilientClass")
  .xfail(.osxMinor(10, 10, reason:
         "Fails on 10.9 and 10.10 -- rdar://51036773"))
  .code {
  forceMetadata()
}

@objc protocol MyProtocol {
  func myMethod() -> Int
}

extension ResilientNSObjectSubclass : MyProtocol {
  @objc func myMethod() -> Int { return 42 }
}

ResilientClassTestSuite.test("category on my class")
  .skip(.custom({ loadClassrefMissing },
                reason: "class stubs support not present"))
  .code {
  print(ResilientNSObjectSubclass.self)
  let o = ResilientNSObjectSubclass()
  expectEqual(42, (o as MyProtocol).myMethod())
}

@objc protocol AnotherProtocol {
  func anotherMethod() -> Int
}

extension ResilientNSObjectOutsideParent : AnotherProtocol {
  @objc func anotherMethod() -> Int { return 69 }
}

ResilientClassTestSuite.test("category on other class")
  .skip(.custom({ loadClassrefMissing },
                reason: "class stubs support not present"))
  .code {
  let o = ResilientNSObjectOutsideParent()
  expectEqual(69, (o as AnotherProtocol).anotherMethod())
}

runAllTests()