Темизация: adaptive цвета чата, context menu, attachment picker, auth + instant отклик DarkMode кнопки
This commit is contained in:
@@ -97,12 +97,14 @@ struct SignalPeerCallFlowTests {
|
||||
let caller = "02a1b2c3d4e5f6a7b8c9d0e1f2a3b4c5d6e7f8a9b0c1d2e3f4a5b6c7d8e9f0a1b2"
|
||||
let callee = "03f0e1d2c3b4a5968778695a4b3c2d1e0f9e8d7c6b5a49382716051a2b3c4d5e6f"
|
||||
let packet = PacketSignalPeer(src: caller, dst: callee, sharedPublic: "",
|
||||
signalType: .call, roomId: "")
|
||||
signalType: .call, callId: "call-1", joinToken: "join-1", roomId: "")
|
||||
let decoded = try decode(packet)
|
||||
#expect(decoded.signalType == .call)
|
||||
#expect(decoded.src == caller)
|
||||
#expect(decoded.dst == callee)
|
||||
#expect(decoded.sharedPublic == "")
|
||||
#expect(decoded.callId == "call-1")
|
||||
#expect(decoded.joinToken == "join-1")
|
||||
#expect(decoded.roomId == "")
|
||||
}
|
||||
|
||||
@@ -153,6 +155,19 @@ struct SignalPeerCallFlowTests {
|
||||
#expect(decoded.signalType == .endCallBecausePeerDisconnected)
|
||||
}
|
||||
|
||||
@Test("RINGING_TIMEOUT short format — 3 bytes wire size")
|
||||
func ringingTimeoutShortFormat() throws {
|
||||
let packet = PacketSignalPeer(src: "ignored", dst: "ignored", sharedPublic: "ignored",
|
||||
signalType: .ringingTimeout, roomId: "ignored")
|
||||
let data = PacketRegistry.encode(packet)
|
||||
#expect(data.count == 3)
|
||||
|
||||
let decoded = try decode(packet)
|
||||
#expect(decoded.signalType == .ringingTimeout)
|
||||
#expect(decoded.src == "")
|
||||
#expect(decoded.dst == "")
|
||||
}
|
||||
|
||||
private func decode(_ packet: PacketSignalPeer) throws -> PacketSignalPeer {
|
||||
let data = PacketRegistry.encode(packet)
|
||||
guard let result = PacketRegistry.decode(from: data),
|
||||
@@ -171,7 +186,8 @@ struct CallPushEnumParityTests {
|
||||
arguments: [
|
||||
(SignalType.call, 0), (SignalType.keyExchange, 1), (SignalType.activeCall, 2),
|
||||
(SignalType.endCall, 3), (SignalType.createRoom, 4),
|
||||
(SignalType.endCallBecausePeerDisconnected, 5), (SignalType.endCallBecauseBusy, 6)
|
||||
(SignalType.endCallBecausePeerDisconnected, 5), (SignalType.endCallBecauseBusy, 6),
|
||||
(SignalType.accept, 7), (SignalType.ringingTimeout, 8)
|
||||
])
|
||||
func signalTypeEnumValues(pair: (SignalType, Int)) {
|
||||
#expect(pair.0.rawValue == pair.1)
|
||||
@@ -222,12 +238,12 @@ struct CallPushWireFormatTests {
|
||||
#expect(data[14] == 0x00); #expect(data[15] == 0x42)
|
||||
}
|
||||
|
||||
@Test("SignalPeer call byte layout: signalType→src→dst")
|
||||
@Test("SignalPeer call byte layout: signalType→src→dst→callId→joinToken")
|
||||
func signalPeerCallByteLayout() {
|
||||
let packet = PacketSignalPeer(src: "S", dst: "D", sharedPublic: "",
|
||||
signalType: .call, roomId: "")
|
||||
let data = PacketRegistry.encode(packet)
|
||||
#expect(data.count == 15)
|
||||
#expect(data.count == 23)
|
||||
|
||||
// packetId = 0x001A
|
||||
#expect(data[0] == 0x00); #expect(data[1] == 0x1A)
|
||||
@@ -241,6 +257,12 @@ struct CallPushWireFormatTests {
|
||||
#expect(data[9] == 0x00); #expect(data[10] == 0x00)
|
||||
#expect(data[11] == 0x00); #expect(data[12] == 0x01)
|
||||
#expect(data[13] == 0x00); #expect(data[14] == 0x44)
|
||||
// callId "": length=0
|
||||
#expect(data[15] == 0x00); #expect(data[16] == 0x00)
|
||||
#expect(data[17] == 0x00); #expect(data[18] == 0x00)
|
||||
// joinToken "": length=0
|
||||
#expect(data[19] == 0x00); #expect(data[20] == 0x00)
|
||||
#expect(data[21] == 0x00); #expect(data[22] == 0x00)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user