From abd17e5df1a8af580a0b3ebb470cae4662cfcc03 Mon Sep 17 00:00:00 2001 From: Sebastian Villena <97059974+ruisebas@users.noreply.github.com> Date: Fri, 3 Jan 2025 13:41:55 -0500 Subject: [PATCH 1/2] chore: Switching to xcbeautify instead of xcpretty (#3945) --- .github/composite_actions/run_xcodebuild/action.yml | 2 +- .github/composite_actions/run_xcodebuild_test/action.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/composite_actions/run_xcodebuild/action.yml b/.github/composite_actions/run_xcodebuild/action.yml index d5567939bf..e5de6b9a4c 100644 --- a/.github/composite_actions/run_xcodebuild/action.yml +++ b/.github/composite_actions/run_xcodebuild/action.yml @@ -71,5 +71,5 @@ runs: fi xcodebuild -version - xcodebuild build -scheme $SCHEME -sdk '${{ inputs.sdk }}' -destination '${{ inputs.destination }}' $otherFlags | xcpretty --simple --color --report junit && exit ${PIPESTATUS[0]} + xcodebuild build -scheme $SCHEME -sdk '${{ inputs.sdk }}' -destination '${{ inputs.destination }}' $otherFlags | xcbeautify --renderer github-actions && exit ${PIPESTATUS[0]} shell: bash \ No newline at end of file diff --git a/.github/composite_actions/run_xcodebuild_test/action.yml b/.github/composite_actions/run_xcodebuild_test/action.yml index b025621254..dff01112ce 100644 --- a/.github/composite_actions/run_xcodebuild_test/action.yml +++ b/.github/composite_actions/run_xcodebuild_test/action.yml @@ -100,7 +100,7 @@ runs: xcode-select -p xcodebuild -version - xcodebuild $action -scheme $SCHEME -sdk '${{ inputs.sdk }}' -destination '${{ inputs.destination }}' ${{ inputs.other_flags }} $clonedSourcePackagesPath $derivedDataPath $coverageFlags | xcpretty --simple --color --report junit && exit ${PIPESTATUS[0]} + xcodebuild $action -scheme $SCHEME -sdk '${{ inputs.sdk }}' -destination '${{ inputs.destination }}' ${{ inputs.other_flags }} $clonedSourcePackagesPath $derivedDataPath $coverageFlags | xcbeautify --renderer github-actions && exit ${PIPESTATUS[0]} shell: bash - name: Generate Coverage report From b2474823c1ee8449b0872d436d1f4a094c6a450d Mon Sep 17 00:00:00 2001 From: Abhash Kumar Singh Date: Fri, 3 Jan 2025 11:32:22 -0800 Subject: [PATCH 2/2] fix(predictions): use serial queue for WebSocketSession delegate queue (#3935) --- .../Liveness/Service/FaceLivenessSession.swift | 12 ++++++++---- .../Liveness/Service/WebSocketSession.swift | 8 +++++++- 2 files changed, 15 insertions(+), 5 deletions(-) diff --git a/AmplifyPlugins/Predictions/AWSPredictionsPlugin/Liveness/Service/FaceLivenessSession.swift b/AmplifyPlugins/Predictions/AWSPredictionsPlugin/Liveness/Service/FaceLivenessSession.swift index 092532d8e3..1723f0c688 100644 --- a/AmplifyPlugins/Predictions/AWSPredictionsPlugin/Liveness/Service/FaceLivenessSession.swift +++ b/AmplifyPlugins/Predictions/AWSPredictionsPlugin/Liveness/Service/FaceLivenessSession.swift @@ -71,7 +71,9 @@ public final class FaceLivenessSession: LivenessService { } public func closeSocket(with code: URLSessionWebSocketTask.CloseCode) { - websocket.close(with: code) + livenessServiceDispatchQueue.async { + self.websocket.close(with: code) + } } public func initializeLivenessStream(withSessionID sessionID: String, userAgent: String = "") throws { @@ -89,14 +91,16 @@ public final class FaceLivenessSession: LivenessService { savedURLForReconnect = url let signedConnectionURL = signer.sign(url: url) - websocket.open(url: signedConnectionURL) + livenessServiceDispatchQueue.async { + self.websocket.open(url: signedConnectionURL) + } } public func send( _ event: LivenessEvent, eventDate: @escaping () -> Date = Date.init ) { - livenessServiceDispatchQueue.sync { + livenessServiceDispatchQueue.async { let encodedPayload = self.eventStreamEncoder.encode( payload: event.payload, headers: [ @@ -107,7 +111,7 @@ public final class FaceLivenessSession: LivenessService { ) let dateForSigning: Date - if let serverDate = serverDate { + if let serverDate = self.serverDate { dateForSigning = serverDate } else { dateForSigning = eventDate() diff --git a/AmplifyPlugins/Predictions/AWSPredictionsPlugin/Liveness/Service/WebSocketSession.swift b/AmplifyPlugins/Predictions/AWSPredictionsPlugin/Liveness/Service/WebSocketSession.swift index f900f3dfc3..5888cde6e4 100644 --- a/AmplifyPlugins/Predictions/AWSPredictionsPlugin/Liveness/Service/WebSocketSession.swift +++ b/AmplifyPlugins/Predictions/AWSPredictionsPlugin/Liveness/Service/WebSocketSession.swift @@ -15,13 +15,19 @@ final class WebSocketSession { private var receiveMessage: ((Result) -> WebSocketMessageResult)? private var onSocketClosed: ((URLSessionWebSocketTask.CloseCode) -> Void)? private var onServerDateReceived: ((Date?) -> Void)? + private let delegateQueue: OperationQueue init() { + self.delegateQueue = OperationQueue() + self.delegateQueue.maxConcurrentOperationCount = 1 + self.delegateQueue.qualityOfService = .userInteractive + self.urlSessionWebSocketDelegate = Delegate() + self.session = URLSession( configuration: .default, delegate: urlSessionWebSocketDelegate, - delegateQueue: .init() + delegateQueue: delegateQueue ) }