mirror of
https://github.com/pointfreeco/swift-composable-architecture.git
synced 2025-12-24 12:14:25 +01:00
* Add an `EffectOf<Action>` typealias for `Effect<Action, Never>` * Fix doc * Rename `EffectOf` to `EffectTask` * Rename `Effect` to `EffectPublisher` * Soft-deprecate `Effect` * Link to `EffectTask` * Use `EffectPublisher` in Combine contexts * Reword soft-deprecation message * Remove `renamed:` fix-it for `Effect` deprecation * Update Sources/ComposableArchitecture/Documentation.docc/Extensions/ReducerProtocol.md Co-authored-by: Stephen Celis <stephen.celis@gmail.com> * Update Sources/ComposableArchitecture/Documentation.docc/ComposableArchitecture.md * Update Sources/ComposableArchitecture/Effect.swift * Fix DocC identifiers Co-authored-by: Stephen Celis <stephen.celis@gmail.com>
158 lines
3.7 KiB
Swift
158 lines
3.7 KiB
Swift
import ComposableArchitecture
|
|
import XCTest
|
|
|
|
@MainActor
|
|
final class DependencyKeyWritingReducerTests: XCTestCase {
|
|
func testWritingFusion() async {
|
|
let reducer: _DependencyKeyWritingReducer<Feature> = Feature()
|
|
.dependency(\.myValue, 42)
|
|
.dependency(\.myValue, 1729)
|
|
.dependency(\.myValue, 1)
|
|
.dependency(\.myValue, 2)
|
|
.dependency(\.myValue, 3)
|
|
|
|
XCTAssertTrue((reducer as Any) is _DependencyKeyWritingReducer<Feature>)
|
|
}
|
|
|
|
func testTransformFusion() async {
|
|
let reducer: _DependencyKeyWritingReducer<Feature> = Feature()
|
|
.transformDependency(\.myValue) { $0 = 42 }
|
|
.transformDependency(\.myValue) { $0 = 1729 }
|
|
.transformDependency(\.myValue) { $0 = 1 }
|
|
.transformDependency(\.myValue) { $0 = 2 }
|
|
.transformDependency(\.myValue) { $0 = 3 }
|
|
|
|
XCTAssertTrue((reducer as Any) is _DependencyKeyWritingReducer<Feature>)
|
|
}
|
|
|
|
func testWritingFusionOrder() async {
|
|
let reducer = Feature()
|
|
.dependency(\.myValue, 42)
|
|
.dependency(\.myValue, 1729)
|
|
|
|
let store = TestStore(
|
|
initialState: Feature.State(),
|
|
reducer: reducer
|
|
)
|
|
|
|
await store.send(.tap) {
|
|
$0.value = 42
|
|
}
|
|
}
|
|
|
|
func testTransformFusionOrder() async {
|
|
let reducer = Feature()
|
|
.transformDependency(\.myValue) { $0 = 42 }
|
|
.transformDependency(\.myValue) { $0 = 1729 }
|
|
|
|
let store = TestStore(
|
|
initialState: Feature.State(),
|
|
reducer: reducer
|
|
)
|
|
|
|
await store.send(.tap) {
|
|
$0.value = 42
|
|
}
|
|
}
|
|
|
|
func testWritingOrder() async {
|
|
let reducer = CombineReducers {
|
|
Feature()
|
|
.dependency(\.myValue, 42)
|
|
}
|
|
.dependency(\.myValue, 1729)
|
|
|
|
let store = TestStore(
|
|
initialState: Feature.State(),
|
|
reducer: reducer
|
|
)
|
|
|
|
await store.send(.tap) {
|
|
$0.value = 42
|
|
}
|
|
}
|
|
|
|
func testTransformOrder() async {
|
|
let reducer = CombineReducers {
|
|
Feature()
|
|
.transformDependency(\.myValue) { $0 = 42 }
|
|
}
|
|
.transformDependency(\.myValue) { $0 = 1729 }
|
|
|
|
let store = TestStore(
|
|
initialState: Feature.State(),
|
|
reducer: reducer
|
|
)
|
|
|
|
await store.send(.tap) {
|
|
$0.value = 42
|
|
}
|
|
}
|
|
|
|
func testDependency_EffectOfEffect() async {
|
|
struct Feature: ReducerProtocol {
|
|
struct State: Equatable { var count = 0 }
|
|
enum Action: Equatable {
|
|
case tap
|
|
case response(Int)
|
|
case otherResponse(Int)
|
|
}
|
|
@Dependency(\.myValue) var myValue
|
|
|
|
func reduce(into state: inout State, action: Action) -> EffectTask<Action> {
|
|
switch action {
|
|
case .tap:
|
|
state.count += 1
|
|
return .task { .response(self.myValue) }
|
|
|
|
case let .response(value):
|
|
state.count = value
|
|
return .task { .otherResponse(self.myValue) }
|
|
|
|
case let .otherResponse(value):
|
|
state.count = value
|
|
return .none
|
|
}
|
|
}
|
|
}
|
|
|
|
let store = TestStore(
|
|
initialState: Feature.State(),
|
|
reducer: Feature()
|
|
.dependency(\.myValue, 42)
|
|
)
|
|
|
|
await store.send(.tap) {
|
|
$0.count = 1
|
|
}
|
|
await store.receive(.response(42)) {
|
|
$0.count = 42
|
|
}
|
|
await store.receive(.otherResponse(42))
|
|
}
|
|
}
|
|
|
|
private struct Feature: ReducerProtocol {
|
|
@Dependency(\.myValue) var myValue
|
|
struct State: Equatable { var value = 0 }
|
|
enum Action { case tap }
|
|
func reduce(into state: inout State, action: Action) -> EffectTask<Action> {
|
|
switch action {
|
|
case .tap:
|
|
state.value = self.myValue
|
|
return .none
|
|
}
|
|
}
|
|
}
|
|
|
|
private enum MyValue: DependencyKey {
|
|
static let liveValue = 0
|
|
static let testValue = 0
|
|
}
|
|
extension DependencyValues {
|
|
var myValue: Int {
|
|
get { self[MyValue.self] }
|
|
set { self[MyValue.self] = newValue }
|
|
}
|
|
}
|