Implemented the Dependency property wrapper.
This commit is contained in:
parent
dd416a85a1
commit
0c480ac5a0
31
Sources/Dependencies/Property Wrappers/Dependency.swift
Normal file
31
Sources/Dependencies/Property Wrappers/Dependency.swift
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
//
|
||||||
|
// Dependency.swift
|
||||||
|
// Dependencies
|
||||||
|
//
|
||||||
|
// Created by Javier Cicchelli on 11/04/2023.
|
||||||
|
// Copyright © 2023 Röck+Cöde. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
/// This property wrapper provides a direct connection to the `DependencyService` service.
|
||||||
|
@propertyWrapper
|
||||||
|
public struct Dependency<D> {
|
||||||
|
|
||||||
|
// MARK: Properties
|
||||||
|
|
||||||
|
private let keyPath: WritableKeyPath<DependencyService, D>
|
||||||
|
|
||||||
|
/// This property allows direct read/write access to a defined dependency attached to a selected key path.
|
||||||
|
public var wrappedValue: D {
|
||||||
|
get { DependencyService[keyPath] }
|
||||||
|
set { DependencyService[keyPath] = newValue }
|
||||||
|
}
|
||||||
|
|
||||||
|
// MARK: Initialisers
|
||||||
|
|
||||||
|
/// Initialise the property wrapper by setting a key path to a defined dependency.
|
||||||
|
/// - Parameter keyPath: A key path to a defined dependency in the `DependencyService` service.
|
||||||
|
public init(_ keyPath: WritableKeyPath<DependencyService, D>) {
|
||||||
|
self.keyPath = keyPath
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
73
Tests/Dependencies/Property Wrappers/DependencyTests.swift
Normal file
73
Tests/Dependencies/Property Wrappers/DependencyTests.swift
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
//
|
||||||
|
// DependencyTests.swift
|
||||||
|
// DependenciesTests
|
||||||
|
//
|
||||||
|
// Created by Javier Cicchelli on 11/04/2023.
|
||||||
|
// Copyright © 2023 Röck+Cöde. All rights reserved.
|
||||||
|
//
|
||||||
|
|
||||||
|
import Dependencies
|
||||||
|
import XCTest
|
||||||
|
|
||||||
|
final class DependencyTests: XCTestCase {
|
||||||
|
|
||||||
|
// MARK: Properties
|
||||||
|
|
||||||
|
private var subject: TestSubject!
|
||||||
|
|
||||||
|
// MARK: Setup
|
||||||
|
|
||||||
|
override func setUp() {
|
||||||
|
DependencyService[\.testService] = SomeService()
|
||||||
|
}
|
||||||
|
|
||||||
|
// MARK: Tests
|
||||||
|
|
||||||
|
func test_readTestService() {
|
||||||
|
// GIVEN
|
||||||
|
subject = .init()
|
||||||
|
|
||||||
|
// WHEN
|
||||||
|
let service = subject.testService
|
||||||
|
|
||||||
|
// THEN
|
||||||
|
XCTAssertNotNil(service)
|
||||||
|
XCTAssert(service is SomeService)
|
||||||
|
}
|
||||||
|
|
||||||
|
func test_writeDependencyKey() async throws {
|
||||||
|
// GIVEN
|
||||||
|
subject = .init()
|
||||||
|
|
||||||
|
subject.testService = SomeOtherService()
|
||||||
|
|
||||||
|
// WHEN
|
||||||
|
let service = DependencyService[\.testService]
|
||||||
|
|
||||||
|
// THEN
|
||||||
|
XCTAssertNotNil(service)
|
||||||
|
XCTAssert(service is SomeOtherService)
|
||||||
|
}
|
||||||
|
|
||||||
|
func test_writeDependencyKeyTwice() async throws {
|
||||||
|
// GIVEN
|
||||||
|
subject = .init()
|
||||||
|
|
||||||
|
subject.testService = SomeOtherService()
|
||||||
|
subject.testService = SomeService()
|
||||||
|
|
||||||
|
// WHEN
|
||||||
|
let service = DependencyService[\.testService]
|
||||||
|
|
||||||
|
// THEN
|
||||||
|
XCTAssertNotNil(service)
|
||||||
|
XCTAssert(service is SomeService)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// MARK: - TestSubject
|
||||||
|
|
||||||
|
private struct TestSubject {
|
||||||
|
@Dependency(\.testService) var testService
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user