From 8f3204a17783f566cacd8dcefc46dec31c174000 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gwendal=20Roue=CC=81?= Date: Sun, 28 Jul 2024 12:04:15 +0200 Subject: [PATCH 1/2] Bump minimum Swift version to 5.10 --- .github/workflows/run_tests.yml | 4 ++-- Package.swift | 16 +++++++++++----- README.md | 2 +- 3 files changed, 14 insertions(+), 8 deletions(-) diff --git a/.github/workflows/run_tests.yml b/.github/workflows/run_tests.yml index 1c23643..e646460 100644 --- a/.github/workflows/run_tests.yml +++ b/.github/workflows/run_tests.yml @@ -23,13 +23,13 @@ jobs: strategy: matrix: os: [macos-latest, ubuntu-latest] - swift-version: ["5.7.0"] + swift-version: ["5.10.0"] runs-on: ${{ matrix.os }} steps: - uses: actions/checkout@v3 - name: Install Swift ${{ matrix.swift-version }} if: ${{ runner.os != 'Windows' }} - uses: swift-actions/setup-swift@v1 + uses: swift-actions/setup-swift@v2 with: swift-version: ${{ matrix.swift-version }} - name: Test diff --git a/Package.swift b/Package.swift index 3ad4575..8af68c5 100644 --- a/Package.swift +++ b/Package.swift @@ -1,4 +1,4 @@ -// swift-tools-version: 5.7 +// swift-tools-version: 5.10 // The swift-tools-version declares the minimum version of Swift required to build this package. import PackageDescription @@ -25,12 +25,18 @@ let package = Package( // Targets are the basic building blocks of a package. A target can define a module or a test suite. // Targets can depend on other targets in this package, and on products in packages this package depends on. .target( - name: "Semaphore", - swiftSettings: [ - // .unsafeFlags(["-Xfrontend", "-warn-concurrency", "-strict-concurrency=complete"]), - ]), + name: "Semaphore"), .testTarget( name: "SemaphoreTests", dependencies: ["Semaphore"]), ] ) + +for target in package.targets { + var settings = target.swiftSettings ?? [] + settings.append(contentsOf: [ + // + .enableExperimentalFeature("StrictConcurrency"), + ]) + target.swiftSettings = settings +} diff --git a/README.md b/README.md index 5aaf0f4..8a31fb0 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ **A Synchronization Primitive for Swift Concurrency** -**Requirements**: iOS 13.0+ / macOS 10.15+ / tvOS 13.0+ / watchOS 6.0+ • Swift 5.7+ / Xcode 14+ +**Requirements**: iOS 13.0+ / macOS 10.15+ / tvOS 13.0+ / watchOS 6.0+ • Swift 5.10+ / Xcode 15.3+ 📖 **[Documentation](https://swiftpackageindex.com/groue/Semaphore/documentation)** From b12e9c28d6c3d09c5ea8a261c8bd89530034f4f0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gwendal=20Roue=CC=81?= Date: Sun, 28 Jul 2024 12:04:25 +0200 Subject: [PATCH 2/2] Fix compiler warnings --- .../SemaphoreTests/AsyncSemaphoreTests.swift | 24 +++++++++---------- 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/Tests/SemaphoreTests/AsyncSemaphoreTests.swift b/Tests/SemaphoreTests/AsyncSemaphoreTests.swift index 82a22d1..ad7cb96 100644 --- a/Tests/SemaphoreTests/AsyncSemaphoreTests.swift +++ b/Tests/SemaphoreTests/AsyncSemaphoreTests.swift @@ -71,7 +71,7 @@ final class AsyncSemaphoreTests: XCTestCase { } } - func test_wait_suspends_on_zero_semaphore_until_signal() { + func test_wait_suspends_on_zero_semaphore_until_signal() async { // Check DispatchSemaphore behavior do { // Given a zero semaphore @@ -88,11 +88,11 @@ final class AsyncSemaphoreTests: XCTestCase { }.start() // Then the thread is initially blocked. - wait(for: [ex1], timeout: 0.5) + await fulfillment(of: [ex1], timeout: 0.5) // When a signal occurs, then the waiting thread is woken. sem.signal() - wait(for: [ex2], timeout: 1) + await fulfillment(of: [ex2], timeout: 1) } // Test that AsyncSemaphore behaves identically @@ -111,11 +111,11 @@ final class AsyncSemaphoreTests: XCTestCase { } // Then the task is initially suspended. - wait(for: [ex1], timeout: 0.5) + await fulfillment(of: [ex1], timeout: 0.5) // When a signal occurs, then the suspended task is resumed. sem.signal() - wait(for: [ex2], timeout: 0.5) + await fulfillment(of: [ex2], timeout: 0.5) } } @@ -134,7 +134,7 @@ final class AsyncSemaphoreTests: XCTestCase { } try await Task.sleep(nanoseconds: 100_000_000) task.cancel() - wait(for: [ex], timeout: 1) + await fulfillment(of: [ex], timeout: 1) } func test_cancellation_before_suspension_throws_CancellationError() throws { @@ -180,14 +180,14 @@ final class AsyncSemaphoreTests: XCTestCase { } // Then the task is initially suspended. - wait(for: [ex1], timeout: 0.5) + await fulfillment(of: [ex1], timeout: 0.5) // When a signal occurs, then the suspended task is resumed. sem.signal() - wait(for: [ex2], timeout: 0.5) + await fulfillment(of: [ex2], timeout: 0.5) } - func test_that_cancellation_before_suspension_increments_the_semaphore() throws { + func test_that_cancellation_before_suspension_increments_the_semaphore() async throws { // Given a task cancelled before it waits on a semaphore, let sem = AsyncSemaphore(value: 0) let task = Task { @@ -212,11 +212,11 @@ final class AsyncSemaphoreTests: XCTestCase { } // Then the task is initially suspended. - wait(for: [ex1], timeout: 0.5) + await fulfillment(of: [ex1], timeout: 0.5) // When a signal occurs, then the suspended task is resumed. sem.signal() - wait(for: [ex2], timeout: 0.5) + await fulfillment(of: [ex2], timeout: 0.5) } // Inspired by @@ -241,7 +241,7 @@ final class AsyncSemaphoreTests: XCTestCase { } // Then the second task is not suspended. - wait(for: [ex], timeout: 0.5) + await fulfillment(of: [ex], timeout: 0.5) } // Test that semaphore can limit the number of concurrent executions of