|
| 1 | +// |
| 2 | +// UIEventReceiverTests.swift |
| 3 | +// |
| 4 | +// |
| 5 | +// Created by Simon Stuart on 11/08/2022. |
| 6 | +// |
| 7 | + |
| 8 | +import XCTest |
| 9 | +import ThreadSafeSwift |
| 10 | +@testable import EventDrivenSwift |
| 11 | + |
| 12 | +final class UIEventReceiverTests: XCTestCase { |
| 13 | + struct TestEventTypeOne: Eventable { |
| 14 | + var foo: Int |
| 15 | + } |
| 16 | + |
| 17 | + class TestEventThread: UIEventReceiver { |
| 18 | + @ThreadSafeSemaphore var foo: Int = 0 |
| 19 | + |
| 20 | + internal func eventOneCallback(_ event: TestEventTypeOne, _ priority: EventPriority) { |
| 21 | + foo = event.foo |
| 22 | + } |
| 23 | + |
| 24 | + override func registerEventListeners() { |
| 25 | + addEventCallback(self.eventOneCallback, forEventType: TestEventTypeOne.self) |
| 26 | + } |
| 27 | + } |
| 28 | + |
| 29 | + let expectedTestOneFoo: Int = 1000 |
| 30 | + |
| 31 | + /// Need a reliable way of Unit Testing this! Anything I do to try to await a result causes this Execution Thread to lock, so the Callback won't occur until *after* the test returns! |
| 32 | + |
| 33 | +// func testEventDispatchQueueDirect() throws { |
| 34 | +// let testOne = TestEventTypeOne(foo: expectedTestOneFoo) // Create the Event |
| 35 | +// let eventThread = TestEventThread() // Create the Thread |
| 36 | +// |
| 37 | +// XCTAssertEqual(eventThread.foo, 0, "Expect initial value of eventThread.foo to be 0, but it's \(eventThread.foo)") |
| 38 | +// |
| 39 | +// eventThread.queueEvent(testOne, priority: .normal) // Now let's dispatch our Event to change this value |
| 40 | +// |
| 41 | +// let seconds = 1.0 |
| 42 | +// DispatchQueue.main.asyncAfter(deadline: .now() + seconds) { |
| 43 | +// XCTAssertEqual(eventThread.foo, testOne.foo, "Expect new value of eventThread.foo to be \(testOne.foo), but it's \(eventThread.foo)") |
| 44 | +// } |
| 45 | +// } |
| 46 | +// |
| 47 | +// func testEventDispatchQueueCentral() throws { |
| 48 | +// let testOne = TestEventTypeOne(foo: expectedTestOneFoo) // Create the Event |
| 49 | +// let eventThread = TestEventThread() // Create the Thread |
| 50 | +// |
| 51 | +// XCTAssertEqual(eventThread.foo, 0, "Expect initial value of eventThread.foo to be 0, but it's \(eventThread.foo)") |
| 52 | +// EventCentral.queueEvent(testOne, priority: .normal) // Now let's dispatch our Event to change this value |
| 53 | +// |
| 54 | +// let seconds = 1.0 |
| 55 | +// DispatchQueue.main.asyncAfter(deadline: .now() + seconds) { |
| 56 | +// XCTAssertEqual(eventThread.foo, testOne.foo, "Expect new value of eventThread.foo to be \(testOne.foo), but it's \(eventThread.foo)") |
| 57 | +// } |
| 58 | +// } |
| 59 | +// |
| 60 | +// func testEventDispatchQueueTransparent() throws { |
| 61 | +// let testOne = TestEventTypeOne(foo: expectedTestOneFoo) // Create the Event |
| 62 | +// let eventThread = TestEventThread() // Create the Thread |
| 63 | +// |
| 64 | +// XCTAssertEqual(eventThread.foo, 0, "Expect initial value of eventThread.foo to be 0, but it's \(eventThread.foo)") |
| 65 | +// |
| 66 | +// testOne.queue() // Now let's dispatch our Event to change this value |
| 67 | +// |
| 68 | +// let seconds = 1.0 |
| 69 | +// DispatchQueue.main.asyncAfter(deadline: .now() + seconds) { |
| 70 | +// XCTAssertEqual(eventThread.foo, testOne.foo, "Expect new value of eventThread.foo to be \(testOne.foo), but it's \(eventThread.foo)") |
| 71 | +// } |
| 72 | +// } |
| 73 | +// |
| 74 | +// func testEventDispatchStackDirect() throws { |
| 75 | +// let testOne = TestEventTypeOne(foo: expectedTestOneFoo) // Create the Event |
| 76 | +// let eventThread = TestEventThread() // Create the Thread |
| 77 | +// |
| 78 | +// XCTAssertEqual(eventThread.foo, 0, "Expect initial value of eventThread.foo to be 0, but it's \(eventThread.foo)") |
| 79 | +// |
| 80 | +// eventThread.stackEvent(testOne, priority: .normal) // Now let's dispatch our Event to change this value |
| 81 | +// |
| 82 | +// let seconds = 1.0 |
| 83 | +// DispatchQueue.main.asyncAfter(deadline: .now() + seconds) { |
| 84 | +// XCTAssertEqual(eventThread.foo, testOne.foo, "Expect new value of eventThread.foo to be \(testOne.foo), but it's \(eventThread.foo)") |
| 85 | +// } |
| 86 | +// } |
| 87 | +// |
| 88 | +// func testEventDispatchStackCentral() throws { |
| 89 | +// let testOne = TestEventTypeOne(foo: expectedTestOneFoo) // Create the Event |
| 90 | +// let eventThread = TestEventThread() // Create the Thread |
| 91 | +// |
| 92 | +// XCTAssertEqual(eventThread.foo, 0, "Expect initial value of eventThread.foo to be 0, but it's \(eventThread.foo)") |
| 93 | +// |
| 94 | +// EventCentral.stackEvent(testOne, priority: .normal) // Now let's dispatch our Event to change this value |
| 95 | +// |
| 96 | +// let seconds = 1.0 |
| 97 | +// DispatchQueue.main.asyncAfter(deadline: .now() + seconds) { |
| 98 | +// XCTAssertEqual(eventThread.foo, testOne.foo, "Expect new value of eventThread.foo to be \(testOne.foo), but it's \(eventThread.foo)") |
| 99 | +// } |
| 100 | +// } |
| 101 | +// |
| 102 | +// func testEventDispatchStackTransparent() throws { |
| 103 | +// let testOne = TestEventTypeOne(foo: expectedTestOneFoo) // Create the Event |
| 104 | +// let eventThread = TestEventThread() // Create the Thread |
| 105 | +// |
| 106 | +// XCTAssertEqual(eventThread.foo, 0, "Expect initial value of eventThread.foo to be 0, but it's \(eventThread.foo)") |
| 107 | +// |
| 108 | +// testOne.stack() // Now let's dispatch our Event to change this value |
| 109 | +// |
| 110 | +// let seconds = 1.0 |
| 111 | +// DispatchQueue.main.asyncAfter(deadline: .now() + seconds) { |
| 112 | +// XCTAssertEqual(eventThread.foo, testOne.foo, "Expect new value of eventThread.foo to be \(testOne.foo), but it's \(eventThread.foo)") |
| 113 | +// } |
| 114 | +// } |
| 115 | +} |
0 commit comments