mirror of
https://github.com/pointfreeco/swift-composable-architecture.git
synced 2025-12-20 09:11:33 +01:00
* wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * Silence test warnings * wip * wip * wip * update a bunch of docs * wip * wip * fix * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * Kill integration tests for now * wip * wip * wip * wip * updating docs for @Reducer macro * replaced more Reducer protocols with @Reducer * Fixed some broken docc references * wip * Some @Reducer docs * more docs * convert some old styles to new style * wip * wip * wip * wip * wip * wip * wip * bump * update tutorials to use body * update tutorials to use DML on destination state enum * Add diagnostic * wip * updated a few more tests * wip * wip * Add another gotcha * wip * wip * wip * fixes * wip * wip * wip * wip * wip * fix * wip * remove for now * wip * wip * updated some docs * migration guides * more migration guide * fix ci * fix * soft deprecate all apis using AnyCasePath * wip * Fix * fix tests * swift-format 509 compatibility * wip * wip * Update Sources/ComposableArchitecture/Macros.swift Co-authored-by: Mateusz Bąk <bakmatthew@icloud.com> * wip * wip * update optional state case study * remove initializer * Don't use @State for BasicsView integration demo * fix tests * remove reduce diagnostics for now * diagnose error not warning * Update Sources/ComposableArchitecture/Macros.swift Co-authored-by: Jesse Tipton <jesse@jessetipton.com> * wip * move integration tests to cron * Revert "move integration tests to cron" This reverts commitf9bdf2f04b. * disable flakey tests on CI * wip * wip * Revert "Revert "move integration tests to cron"" This reverts commit66aafa7327. * fix * wip * fix --------- Co-authored-by: Brandon Williams <mbrandonw@hey.com> Co-authored-by: Mateusz Bąk <bakmatthew@icloud.com> Co-authored-by: Brandon Williams <135203+mbrandonw@users.noreply.github.com> Co-authored-by: Jesse Tipton <jesse@jessetipton.com>
131 lines
3.9 KiB
Swift
131 lines
3.9 KiB
Swift
import ComposableArchitecture
|
|
import XCTest
|
|
|
|
@testable import SpeechRecognition
|
|
|
|
@MainActor
|
|
final class SpeechRecognitionTests: XCTestCase {
|
|
let recognitionTask = AsyncThrowingStream.makeStream(of: SpeechRecognitionResult.self)
|
|
|
|
func testDenyAuthorization() async {
|
|
let store = TestStore(initialState: SpeechRecognition.State()) {
|
|
SpeechRecognition()
|
|
} withDependencies: {
|
|
$0.speechClient.requestAuthorization = { .denied }
|
|
}
|
|
|
|
await store.send(.recordButtonTapped) {
|
|
$0.isRecording = true
|
|
}
|
|
await store.receive(\.speechRecognizerAuthorizationStatusResponse) {
|
|
$0.alert = AlertState {
|
|
TextState(
|
|
"""
|
|
You denied access to speech recognition. This app needs access to transcribe your speech.
|
|
"""
|
|
)
|
|
}
|
|
$0.isRecording = false
|
|
}
|
|
}
|
|
|
|
func testRestrictedAuthorization() async {
|
|
let store = TestStore(initialState: SpeechRecognition.State()) {
|
|
SpeechRecognition()
|
|
} withDependencies: {
|
|
$0.speechClient.requestAuthorization = { .restricted }
|
|
}
|
|
|
|
await store.send(.recordButtonTapped) {
|
|
$0.isRecording = true
|
|
}
|
|
await store.receive(\.speechRecognizerAuthorizationStatusResponse) {
|
|
$0.alert = AlertState { TextState("Your device does not allow speech recognition.") }
|
|
$0.isRecording = false
|
|
}
|
|
}
|
|
|
|
func testAllowAndRecord() async {
|
|
let store = TestStore(initialState: SpeechRecognition.State()) {
|
|
SpeechRecognition()
|
|
} withDependencies: {
|
|
$0.speechClient.finishTask = { self.recognitionTask.continuation.finish() }
|
|
$0.speechClient.startTask = { _ in self.recognitionTask.stream }
|
|
$0.speechClient.requestAuthorization = { .authorized }
|
|
}
|
|
|
|
let firstResult = SpeechRecognitionResult(
|
|
bestTranscription: Transcription(
|
|
formattedString: "Hello",
|
|
segments: []
|
|
),
|
|
isFinal: false,
|
|
transcriptions: []
|
|
)
|
|
var secondResult = firstResult
|
|
secondResult.bestTranscription.formattedString = "Hello world"
|
|
|
|
await store.send(.recordButtonTapped) {
|
|
$0.isRecording = true
|
|
}
|
|
|
|
await store.receive(\.speechRecognizerAuthorizationStatusResponse)
|
|
|
|
self.recognitionTask.continuation.yield(firstResult)
|
|
await store.receive(\.speech.success) {
|
|
$0.transcribedText = "Hello"
|
|
}
|
|
|
|
self.recognitionTask.continuation.yield(secondResult)
|
|
await store.receive(\.speech.success) {
|
|
$0.transcribedText = "Hello world"
|
|
}
|
|
|
|
await store.send(.recordButtonTapped) {
|
|
$0.isRecording = false
|
|
}
|
|
|
|
await store.finish()
|
|
}
|
|
|
|
func testAudioSessionFailure() async {
|
|
let store = TestStore(initialState: SpeechRecognition.State()) {
|
|
SpeechRecognition()
|
|
} withDependencies: {
|
|
$0.speechClient.startTask = { _ in self.recognitionTask.stream }
|
|
$0.speechClient.requestAuthorization = { .authorized }
|
|
}
|
|
|
|
await store.send(.recordButtonTapped) {
|
|
$0.isRecording = true
|
|
}
|
|
|
|
await store.receive(\.speechRecognizerAuthorizationStatusResponse)
|
|
|
|
recognitionTask.continuation.finish(throwing: SpeechClient.Failure.couldntConfigureAudioSession)
|
|
await store.receive(\.speech.failure) {
|
|
$0.alert = AlertState { TextState("Problem with audio device. Please try again.") }
|
|
}
|
|
}
|
|
|
|
func testAudioEngineFailure() async {
|
|
let store = TestStore(initialState: SpeechRecognition.State()) {
|
|
SpeechRecognition()
|
|
} withDependencies: {
|
|
$0.speechClient.startTask = { _ in self.recognitionTask.stream }
|
|
$0.speechClient.requestAuthorization = { .authorized }
|
|
}
|
|
|
|
await store.send(.recordButtonTapped) {
|
|
$0.isRecording = true
|
|
}
|
|
|
|
await store.receive(\.speechRecognizerAuthorizationStatusResponse)
|
|
|
|
recognitionTask.continuation.finish(throwing: SpeechClient.Failure.couldntStartAudioEngine)
|
|
await store.receive(\.speech.failure) {
|
|
$0.alert = AlertState { TextState("Problem with audio device. Please try again.") }
|
|
}
|
|
}
|
|
}
|