61 lines
2.0 KiB
Swift
61 lines
2.0 KiB
Swift
import AppKit
|
|
import ClawdbotChatUI
|
|
import Foundation
|
|
import Testing
|
|
@testable import Clawdbot
|
|
|
|
@Suite(.serialized)
|
|
@MainActor
|
|
struct WebChatSwiftUISmokeTests {
|
|
private struct TestTransport: ClawdbotChatTransport, Sendable {
|
|
func requestHistory(sessionKey: String) async throws -> ClawdbotChatHistoryPayload {
|
|
let json = """
|
|
{"sessionKey":"\(sessionKey)","sessionId":null,"messages":[],"thinkingLevel":"off"}
|
|
"""
|
|
return try JSONDecoder().decode(ClawdbotChatHistoryPayload.self, from: Data(json.utf8))
|
|
}
|
|
|
|
func sendMessage(
|
|
sessionKey _: String,
|
|
message _: String,
|
|
thinking _: String,
|
|
idempotencyKey _: String,
|
|
attachments _: [ClawdbotChatAttachmentPayload]) async throws -> ClawdbotChatSendResponse
|
|
{
|
|
let json = """
|
|
{"runId":"\(UUID().uuidString)","status":"ok"}
|
|
"""
|
|
return try JSONDecoder().decode(ClawdbotChatSendResponse.self, from: Data(json.utf8))
|
|
}
|
|
|
|
func requestHealth(timeoutMs _: Int) async throws -> Bool { true }
|
|
|
|
func events() -> AsyncStream<ClawdbotChatTransportEvent> {
|
|
AsyncStream { continuation in
|
|
continuation.finish()
|
|
}
|
|
}
|
|
|
|
func setActiveSessionKey(_: String) async throws {}
|
|
}
|
|
|
|
@Test func windowControllerShowAndClose() {
|
|
let controller = WebChatSwiftUIWindowController(
|
|
sessionKey: "main",
|
|
presentation: .window,
|
|
transport: TestTransport())
|
|
controller.show()
|
|
controller.close()
|
|
}
|
|
|
|
@Test func panelControllerPresentAndClose() {
|
|
let anchor = { NSRect(x: 200, y: 400, width: 40, height: 40) }
|
|
let controller = WebChatSwiftUIWindowController(
|
|
sessionKey: "main",
|
|
presentation: .panel(anchorProvider: anchor),
|
|
transport: TestTransport())
|
|
controller.presentAnchored(anchorProvider: anchor)
|
|
controller.close()
|
|
}
|
|
}
|