From acfd2d42683dd316068f747fd312f5937dbe3dc0 Mon Sep 17 00:00:00 2001 From: Sho Ikeda Date: Thu, 10 Sep 2020 00:00:34 +0900 Subject: [PATCH] [BREAKING] Make `postNotifications` generic and usable with non-void closures --- Sources/Nimble/Matchers/PostNotification.swift | 16 ++++++++-------- .../Matchers/PostNotificationTest.swift | 8 +------- 2 files changed, 9 insertions(+), 15 deletions(-) diff --git a/Sources/Nimble/Matchers/PostNotification.swift b/Sources/Nimble/Matchers/PostNotification.swift index b491db18c..cf2018624 100644 --- a/Sources/Nimble/Matchers/PostNotification.swift +++ b/Sources/Nimble/Matchers/PostNotification.swift @@ -40,11 +40,11 @@ internal class NotificationCollector { private let mainThread = pthread_self() -private func _postNotifications( +private func _postNotifications( _ predicate: Predicate<[Notification]>, from center: NotificationCenter, names: Set = [] -) -> Predicate { +) -> Predicate { _ = mainThread // Force lazy-loading of this value let collector = NotificationCollector(notificationCenter: center, names: names) collector.startObserving() @@ -80,27 +80,27 @@ private func _postNotifications( } } -public func postNotifications( +public func postNotifications( _ predicate: Predicate<[Notification]>, from center: NotificationCenter = .default -) -> Predicate { +) -> Predicate { _postNotifications(predicate, from: center) } @available(*, deprecated, renamed: "postNotifications(_:from:)") -public func postNotifications( +public func postNotifications( _ predicate: Predicate<[Notification]>, fromNotificationCenter center: NotificationCenter -) -> Predicate { +) -> Predicate { postNotifications(predicate, from: center) } #if os(macOS) -public func postDistributedNotifications( +public func postDistributedNotifications( _ predicate: Predicate<[Notification]>, from center: DistributedNotificationCenter = .default(), names: Set -) -> Predicate { +) -> Predicate { _postNotifications(predicate, from: center, names: names) } #endif diff --git a/Tests/NimbleTests/Matchers/PostNotificationTest.swift b/Tests/NimbleTests/Matchers/PostNotificationTest.swift index 6e44dd2d0..b79c3cb75 100644 --- a/Tests/NimbleTests/Matchers/PostNotificationTest.swift +++ b/Tests/NimbleTests/Matchers/PostNotificationTest.swift @@ -8,7 +8,6 @@ final class PostNotificationTest: XCTestCase { func testPassesWhenNoNotificationsArePosted() { expect { // no notifications here! - return nil }.to(postNotifications(beEmpty())) } @@ -24,10 +23,9 @@ final class PostNotificationTest: XCTestCase { let bar = 2 as NSNumber let n1 = Notification(name: Notification.Name("Foo"), object: foo) let n2 = Notification(name: Notification.Name("Bar"), object: bar) - expect { + expect { () -> Void in self.notificationCenter.post(n1) self.notificationCenter.post(n2) - return nil }.to(postNotifications(equal([n1, n2]), from: notificationCenter)) } @@ -36,7 +34,6 @@ final class PostNotificationTest: XCTestCase { failsWithErrorMessage("expected to equal <[\(testNotification)]>, got no notifications") { expect { // no notifications here! - return nil }.to(postNotifications(equal([testNotification]), from: self.notificationCenter)) } } @@ -47,7 +44,6 @@ final class PostNotificationTest: XCTestCase { failsWithErrorMessage("expected to equal <[\(n1)]>, got <[\(n2)]>") { expect { self.notificationCenter.post(n2) - return nil }.to(postNotifications(equal([n1]), from: self.notificationCenter)) } } @@ -58,7 +54,6 @@ final class PostNotificationTest: XCTestCase { failsWithErrorMessage("expected to equal <[\(n1)]>, got <[\(n2)]>") { expect { self.notificationCenter.post(n2) - return nil }.to(postNotifications(equal([n1]), from: self.notificationCenter)) } } @@ -69,7 +64,6 @@ final class PostNotificationTest: XCTestCase { deferToMainQueue { self.notificationCenter.post(testNotification) } - return nil }.toEventually(postNotifications(equal([testNotification]), from: notificationCenter)) }