|
| 1 | +// RUN: %target-run-simple-swift(-I %S/Inputs/ -Xfrontend -enable-cxx-interop) |
| 2 | +// |
| 3 | +// REQUIRES: executable_test |
| 4 | +// |
| 5 | + |
| 6 | +import StdlibUnittest |
| 7 | +import AmbiguousMethods |
| 8 | + |
| 9 | +var CxxAmbiguousMethodTestSuite = TestSuite("CxxAmbiguousMethods") |
| 10 | + |
| 11 | +CxxAmbiguousMethodTestSuite.test("numberOfMutableMethodsCalled: () -> Int") { |
| 12 | + var instance = HasAmbiguousMethods() |
| 13 | + |
| 14 | + // Sanity check. Make sure we start at 0 |
| 15 | + expectEqual(0, instance.numberOfMutableMethodsCalled()) |
| 16 | + |
| 17 | + // Make sure calling numberOfMutableMethodsCalled above didn't |
| 18 | + // change the count |
| 19 | + expectEqual(0, instance.numberOfMutableMethodsCalled()) |
| 20 | + |
| 21 | + // Check that mutable version _does_ change the mutable call count |
| 22 | + expectEqual(1, instance.numberOfMutableMethodsCalledMutating()) |
| 23 | + |
| 24 | + expectEqual(1, instance.numberOfMutableMethodsCalled()) |
| 25 | +} |
| 26 | + |
| 27 | +CxxAmbiguousMethodTestSuite.test("Basic Increment: (Int) -> Int") { |
| 28 | + var instance = HasAmbiguousMethods() |
| 29 | + var a: Int32 = 0 |
| 30 | + |
| 31 | + // Sanity check. Make sure we start at 0 |
| 32 | + expectEqual(0, instance.numberOfMutableMethodsCalled()) |
| 33 | + |
| 34 | + // Non mutable version should NOT change count |
| 35 | + a = instance.increment(a); |
| 36 | + expectEqual(1, a) |
| 37 | + expectEqual(0, instance.numberOfMutableMethodsCalled()) |
| 38 | + |
| 39 | + a = instance.incrementMutating(a); |
| 40 | + expectEqual(2, a) |
| 41 | + expectEqual(1, instance.numberOfMutableMethodsCalled()) |
| 42 | +} |
| 43 | + |
| 44 | +CxxAmbiguousMethodTestSuite.test("Out Param Increment: (Int, Int, inout Int) -> Void") { |
| 45 | + var instance = HasAmbiguousMethods() |
| 46 | + var out: Int32 = 0 |
| 47 | + |
| 48 | + // Sanity check. Make sure we start at 0 |
| 49 | + expectEqual(0, instance.numberOfMutableMethodsCalled()) |
| 50 | + |
| 51 | + // Non mutable version should NOT change count |
| 52 | + instance.increment(0, 1, &out); |
| 53 | + expectEqual(1, out) |
| 54 | + expectEqual(0, instance.numberOfMutableMethodsCalled()) |
| 55 | + |
| 56 | + instance.incrementMutating(5, 2, &out); |
| 57 | + expectEqual(7, out) |
| 58 | + expectEqual(1, instance.numberOfMutableMethodsCalled()) |
| 59 | +} |
| 60 | + |
| 61 | +CxxAmbiguousMethodTestSuite.test("Inout Param Increment: (inout Int, Int) -> Void") { |
| 62 | + var instance = HasAmbiguousMethods() |
| 63 | + var inoutVal: Int32 = 0 |
| 64 | + |
| 65 | + // Sanity check. Make sure we start at 0 |
| 66 | + expectEqual(0, instance.numberOfMutableMethodsCalled()) |
| 67 | + |
| 68 | + // Non mutable version should NOT change count |
| 69 | + instance.increment(&inoutVal, 1); |
| 70 | + expectEqual(1, inoutVal) |
| 71 | + expectEqual(0, instance.numberOfMutableMethodsCalled()) |
| 72 | + |
| 73 | + instance.incrementMutating(&inoutVal, 2); |
| 74 | + expectEqual(3, inoutVal) |
| 75 | + expectEqual(1, instance.numberOfMutableMethodsCalled()) |
| 76 | +} |
| 77 | + |
| 78 | +runAllTests() |
0 commit comments