From ee009170fb0ebab8b4470099c6cf38541259c415 Mon Sep 17 00:00:00 2001 From: Michael Brown Date: Mon, 18 Mar 2024 16:26:29 +0000 Subject: [PATCH 1/7] Fix minor issues in Tests for Xcode 15.x --- Tests/ReactiveSwiftTests/DateSchedulerAsyncTestCase.swift | 2 +- Tests/ReactiveSwiftTests/SignalProducerNimbleMatchers.swift | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Tests/ReactiveSwiftTests/DateSchedulerAsyncTestCase.swift b/Tests/ReactiveSwiftTests/DateSchedulerAsyncTestCase.swift index 7c02cf271..7fca90495 100644 --- a/Tests/ReactiveSwiftTests/DateSchedulerAsyncTestCase.swift +++ b/Tests/ReactiveSwiftTests/DateSchedulerAsyncTestCase.swift @@ -86,7 +86,7 @@ final class DateSchedulerAsyncTestCase: XCTestCase { task.cancel() // cancel the timer - await waitForExpectations(timeout: 0.1) + await fulfillment(of: [expectation], timeout: 0.1) } } #endif diff --git a/Tests/ReactiveSwiftTests/SignalProducerNimbleMatchers.swift b/Tests/ReactiveSwiftTests/SignalProducerNimbleMatchers.swift index 4d4b70aac..7ba4262ad 100644 --- a/Tests/ReactiveSwiftTests/SignalProducerNimbleMatchers.swift +++ b/Tests/ReactiveSwiftTests/SignalProducerNimbleMatchers.swift @@ -11,11 +11,11 @@ import Foundation import ReactiveSwift import Nimble -public func sendValue(_ value: T?, sendError: E?, complete: Bool) -> Predicate> { +public func sendValue(_ value: T?, sendError: E?, complete: Bool) -> Nimble.Predicate> { return sendValues(value.map { [$0] } ?? [], sendError: sendError, complete: complete) } -public func sendValues(_ values: [T], sendError maybeSendError: E?, complete: Bool) -> Predicate> { +public func sendValues(_ values: [T], sendError maybeSendError: E?, complete: Bool) -> Nimble.Predicate> { return Predicate> { actualExpression in precondition(maybeSendError == nil || !complete, "Signals can't both send an error and complete") guard let signalProducer = try actualExpression.evaluate() else { From 8367745f44eac6c491157bb6d682c9764caf03fc Mon Sep 17 00:00:00 2001 From: Michael Brown Date: Mon, 18 Mar 2024 17:33:03 +0000 Subject: [PATCH 2/7] Update CI to use Xcode 15.2 and most recent GH action modules. Update podspec to declare support for Swift 5.8 and 5.9 --- .github/workflows/master.yml | 29 +++++++++++++---------------- .github/workflows/test.yml | 12 ++++++------ ReactiveSwift.podspec | 2 +- 3 files changed, 20 insertions(+), 23 deletions(-) diff --git a/.github/workflows/master.yml b/.github/workflows/master.yml index bb6e643a3..2ff991425 100644 --- a/.github/workflows/master.yml +++ b/.github/workflows/master.yml @@ -11,22 +11,19 @@ on: - master env: - # Keep using Xcode 13 until CP releases the fix for watchOS verification on Xcode 14 - # https://github.com/CocoaPods/CocoaPods/issues/11558 - # https://github.com/CocoaPods/CocoaPods/pull/11660 - DEVELOPER_DIR: /Applications/Xcode_13.4.1.app/Contents/Developer + DEVELOPER_DIR: /Applications/Xcode_15.2.app/Contents/Developer name: Verification | Release jobs: carthage: if: ${{ github.event_name == 'push' || ( github.event_name == 'pull_request' && github.event.label.name == 'ci:verify' ) }} name: Carthage Verification - runs-on: macos-12 + runs-on: macos-14 steps: - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 - name: Recover cached dependencies - uses: actions/cache@v1 + uses: actions/cache@v2 id: dependency-cache with: path: ~/Library/Caches/org.carthage.CarthageKit @@ -39,10 +36,10 @@ jobs: swiftpm-macos: if: ${{ github.event_name == 'push' || ( github.event_name == 'pull_request' && github.event.label.name == 'ci:verify' ) }} name: SwiftPM macOS Verification - runs-on: macos-12 + runs-on: macos-14 steps: - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 - name: Pull dependencies run: | swift package resolve @@ -54,10 +51,10 @@ jobs: cocoapods: if: ${{ github.event_name == 'push' || ( github.event_name == 'pull_request' && github.event.label.name == 'ci:verify' ) }} name: CocoaPods Verification - runs-on: macos-12 + runs-on: macos-14 steps: - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 - name: CocoaPods verification run: | pod repo update @@ -66,22 +63,22 @@ jobs: release-github: if: ${{ github.event_name == 'push' && github.ref_type == 'tag' }} name: GitHub Release - runs-on: macos-12 + runs-on: macos-14 needs: [swiftpm-macos, cocoapods, carthage] steps: - name: git checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 - name: create release - uses: softprops/action-gh-release@v1 + uses: softprops/action-gh-release@v2 release-cocoapods: if: ${{ github.event_name == 'push' && github.ref_type == 'tag' }} name: CocoaPods Release - runs-on: macos-12 + runs-on: macos-14 needs: [swiftpm-macos, cocoapods, carthage] steps: - name: git checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 - name: pod trunk push env: COCOAPODS_TRUNK_TOKEN: ${{ secrets.COCOAPODS_TRUNK_TOKEN }} diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index e14a8ab8e..3fcf36d51 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -3,18 +3,18 @@ name: Test jobs: test: name: Test - runs-on: macos-12 + runs-on: macos-14 strategy: fail-fast: false matrix: destination: [macOS, iOS, tvOS, watchOS] env: - DEVELOPER_DIR: /Applications/Xcode_14.1.app/Contents/Developer + DEVELOPER_DIR: /Applications/Xcode_15.2.app/Contents/Developer steps: - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 - name: Recover cached dependencies - uses: actions/cache@v1 + uses: actions/cache@v4 id: dependency-cache with: path: Carthage/Checkouts @@ -74,11 +74,11 @@ jobs: runs-on: ubuntu-22.04 steps: - name: Setup Swift version - uses: swift-actions/setup-swift@v1 + uses: swift-actions/setup-swift@v2 with: swift-version: ${{ matrix.swift }} - name: Checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 - name: Pull dependencies run: | swift package resolve diff --git a/ReactiveSwift.podspec b/ReactiveSwift.podspec index 7eaa108a6..bf24fdfa2 100644 --- a/ReactiveSwift.podspec +++ b/ReactiveSwift.podspec @@ -25,5 +25,5 @@ Pod::Spec.new do |s| } s.cocoapods_version = ">= 1.7.0" - s.swift_versions = ["5.2", "5.3" "5.4", "5.5", "5.6", "5.7"] + s.swift_versions = ["5.2", "5.3" "5.4", "5.5", "5.6", "5.7", "5.8", "5.9"] end From 858d2483a93fbb9becbe036725671bb850d5d8c1 Mon Sep 17 00:00:00 2001 From: Michael Brown Date: Tue, 19 Mar 2024 11:02:54 +0000 Subject: [PATCH 3/7] Update Quick and Nimble to latest versions. --- Cartfile.private | 4 ++-- Cartfile.resolved | 4 ++-- Carthage/Checkouts/Nimble | 2 +- Carthage/Checkouts/Quick | 2 +- Package.resolved | 16 ++++++++-------- Package.swift | 4 ++-- Tests/ReactiveSwiftTests/ActionSpec.swift | 2 +- Tests/ReactiveSwiftTests/AtomicSpec.swift | 2 +- Tests/ReactiveSwiftTests/BagSpec.swift | 2 +- .../DateSchedulerAsyncTestCase.swift | 6 +++++- Tests/ReactiveSwiftTests/DeprecationSpec.swift | 2 +- Tests/ReactiveSwiftTests/DisposableSpec.swift | 2 +- Tests/ReactiveSwiftTests/FlattenSpec.swift | 2 +- .../FoundationExtensionsSpec.swift | 2 +- Tests/ReactiveSwiftTests/LifetimeSpec.swift | 2 +- Tests/ReactiveSwiftTests/PropertySpec.swift | 2 +- .../ReactiveExtensionsSpec.swift | 2 +- Tests/ReactiveSwiftTests/SchedulerSpec.swift | 2 +- .../ReactiveSwiftTests/SignalLifetimeSpec.swift | 2 +- .../SignalProducerLiftingSpec.swift | 2 +- .../SignalProducerNimbleMatchers.swift | 14 +++++++------- .../ReactiveSwiftTests/SignalProducerSpec.swift | 8 ++++---- Tests/ReactiveSwiftTests/SignalSpec.swift | 2 +- .../UnidirectionalBindingSpec.swift | 2 +- .../ValidatingPropertySpec.swift | 2 +- 25 files changed, 48 insertions(+), 44 deletions(-) diff --git a/Cartfile.private b/Cartfile.private index 760240fd4..ef0f247fd 100644 --- a/Cartfile.private +++ b/Cartfile.private @@ -1,3 +1,3 @@ github "xcconfigs/xcconfigs" ~> 1.1 -github "Quick/Quick" ~> 4.0.0 -github "Quick/Nimble" ~> 9.0.0 +github "Quick/Quick" ~> 7.0.0 +github "Quick/Nimble" ~> 13.0.0 diff --git a/Cartfile.resolved b/Cartfile.resolved index bbd8eb5be..f8f62dc73 100644 --- a/Cartfile.resolved +++ b/Cartfile.resolved @@ -1,3 +1,3 @@ -github "Quick/Nimble" "v9.2.1" -github "Quick/Quick" "v4.0.0" +github "Quick/Nimble" "v13.2.1" +github "Quick/Quick" "v7.4.1" github "xcconfigs/xcconfigs" "1.1" diff --git a/Carthage/Checkouts/Nimble b/Carthage/Checkouts/Nimble index c93f16c25..efe11bbca 160000 --- a/Carthage/Checkouts/Nimble +++ b/Carthage/Checkouts/Nimble @@ -1 +1 @@ -Subproject commit c93f16c25af5770f0d3e6af27c9634640946b068 +Subproject commit efe11bbca024b57115260709b5c05e01131470d0 diff --git a/Carthage/Checkouts/Quick b/Carthage/Checkouts/Quick index bd86ca014..6d01974d2 160000 --- a/Carthage/Checkouts/Quick +++ b/Carthage/Checkouts/Quick @@ -1 +1 @@ -Subproject commit bd86ca0141e3cfb333546de5a11ede63f0c4a0e6 +Subproject commit 6d01974d236f598633cac58280372c0c8cfea5bc diff --git a/Package.resolved b/Package.resolved index f99c90046..653bc4e47 100644 --- a/Package.resolved +++ b/Package.resolved @@ -6,8 +6,8 @@ "repositoryURL": "https://github.com/mattgallagher/CwlCatchException.git", "state": { "branch": null, - "revision": "682841464136f8c66e04afe5dbd01ab51a3a56f2", - "version": "2.1.0" + "revision": "3ef6999c73b6938cc0da422f2c912d0158abb0a0", + "version": "2.2.0" } }, { @@ -15,8 +15,8 @@ "repositoryURL": "https://github.com/mattgallagher/CwlPreconditionTesting.git", "state": { "branch": null, - "revision": "02b7a39a99c4da27abe03cab2053a9034379639f", - "version": "2.0.0" + "revision": "2ef56b2caf25f55fa7eef8784c30d5a767550f54", + "version": "2.2.1" } }, { @@ -24,8 +24,8 @@ "repositoryURL": "https://github.com/Quick/Nimble.git", "state": { "branch": null, - "revision": "af1730dde4e6c0d45bf01b99f8a41713ce536790", - "version": "9.2.0" + "revision": "efe11bbca024b57115260709b5c05e01131470d0", + "version": "13.2.1" } }, { @@ -33,8 +33,8 @@ "repositoryURL": "https://github.com/Quick/Quick.git", "state": { "branch": null, - "revision": "bd86ca0141e3cfb333546de5a11ede63f0c4a0e6", - "version": "4.0.0" + "revision": "6d01974d236f598633cac58280372c0c8cfea5bc", + "version": "7.4.1" } } ] diff --git a/Package.swift b/Package.swift index 1d695a46d..8aa431c33 100644 --- a/Package.swift +++ b/Package.swift @@ -10,8 +10,8 @@ let package = Package( .library(name: "ReactiveSwift", targets: ["ReactiveSwift"]), ], dependencies: [ - .package(url: "https://github.com/Quick/Quick.git", from: "4.0.0"), - .package(url: "https://github.com/Quick/Nimble.git", from: "9.0.0"), + .package(url: "https://github.com/Quick/Quick.git", from: "7.0.0"), + .package(url: "https://github.com/Quick/Nimble.git", from: "13.0.0"), ], targets: [ .target(name: "ReactiveSwift", dependencies: [], path: "Sources"), diff --git a/Tests/ReactiveSwiftTests/ActionSpec.swift b/Tests/ReactiveSwiftTests/ActionSpec.swift index e183a2073..e00c0d517 100755 --- a/Tests/ReactiveSwiftTests/ActionSpec.swift +++ b/Tests/ReactiveSwiftTests/ActionSpec.swift @@ -13,7 +13,7 @@ import Quick @testable import ReactiveSwift class ActionSpec: QuickSpec { - override func spec() { + override class func spec() { describe("Action") { var action: Action! var enabled: MutableProperty! diff --git a/Tests/ReactiveSwiftTests/AtomicSpec.swift b/Tests/ReactiveSwiftTests/AtomicSpec.swift index 8234f5b9f..0f07b7a71 100644 --- a/Tests/ReactiveSwiftTests/AtomicSpec.swift +++ b/Tests/ReactiveSwiftTests/AtomicSpec.swift @@ -11,7 +11,7 @@ import Quick import ReactiveSwift class AtomicSpec: QuickSpec { - override func spec() { + override class func spec() { var atomic: Atomic! beforeEach { diff --git a/Tests/ReactiveSwiftTests/BagSpec.swift b/Tests/ReactiveSwiftTests/BagSpec.swift index 665f8acb0..364a0f29c 100644 --- a/Tests/ReactiveSwiftTests/BagSpec.swift +++ b/Tests/ReactiveSwiftTests/BagSpec.swift @@ -11,7 +11,7 @@ import Quick import ReactiveSwift class BagSpec: QuickSpec { - override func spec() { + override class func spec() { var bag = Bag() beforeEach { diff --git a/Tests/ReactiveSwiftTests/DateSchedulerAsyncTestCase.swift b/Tests/ReactiveSwiftTests/DateSchedulerAsyncTestCase.swift index 7fca90495..bd5843001 100644 --- a/Tests/ReactiveSwiftTests/DateSchedulerAsyncTestCase.swift +++ b/Tests/ReactiveSwiftTests/DateSchedulerAsyncTestCase.swift @@ -86,7 +86,11 @@ final class DateSchedulerAsyncTestCase: XCTestCase { task.cancel() // cancel the timer - await fulfillment(of: [expectation], timeout: 0.1) + #if swift(>=5.8) + await fulfillment(of: [expectation], timeout: 0.1) + #else + await waitForExpectations(timeout: 0.1) + #endif } } #endif diff --git a/Tests/ReactiveSwiftTests/DeprecationSpec.swift b/Tests/ReactiveSwiftTests/DeprecationSpec.swift index 370ac3467..1a5418582 100644 --- a/Tests/ReactiveSwiftTests/DeprecationSpec.swift +++ b/Tests/ReactiveSwiftTests/DeprecationSpec.swift @@ -3,5 +3,5 @@ import Nimble import ReactiveSwift class DeprecationSpec: QuickSpec { - override func spec() {} + override class func spec() {} } diff --git a/Tests/ReactiveSwiftTests/DisposableSpec.swift b/Tests/ReactiveSwiftTests/DisposableSpec.swift index 8a62b2322..1d4c5820e 100644 --- a/Tests/ReactiveSwiftTests/DisposableSpec.swift +++ b/Tests/ReactiveSwiftTests/DisposableSpec.swift @@ -11,7 +11,7 @@ import Quick import ReactiveSwift class DisposableSpec: QuickSpec { - override func spec() { + override class func spec() { describe("SimpleDisposable") { it("should set disposed to true") { let disposable = AnyDisposable() diff --git a/Tests/ReactiveSwiftTests/FlattenSpec.swift b/Tests/ReactiveSwiftTests/FlattenSpec.swift index 873603077..722bd4fee 100644 --- a/Tests/ReactiveSwiftTests/FlattenSpec.swift +++ b/Tests/ReactiveSwiftTests/FlattenSpec.swift @@ -18,7 +18,7 @@ private extension Signal { private typealias Pipe = Signal, TestError>.Pipe class FlattenSpec: QuickSpec { - override func spec() { + override class func spec() { func describeSignalFlattenDisposal(_ flattenStrategy: FlattenStrategy, name: String) { describe(name) { var pipe: Pipe! diff --git a/Tests/ReactiveSwiftTests/FoundationExtensionsSpec.swift b/Tests/ReactiveSwiftTests/FoundationExtensionsSpec.swift index 032bfe28c..3c12506c9 100644 --- a/Tests/ReactiveSwiftTests/FoundationExtensionsSpec.swift +++ b/Tests/ReactiveSwiftTests/FoundationExtensionsSpec.swift @@ -18,7 +18,7 @@ extension Notification.Name { } class FoundationExtensionsSpec: QuickSpec { - override func spec() { + override class func spec() { describe("NotificationCenter.reactive.notifications") { let center = NotificationCenter.default diff --git a/Tests/ReactiveSwiftTests/LifetimeSpec.swift b/Tests/ReactiveSwiftTests/LifetimeSpec.swift index 3b2f40152..892983cff 100644 --- a/Tests/ReactiveSwiftTests/LifetimeSpec.swift +++ b/Tests/ReactiveSwiftTests/LifetimeSpec.swift @@ -3,7 +3,7 @@ import Nimble import ReactiveSwift final class LifetimeSpec: QuickSpec { - override func spec() { + override class func spec() { describe("Lifetime") { it("should complete its lifetime ended signal when the token deinitializes") { let object = MutableReference(TestObject()) diff --git a/Tests/ReactiveSwiftTests/PropertySpec.swift b/Tests/ReactiveSwiftTests/PropertySpec.swift index 8436fec8c..ed3419667 100644 --- a/Tests/ReactiveSwiftTests/PropertySpec.swift +++ b/Tests/ReactiveSwiftTests/PropertySpec.swift @@ -21,7 +21,7 @@ private let subsequentOtherPropertyValue = "SubsequentOtherValue" private let finalOtherPropertyValue = "FinalOtherValue" class PropertySpec: QuickSpec { - override func spec() { + override class func spec() { describe("MutableProperty") { it("should have the value given at initialization") { let mutableProperty = MutableProperty(initialPropertyValue) diff --git a/Tests/ReactiveSwiftTests/ReactiveExtensionsSpec.swift b/Tests/ReactiveSwiftTests/ReactiveExtensionsSpec.swift index 39d6b4e5d..11cc9bf9c 100644 --- a/Tests/ReactiveSwiftTests/ReactiveExtensionsSpec.swift +++ b/Tests/ReactiveSwiftTests/ReactiveExtensionsSpec.swift @@ -18,7 +18,7 @@ extension Reactive where Base: TestExtensionProvider { } final class ReactiveExtensionsSpec: QuickSpec { - override func spec() { + override class func spec() { describe("ReactiveExtensions") { it("allows reactive extensions of instances") { expect(TestExtensionProvider().reactive.instanceProperty.first()?.value) == "instance" diff --git a/Tests/ReactiveSwiftTests/SchedulerSpec.swift b/Tests/ReactiveSwiftTests/SchedulerSpec.swift index 2e704f125..10f9f7da9 100644 --- a/Tests/ReactiveSwiftTests/SchedulerSpec.swift +++ b/Tests/ReactiveSwiftTests/SchedulerSpec.swift @@ -26,7 +26,7 @@ import ReactiveSwift #endif class SchedulerSpec: QuickSpec { - override func spec() { + override class func spec() { describe("ImmediateScheduler") { it("should run enqueued actions immediately") { var didRun = false diff --git a/Tests/ReactiveSwiftTests/SignalLifetimeSpec.swift b/Tests/ReactiveSwiftTests/SignalLifetimeSpec.swift index 14a53203d..bf8478317 100644 --- a/Tests/ReactiveSwiftTests/SignalLifetimeSpec.swift +++ b/Tests/ReactiveSwiftTests/SignalLifetimeSpec.swift @@ -13,7 +13,7 @@ import Quick import ReactiveSwift class SignalLifetimeSpec: QuickSpec { - override func spec() { + override class func spec() { describe("init") { var testScheduler: TestScheduler! diff --git a/Tests/ReactiveSwiftTests/SignalProducerLiftingSpec.swift b/Tests/ReactiveSwiftTests/SignalProducerLiftingSpec.swift index 1e1fe0327..4a9325128 100644 --- a/Tests/ReactiveSwiftTests/SignalProducerLiftingSpec.swift +++ b/Tests/ReactiveSwiftTests/SignalProducerLiftingSpec.swift @@ -14,7 +14,7 @@ import Quick @testable import ReactiveSwift class SignalProducerLiftingSpec: QuickSpec { - override func spec() { + override class func spec() { describe("map") { it("should transform the values of the signal") { let (producer, observer) = SignalProducer.pipe() diff --git a/Tests/ReactiveSwiftTests/SignalProducerNimbleMatchers.swift b/Tests/ReactiveSwiftTests/SignalProducerNimbleMatchers.swift index 7ba4262ad..1fffa7859 100644 --- a/Tests/ReactiveSwiftTests/SignalProducerNimbleMatchers.swift +++ b/Tests/ReactiveSwiftTests/SignalProducerNimbleMatchers.swift @@ -11,17 +11,17 @@ import Foundation import ReactiveSwift import Nimble -public func sendValue(_ value: T?, sendError: E?, complete: Bool) -> Nimble.Predicate> { +public func sendValue(_ value: T?, sendError: E?, complete: Bool) -> Matcher> { return sendValues(value.map { [$0] } ?? [], sendError: sendError, complete: complete) } -public func sendValues(_ values: [T], sendError maybeSendError: E?, complete: Bool) -> Nimble.Predicate> { - return Predicate> { actualExpression in +public func sendValues(_ values: [T], sendError maybeSendError: E?, complete: Bool) -> Matcher> { + return Matcher> { actualExpression in precondition(maybeSendError == nil || !complete, "Signals can't both send an error and complete") guard let signalProducer = try actualExpression.evaluate() else { let message = ExpectationMessage.fail("The SignalProducer was not created.") .appendedBeNilHint() - return PredicateResult(status: .fail, message: message) + return MatcherResult(status: .fail, message: message) } var sentValues: [T] = [] @@ -46,7 +46,7 @@ public func sendValues(_ values: [T], sendError mayb "send values <\(values)>", actual: "<\(sentValues)>" ) - return PredicateResult(status: .doesNotMatch, message: message) + return MatcherResult(status: .doesNotMatch, message: message) } if sentError != maybeSendError { @@ -54,13 +54,13 @@ public func sendValues(_ values: [T], sendError mayb "send error <\(String(describing: maybeSendError))>", actual: "<\(String(describing: sentError))>" ) - return PredicateResult(status: .doesNotMatch, message: message) + return MatcherResult(status: .doesNotMatch, message: message) } let completeMessage = complete ? "complete, but the producer did not complete" : "not to complete, but the producer completed" let message = ExpectationMessage.expectedTo(completeMessage) - return PredicateResult(bool: signalCompleted == complete, message: message) + return MatcherResult(bool: signalCompleted == complete, message: message) } } diff --git a/Tests/ReactiveSwiftTests/SignalProducerSpec.swift b/Tests/ReactiveSwiftTests/SignalProducerSpec.swift index a8d926b76..29ff7c1d0 100644 --- a/Tests/ReactiveSwiftTests/SignalProducerSpec.swift +++ b/Tests/ReactiveSwiftTests/SignalProducerSpec.swift @@ -14,7 +14,7 @@ import Quick @testable import ReactiveSwift class SignalProducerSpec: QuickSpec { - override func spec() { + override class func spec() { describe("init") { it("should run the handler once per start()") { var handlerCalledTimes = 0 @@ -3832,9 +3832,9 @@ class SignalProducerSpec: QuickSpec { // MARK: - Helpers -private func == (left: Expectation, right: Any.Type) { - left.to(Predicate { expression in - PredicateResult( +private func == (left: SyncExpectation, right: Any.Type) { + left.to(Matcher { expression in + MatcherResult( bool: try expression.evaluate()! == right, message: ExpectationMessage.expectedActualValueTo("equal to") ) diff --git a/Tests/ReactiveSwiftTests/SignalSpec.swift b/Tests/ReactiveSwiftTests/SignalSpec.swift index 49bfdce0b..c4c416c66 100755 --- a/Tests/ReactiveSwiftTests/SignalSpec.swift +++ b/Tests/ReactiveSwiftTests/SignalSpec.swift @@ -14,7 +14,7 @@ import Quick @testable import ReactiveSwift class SignalSpec: QuickSpec { - override func spec() { + override class func spec() { describe("init") { var testScheduler: TestScheduler! diff --git a/Tests/ReactiveSwiftTests/UnidirectionalBindingSpec.swift b/Tests/ReactiveSwiftTests/UnidirectionalBindingSpec.swift index ffe80d788..8a868d5d5 100644 --- a/Tests/ReactiveSwiftTests/UnidirectionalBindingSpec.swift +++ b/Tests/ReactiveSwiftTests/UnidirectionalBindingSpec.swift @@ -9,7 +9,7 @@ private class Object { } class UnidirectionalBindingSpec: QuickSpec { - override func spec() { + override class func spec() { describe("BindingTarget") { var token: Lifetime.Token! var lifetime: Lifetime! diff --git a/Tests/ReactiveSwiftTests/ValidatingPropertySpec.swift b/Tests/ReactiveSwiftTests/ValidatingPropertySpec.swift index 86e190930..89bf966bb 100644 --- a/Tests/ReactiveSwiftTests/ValidatingPropertySpec.swift +++ b/Tests/ReactiveSwiftTests/ValidatingPropertySpec.swift @@ -3,7 +3,7 @@ import Nimble import ReactiveSwift class ValidatingPropertySpec: QuickSpec { - override func spec() { + override class func spec() { describe("ValidatingProperty") { describe("no dependency") { var root: MutableProperty! From 715c33938ce9162f47576fe143541423df461584 Mon Sep 17 00:00:00 2001 From: Michael Brown Date: Tue, 19 Mar 2024 14:28:36 +0000 Subject: [PATCH 4/7] Update Xcode schemes and minimum OS targets. --- .github/workflows/test.yml | 1 - ReactiveSwift.xcodeproj/project.pbxproj | 36 ++++++++++++++++--- .../xcschemes/ReactiveSwift-iOS.xcscheme | 25 +++++++------ .../xcschemes/ReactiveSwift-macOS.xcscheme | 4 +-- .../xcschemes/ReactiveSwift-tvOS.xcscheme | 25 +++++++------ 5 files changed, 64 insertions(+), 27 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 3fcf36d51..99466058d 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -39,7 +39,6 @@ jobs: SCHEME=ReactiveSwift-tvOS ;; "watchOS") - ACTION=build DESTINATION="platform=watchOS Simulator,name=Apple Watch Series 5 (44mm)" SCHEME=ReactiveSwift-watchOS ;; diff --git a/ReactiveSwift.xcodeproj/project.pbxproj b/ReactiveSwift.xcodeproj/project.pbxproj index 9f91d30ab..7437ac5e6 100644 --- a/ReactiveSwift.xcodeproj/project.pbxproj +++ b/ReactiveSwift.xcodeproj/project.pbxproj @@ -1492,6 +1492,7 @@ "DTRACE_PROBES_DISABLED=1", ); INFOPLIST_FILE = Sources/Info.plist; + TVOS_DEPLOYMENT_TARGET = 12.0; }; name = Debug; }; @@ -1506,6 +1507,7 @@ "DTRACE_PROBES_DISABLED=1", ); INFOPLIST_FILE = Sources/Info.plist; + TVOS_DEPLOYMENT_TARGET = 12.0; }; name = Test; }; @@ -1520,6 +1522,7 @@ "DTRACE_PROBES_DISABLED=1", ); INFOPLIST_FILE = Sources/Info.plist; + TVOS_DEPLOYMENT_TARGET = 12.0; }; name = Release; }; @@ -1534,6 +1537,7 @@ "DTRACE_PROBES_DISABLED=1", ); INFOPLIST_FILE = Sources/Info.plist; + TVOS_DEPLOYMENT_TARGET = 12.0; }; name = Profile; }; @@ -1599,6 +1603,7 @@ ); INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; + TVOS_DEPLOYMENT_TARGET = 12.0; }; name = Debug; }; @@ -1612,6 +1617,7 @@ ); INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; + TVOS_DEPLOYMENT_TARGET = 12.0; }; name = Test; }; @@ -1625,6 +1631,7 @@ ); INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; + TVOS_DEPLOYMENT_TARGET = 12.0; }; name = Release; }; @@ -1638,6 +1645,7 @@ ); INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; + TVOS_DEPLOYMENT_TARGET = 12.0; }; name = Profile; }; @@ -1652,6 +1660,8 @@ "DTRACE_PROBES_DISABLED=1", ); INFOPLIST_FILE = Sources/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; + WATCHOS_DEPLOYMENT_TARGET = 4.0; }; name = Debug; }; @@ -1666,6 +1676,8 @@ "DTRACE_PROBES_DISABLED=1", ); INFOPLIST_FILE = Sources/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; + WATCHOS_DEPLOYMENT_TARGET = 4.0; }; name = Test; }; @@ -1680,6 +1692,8 @@ "DTRACE_PROBES_DISABLED=1", ); INFOPLIST_FILE = Sources/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; + WATCHOS_DEPLOYMENT_TARGET = 4.0; }; name = Release; }; @@ -1694,6 +1708,8 @@ "DTRACE_PROBES_DISABLED=1", ); INFOPLIST_FILE = Sources/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; + WATCHOS_DEPLOYMENT_TARGET = 4.0; }; name = Profile; }; @@ -1748,6 +1764,7 @@ DYLIB_CURRENT_VERSION = 1; FRAMEWORK_VERSION = A; INFOPLIST_FILE = Sources/Info.plist; + MACOSX_DEPLOYMENT_TARGET = 10.13; SUPPORTS_MACCATALYST = YES; }; name = Debug; @@ -1760,6 +1777,7 @@ DYLIB_CURRENT_VERSION = 1; FRAMEWORK_VERSION = A; INFOPLIST_FILE = Sources/Info.plist; + MACOSX_DEPLOYMENT_TARGET = 10.13; SUPPORTS_MACCATALYST = YES; }; name = Release; @@ -1769,7 +1787,7 @@ baseConfigurationReference = E6124BA9267DF505005A3490 /* macOS-XCTest.xcconfig */; buildSettings = { INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; - MACOSX_DEPLOYMENT_TARGET = 10.12; + MACOSX_DEPLOYMENT_TARGET = 10.13; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; }; name = Debug; @@ -1779,7 +1797,7 @@ baseConfigurationReference = E6124BA9267DF505005A3490 /* macOS-XCTest.xcconfig */; buildSettings = { INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; - MACOSX_DEPLOYMENT_TARGET = 10.12; + MACOSX_DEPLOYMENT_TARGET = 10.13; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; }; name = Release; @@ -1791,6 +1809,7 @@ DYLIB_COMPATIBILITY_VERSION = 1; DYLIB_CURRENT_VERSION = 1; INFOPLIST_FILE = Sources/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; }; name = Debug; }; @@ -1801,6 +1820,7 @@ DYLIB_COMPATIBILITY_VERSION = 1; DYLIB_CURRENT_VERSION = 1; INFOPLIST_FILE = Sources/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; }; name = Release; }; @@ -1809,6 +1829,7 @@ baseConfigurationReference = D047263219E49FE8006002AA /* iOS-Application.xcconfig */; buildSettings = { INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; }; name = Debug; @@ -1818,6 +1839,7 @@ baseConfigurationReference = D047263219E49FE8006002AA /* iOS-Application.xcconfig */; buildSettings = { INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; }; name = Release; @@ -1851,6 +1873,7 @@ DYLIB_CURRENT_VERSION = 1; FRAMEWORK_VERSION = A; INFOPLIST_FILE = Sources/Info.plist; + MACOSX_DEPLOYMENT_TARGET = 10.13; SUPPORTS_MACCATALYST = YES; }; name = Profile; @@ -1860,7 +1883,7 @@ baseConfigurationReference = E6124BA9267DF505005A3490 /* macOS-XCTest.xcconfig */; buildSettings = { INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; - MACOSX_DEPLOYMENT_TARGET = 10.10; + MACOSX_DEPLOYMENT_TARGET = 10.13; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; }; name = Profile; @@ -1872,6 +1895,7 @@ DYLIB_COMPATIBILITY_VERSION = 1; DYLIB_CURRENT_VERSION = 1; INFOPLIST_FILE = Sources/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; }; name = Profile; }; @@ -1880,6 +1904,7 @@ baseConfigurationReference = D047263219E49FE8006002AA /* iOS-Application.xcconfig */; buildSettings = { INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; }; name = Profile; @@ -1913,6 +1938,7 @@ DYLIB_CURRENT_VERSION = 1; FRAMEWORK_VERSION = A; INFOPLIST_FILE = Sources/Info.plist; + MACOSX_DEPLOYMENT_TARGET = 10.13; SUPPORTS_MACCATALYST = YES; }; name = Test; @@ -1922,7 +1948,7 @@ baseConfigurationReference = E6124BA9267DF505005A3490 /* macOS-XCTest.xcconfig */; buildSettings = { INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; - MACOSX_DEPLOYMENT_TARGET = 10.10; + MACOSX_DEPLOYMENT_TARGET = 10.13; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; }; name = Test; @@ -1934,6 +1960,7 @@ DYLIB_COMPATIBILITY_VERSION = 1; DYLIB_CURRENT_VERSION = 1; INFOPLIST_FILE = Sources/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; }; name = Test; }; @@ -1942,6 +1969,7 @@ baseConfigurationReference = D047263219E49FE8006002AA /* iOS-Application.xcconfig */; buildSettings = { INFOPLIST_FILE = Tests/ReactiveSwiftTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; PRODUCT_NAME = "$(PROJECT_NAME)Tests"; }; name = Test; diff --git a/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-iOS.xcscheme b/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-iOS.xcscheme index 867a3c291..135cf3431 100644 --- a/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-iOS.xcscheme +++ b/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-iOS.xcscheme @@ -28,9 +28,9 @@ buildForAnalyzing = "NO"> @@ -42,9 +42,9 @@ buildForAnalyzing = "NO"> @@ -68,8 +68,8 @@ buildConfiguration = "Debug" selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" - codeCoverageEnabled = "YES" - shouldUseLaunchSchemeArgsEnv = "YES"> + shouldUseLaunchSchemeArgsEnv = "YES" + codeCoverageEnabled = "YES"> - - - - + + + + diff --git a/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-macOS.xcscheme b/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-macOS.xcscheme index 0c3e486a0..db6e1f685 100644 --- a/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-macOS.xcscheme +++ b/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-macOS.xcscheme @@ -30,7 +30,7 @@ BuildableIdentifier = "primary" BlueprintIdentifier = "1F925EAC195C0D6300ED456B" BuildableName = "Nimble.framework" - BlueprintName = "Nimble-macOS" + BlueprintName = "Nimble" ReferencedContainer = "container:Carthage/Checkouts/Nimble/Nimble.xcodeproj"> @@ -44,7 +44,7 @@ BuildableIdentifier = "primary" BlueprintIdentifier = "DAEB6B8D1943873100289F44" BuildableName = "Quick.framework" - BlueprintName = "Quick-macOS" + BlueprintName = "Quick" ReferencedContainer = "container:Carthage/Checkouts/Quick/Quick.xcodeproj"> diff --git a/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-tvOS.xcscheme b/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-tvOS.xcscheme index b90c8d3de..c4c4f2fc6 100644 --- a/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-tvOS.xcscheme +++ b/ReactiveSwift.xcodeproj/xcshareddata/xcschemes/ReactiveSwift-tvOS.xcscheme @@ -28,9 +28,9 @@ buildForAnalyzing = "NO"> @@ -42,9 +42,9 @@ buildForAnalyzing = "NO"> @@ -68,8 +68,8 @@ buildConfiguration = "Debug" selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB" selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB" - codeCoverageEnabled = "YES" - shouldUseLaunchSchemeArgsEnv = "YES"> + shouldUseLaunchSchemeArgsEnv = "YES" + codeCoverageEnabled = "YES"> - - - - + + + + From 7b0669c10933ffa9801b4dee108cd527530fcbda Mon Sep 17 00:00:00 2001 From: Michael Brown Date: Tue, 19 Mar 2024 14:41:02 +0000 Subject: [PATCH 5/7] Update iPhone device for testing. --- .github/workflows/test.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 99466058d..15b65dabf 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -31,7 +31,7 @@ jobs: case "${{ matrix.destination }}" in "iOS") - DESTINATION="platform=iOS Simulator,name=iPhone 11 Pro" + DESTINATION="platform=iOS Simulator,name=iPhone 14 Pro" SCHEME=ReactiveSwift-iOS ;; "tvOS") @@ -39,6 +39,7 @@ jobs: SCHEME=ReactiveSwift-tvOS ;; "watchOS") + ACTION=build DESTINATION="platform=watchOS Simulator,name=Apple Watch Series 5 (44mm)" SCHEME=ReactiveSwift-watchOS ;; From 1d671572c75db8b080c9c81317e597328d4e9522 Mon Sep 17 00:00:00 2001 From: Michael Brown Date: Tue, 19 Mar 2024 15:47:45 +0000 Subject: [PATCH 6/7] Updated CHANGELOG and podspec. --- CHANGELOG.md | 10 +++++----- ReactiveSwift.podspec | 4 ++-- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index b6fbd3cb2..931905005 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,12 +1,12 @@ # master *Please add new entries at the top.* -1. Change `QueueScheduler` to use unspecified QoS when QoS parameter is defaulted -1. Add support for VisionOS (#875, kudos to @NachoSoto) -1. Fix minimum deployment target of iOS 11 in CocoaPods +1. Change `QueueScheduler` to use unspecified QoS when QoS parameter is defaulted (#880, kudos to @jamieQ) +1. Add support for visionOS (#875, kudos to @NachoSoto) 1. Fix CI release git tag push trigger (#869, kudos to @p4checo) -1. Find and remove items from Bag using a binary search to improve performance when the collection gets large. -2. Add extension to `ScopedDisposable` for inner `SerialDisposable` (#873, kudos to @sirnacnud) +1. Find and remove items from Bag using a binary search to improve performance when the collection gets large (#878, kudos to @nickoto) +1. Add extension to `ScopedDisposable` for inner `SerialDisposable` (#873, kudos to @sirnacnud) +1. Updated project settings for Xcode 15.2, bumped min deployment targets to iOS 12, macOS 10.13, tvOS 12, watchOS 4, visionOS 1.0 (#883, kudos to @mluisbrown) # 7.1.1 1. Bumped deployment target to iOS 11, tvOS 11, watchOS 4, macOS 10.13, per Xcode 14 warnings (#865, kudos to @lickel) diff --git a/ReactiveSwift.podspec b/ReactiveSwift.podspec index bf24fdfa2..27a728ce9 100644 --- a/ReactiveSwift.podspec +++ b/ReactiveSwift.podspec @@ -10,10 +10,10 @@ Pod::Spec.new do |s| s.license = { :type => "MIT", :file => "LICENSE.md" } s.author = "ReactiveCocoa" - s.ios.deployment_target = "11.0" + s.ios.deployment_target = "12.0" s.osx.deployment_target = "10.13" s.watchos.deployment_target = "4.0" - s.tvos.deployment_target = "11.0" + s.tvos.deployment_target = "12.0" s.source = { :git => "https://github.com/ReactiveCocoa/ReactiveSwift.git", :tag => "#{s.version}" } # Directory glob for all Swift files From a1ac77efbf9ccb63b2b5dfa9b5f13e0250684543 Mon Sep 17 00:00:00 2001 From: Michael Brown Date: Wed, 20 Mar 2024 09:06:49 +0000 Subject: [PATCH 7/7] Bump version in podspec in preparation for next release 7.2.0 --- ReactiveSwift.podspec | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ReactiveSwift.podspec b/ReactiveSwift.podspec index 27a728ce9..04241175f 100644 --- a/ReactiveSwift.podspec +++ b/ReactiveSwift.podspec @@ -1,7 +1,7 @@ Pod::Spec.new do |s| s.name = "ReactiveSwift" # Version goes here and will be used to access the git tag later on, once we have a first release. - s.version = "7.1.1" + s.version = "7.2.0" s.summary = "Streams of values over time" s.description = <<-DESC ReactiveSwift is a Swift framework inspired by Functional Reactive Programming. It provides APIs for composing and transforming streams of values over time.