Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@
import software.aws.toolkits.jetbrains.services.amazonq.lsp.JsonRpcRequest
import software.aws.toolkits.jetbrains.services.amazonq.lsp.encryption.JwtEncryptionManager
import software.aws.toolkits.jetbrains.services.amazonq.lsp.flareChat.AwsServerCapabilitiesProvider
import software.aws.toolkits.jetbrains.services.amazonq.lsp.flareChat.ChatAsyncResultManager
import software.aws.toolkits.jetbrains.services.amazonq.lsp.flareChat.ChatCommunicationManager
import software.aws.toolkits.jetbrains.services.amazonq.lsp.flareChat.FlareUiMessage
import software.aws.toolkits.jetbrains.services.amazonq.lsp.model.aws.chat.AUTH_FOLLOW_UP_CLICKED
Expand Down Expand Up @@ -106,6 +107,7 @@
) {
var uiReady = CompletableDeferred<Boolean>()
private val chatCommunicationManager = ChatCommunicationManager.getInstance(project)
private val chatAsyncResultManager = ChatAsyncResultManager.getInstance(project)

Check warning on line 110 in plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt#L110

Added line #L110 was not covered by tests

suspend fun connect(
browser: Browser,
Expand Down Expand Up @@ -227,6 +229,7 @@

val tabId = requestFromUi.params.tabId
val partialResultToken = chatCommunicationManager.addPartialChatMessage(tabId)
chatCommunicationManager.registerPartialResultToken(partialResultToken)

Check warning on line 232 in plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt#L232

Added line #L232 was not covered by tests

var encryptionManager: JwtEncryptionManager? = null
val result = AmazonQLspService.executeIfRunning(project) { server ->
Expand All @@ -247,6 +250,7 @@
val tabId = requestFromUi.params.tabId
val quickActionParams = node.params ?: error("empty payload")
val partialResultToken = chatCommunicationManager.addPartialChatMessage(tabId)
chatCommunicationManager.registerPartialResultToken(partialResultToken)

Check warning on line 253 in plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt#L253

Added line #L253 was not covered by tests
var encryptionManager: JwtEncryptionManager? = null
val result = AmazonQLspService.executeIfRunning(project) { server ->
encryptionManager = this.encryptionManager
Expand Down Expand Up @@ -476,15 +480,32 @@
)
browser.postChat(messageToChat)
chatCommunicationManager.removeInflightRequestForTab(tabId)
} catch (_: CancellationException) {
} catch (e: CancellationException) {

Check warning on line 483 in plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt#L483

Added line #L483 was not covered by tests
LOG.warn { "Cancelled chat generation" }
try {
chatAsyncResultManager.createRequestId(partialResultToken)
chatAsyncResultManager.getResult(partialResultToken)
handleCancellation(tabId, browser)
} catch (ex: Exception) {
LOG.warn(ex) { "An error occurred while processing cancellation" }

Check warning on line 490 in plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt#L485-L490

Added lines #L485 - L490 were not covered by tests
} finally {
chatAsyncResultManager.removeRequestId(partialResultToken)
chatCommunicationManager.removePartialResultLock(partialResultToken)
chatCommunicationManager.removeFinalResultProcessed(partialResultToken)

Check warning on line 494 in plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt#L492-L494

Added lines #L492 - L494 were not covered by tests
}
} catch (e: Exception) {
LOG.warn(e) { "Failed to send chat message" }
browser.postChat(chatCommunicationManager.getErrorUiMessage(tabId, e, partialResultToken))
}
}
}

private fun handleCancellation(tabId: String, browser: Browser) {
// Send a message to hide the stop button without showing an error
val cancelMessage = chatCommunicationManager.getCancellationUiMessage(tabId)
browser.postChat(cancelMessage)
}

Check warning on line 507 in plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/chat/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/webview/BrowserConnector.kt#L505-L507

Added lines #L505 - L507 were not covered by tests

private fun cancelInflightRequests(tabId: String) {
chatCommunicationManager.getInflightRequestForTab(tabId)?.let { request ->
request.cancel(true)
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
// Copyright 2025 Amazon.com, Inc. or its affiliates. All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0

package software.aws.toolkits.jetbrains.services.amazonq.lsp.flareChat

import com.intellij.openapi.components.Service
import com.intellij.openapi.components.service
import com.intellij.openapi.project.Project
import java.util.concurrent.CompletableFuture
import java.util.concurrent.ConcurrentHashMap
import java.util.concurrent.TimeUnit
import java.util.concurrent.TimeoutException

/**
* Manages asynchronous results for chat operations, particularly handling the coordination
* between partial results and final results during cancellation.
*/
@Service(Service.Level.PROJECT)
class ChatAsyncResultManager {
private val results = ConcurrentHashMap<String, CompletableFuture<Any>>()
private val completedResults = ConcurrentHashMap<String, Any>()
private val timeout = 30L
private val timeUnit = TimeUnit.SECONDS

Check warning on line 23 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L18-L23

Added lines #L18 - L23 were not covered by tests

fun createRequestId(requestId: String) {
if (!completedResults.containsKey(requestId)) {
results[requestId] = CompletableFuture()

Check warning on line 27 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L27

Added line #L27 was not covered by tests
}
}

Check warning on line 29 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L29

Added line #L29 was not covered by tests

fun removeRequestId(requestId: String) {
val future = results.remove(requestId)

Check warning on line 32 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L32

Added line #L32 was not covered by tests
if (future != null && !future.isDone) {
future.cancel(true)

Check warning on line 34 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L34

Added line #L34 was not covered by tests
}
completedResults.remove(requestId)
}

Check warning on line 37 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L36-L37

Added lines #L36 - L37 were not covered by tests

fun setResult(requestId: String, result: Any) {
val future = results[requestId]

Check warning on line 40 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L40

Added line #L40 was not covered by tests
if (future != null) {
future.complete(result)
results.remove(requestId)

Check warning on line 43 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L42-L43

Added lines #L42 - L43 were not covered by tests
}
completedResults[requestId] = result
}

Check warning on line 46 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L45-L46

Added lines #L45 - L46 were not covered by tests

fun getResult(requestId: String): Any? =
getResult(requestId, timeout, timeUnit)

Check warning on line 49 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L49

Added line #L49 was not covered by tests

private fun getResult(requestId: String, timeout: Long, unit: TimeUnit): Any? {
val completedResult = completedResults[requestId]

Check warning on line 52 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L52

Added line #L52 was not covered by tests
if (completedResult != null) {
return completedResult

Check warning on line 54 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L54

Added line #L54 was not covered by tests
}

val future = results[requestId] ?: throw IllegalArgumentException("Request ID not found: $requestId")

try {
val result = future.get(timeout, unit)
completedResults[requestId] = result
results.remove(requestId)
return result
} catch (e: TimeoutException) {
future.cancel(true)
results.remove(requestId)
throw TimeoutException("Operation timed out for requestId: $requestId")

Check warning on line 67 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L59-L67

Added lines #L59 - L67 were not covered by tests
}
}

companion object {
fun getInstance(project: Project) = project.service<ChatAsyncResultManager>()

Check warning on line 72 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatAsyncResultManager.kt#L72

Added line #L72 was not covered by tests
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@
private val inflightRequestByTabId = ConcurrentHashMap<String, CompletableFuture<String>>()
private val pendingSerializedChatRequests = ConcurrentHashMap<String, CompletableFuture<GetSerializedChatResult>>()
private val pendingTabRequests = ConcurrentHashMap<String, CompletableFuture<LSPAny>>()
private val partialResultLocks = ConcurrentHashMap<String, Any>()
private val finalResultProcessed = ConcurrentHashMap<String, Boolean>()

Check warning on line 47 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L46-L47

Added lines #L46 - L47 were not covered by tests

fun setUiReady() {
uiReady.complete(true)
Expand Down Expand Up @@ -97,6 +99,20 @@
fun removeTabOpenRequest(requestId: String) =
pendingTabRequests.remove(requestId)

fun removePartialResultLock(token: String) {
partialResultLocks.remove(token)
}

Check warning on line 104 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L103-L104

Added lines #L103 - L104 were not covered by tests

fun removeFinalResultProcessed(token: String) {
finalResultProcessed.remove(token)
}

Check warning on line 108 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L107-L108

Added lines #L107 - L108 were not covered by tests

fun registerPartialResultToken(partialResultToken: String) {
val lock = Any()
partialResultLocks[partialResultToken] = lock
finalResultProcessed[partialResultToken] = false
}

Check warning on line 114 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L111-L114

Added lines #L111 - L114 were not covered by tests

fun handlePartialResultProgressNotification(project: Project, params: ProgressParams) {
val token = ProgressNotificationUtils.getToken(params)
val tabId = getPartialChatMessage(token)
Expand All @@ -112,13 +128,49 @@
val encryptedPartialChatResult = getObject(params, String::class.java)
if (encryptedPartialChatResult != null) {
val partialChatResult = AmazonQLspService.getInstance(project).encryptionManager.decrypt(encryptedPartialChatResult)
val uiMessage = convertToJsonToSendToChat(
command = SEND_CHAT_COMMAND_PROMPT,
tabId = tabId,
params = partialChatResult,
isPartialResult = true
)
AsyncChatUiListener.notifyPartialMessageUpdate(uiMessage)

// Special case: check for stop message before proceeding
val partialResultMap = tryOrNull {
Gson().fromJson(partialChatResult, Map::class.java)

Check warning on line 134 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L133-L134

Added lines #L133 - L134 were not covered by tests
}

if (partialResultMap != null) {
@Suppress("UNCHECKED_CAST")

Check warning on line 138 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L138

Added line #L138 was not covered by tests
val additionalMessages = partialResultMap["additionalMessages"] as? List<Map<String, Any>>
if (additionalMessages != null) {
for (message in additionalMessages) {
val messageId = message["messageId"] as? String
if (messageId != null && messageId.startsWith("stopped")) {
// Process stop messages immediately
val uiMessage = convertToJsonToSendToChat(
command = SEND_CHAT_COMMAND_PROMPT,
tabId = tabId,
params = partialChatResult,
isPartialResult = true

Check warning on line 149 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L145-L149

Added lines #L145 - L149 were not covered by tests
)
AsyncChatUiListener.notifyPartialMessageUpdate(uiMessage)
finalResultProcessed[token] = true
ChatAsyncResultManager.getInstance(project).setResult(token, partialResultMap)
return

Check warning on line 154 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L151-L154

Added lines #L151 - L154 were not covered by tests
}
}
}
}

// Normal processing for non-stop messages
val lock = partialResultLocks[token] ?: return
synchronized(lock) {

Check warning on line 162 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L162

Added line #L162 was not covered by tests
if (finalResultProcessed[token] == true || partialResultLocks[token] == null) {
return@synchronized

Check warning on line 164 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L164

Added line #L164 was not covered by tests
}
val uiMessage = convertToJsonToSendToChat(
command = SEND_CHAT_COMMAND_PROMPT,
tabId = tabId,
params = partialChatResult,
isPartialResult = true

Check warning on line 170 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L166-L170

Added lines #L166 - L170 were not covered by tests
)
AsyncChatUiListener.notifyPartialMessageUpdate(uiMessage)
}

Check warning on line 173 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L172-L173

Added lines #L172 - L173 were not covered by tests
}
}

Expand Down Expand Up @@ -148,6 +200,21 @@
return uiMessage
}

fun getCancellationUiMessage(tabId: String): String {
// Create a minimal error params with empty error message to hide the stop button
// without showing an actual error message to the user
val errorParams = Gson().toJson(ErrorParams(tabId, null, "", "")).toString()

Check warning on line 206 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L206

Added line #L206 was not covered by tests

return """

Check warning on line 208 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L208

Added line #L208 was not covered by tests
{
"command":"$CHAT_ERROR_PARAMS",
"tabId": "$tabId",
"params": $errorParams,

Check warning on line 212 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L211-L212

Added lines #L211 - L212 were not covered by tests
"isPartialResult": false
}
""".trimIndent()

Check warning on line 215 in plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt

View check run for this annotation

Codecov / codecov/patch

plugins/amazonq/shared/jetbrains-community/src/software/aws/toolkits/jetbrains/services/amazonq/lsp/flareChat/ChatCommunicationManager.kt#L215

Added line #L215 was not covered by tests
}

fun handleAuthFollowUpClicked(project: Project, params: AuthFollowUpClickedParams) {
val incomingType = params.authFollowupType
val connectionManager = ToolkitConnectionManager.getInstance(project)
Expand Down
Loading