mirror of
https://github.com/Mezeporta/Erupe.git
synced 2026-03-22 15:43:49 +01:00
Add comprehensive tests for handler files: - handlers_object: object creation, positioning, binary ops - handlers_semaphore: create, acquire, release, check, delete - handlers_reserve: stub handlers and reserve188/18B - handlers_event: registration, release, feature weapons - handlers_mutex: create, open, close, delete operations - handlers_campaign: enumerate, state, apply - handlers_bbs: user status, SNS status, article apply - handlers_tournament: info, entry, acquire - handlers_users: user binary operations - handlers_clients: client enumeration - handlers_rengoku: ranking - handlers_register: raviente semaphore functions - handlers_tower: tower info, tenrouirai, seibatu ranking All tests pass with race detection enabled.
151 lines
3.4 KiB
Go
151 lines
3.4 KiB
Go
package channelserver
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"erupe-ce/network/mhfpacket"
|
|
)
|
|
|
|
func TestHandleMsgSysEnumerateClient_StageNotExists(t *testing.T) {
|
|
server := createMockServer()
|
|
session := createMockSession(1, server)
|
|
|
|
pkt := &mhfpacket.MsgSysEnumerateClient{
|
|
AckHandle: 12345,
|
|
StageID: "nonexistent_stage",
|
|
Get: 0,
|
|
}
|
|
|
|
handleMsgSysEnumerateClient(session, pkt)
|
|
|
|
// Verify response packet was queued (failure expected)
|
|
select {
|
|
case p := <-session.sendPackets:
|
|
if len(p.data) == 0 {
|
|
t.Error("Response packet should have data")
|
|
}
|
|
default:
|
|
t.Error("No response packet queued")
|
|
}
|
|
}
|
|
|
|
func TestHandleMsgSysEnumerateClient_AllClients(t *testing.T) {
|
|
server := createMockServer()
|
|
session := createMockSession(1, server)
|
|
|
|
// Create stage with clients
|
|
stage := NewStage("test_stage")
|
|
server.stages["test_stage"] = stage
|
|
|
|
client1 := createMockSession(100, server)
|
|
client2 := createMockSession(200, server)
|
|
stage.clients[client1] = client1.charID
|
|
stage.clients[client2] = client2.charID
|
|
|
|
pkt := &mhfpacket.MsgSysEnumerateClient{
|
|
AckHandle: 12345,
|
|
StageID: "test_stage",
|
|
Get: 0, // All clients
|
|
}
|
|
|
|
handleMsgSysEnumerateClient(session, pkt)
|
|
|
|
// Verify response packet was queued
|
|
select {
|
|
case p := <-session.sendPackets:
|
|
if len(p.data) == 0 {
|
|
t.Error("Response packet should have data")
|
|
}
|
|
default:
|
|
t.Error("No response packet queued")
|
|
}
|
|
}
|
|
|
|
func TestHandleMsgSysEnumerateClient_NotReady(t *testing.T) {
|
|
server := createMockServer()
|
|
session := createMockSession(1, server)
|
|
|
|
// Create stage with reserved slots
|
|
stage := NewStage("test_stage")
|
|
server.stages["test_stage"] = stage
|
|
|
|
stage.reservedClientSlots[100] = false // Not ready
|
|
stage.reservedClientSlots[200] = true // Ready
|
|
|
|
pkt := &mhfpacket.MsgSysEnumerateClient{
|
|
AckHandle: 12345,
|
|
StageID: "test_stage",
|
|
Get: 1, // Not ready
|
|
}
|
|
|
|
handleMsgSysEnumerateClient(session, pkt)
|
|
|
|
// Verify response packet was queued
|
|
select {
|
|
case p := <-session.sendPackets:
|
|
if len(p.data) == 0 {
|
|
t.Error("Response packet should have data")
|
|
}
|
|
default:
|
|
t.Error("No response packet queued")
|
|
}
|
|
}
|
|
|
|
func TestHandleMsgSysEnumerateClient_Ready(t *testing.T) {
|
|
server := createMockServer()
|
|
session := createMockSession(1, server)
|
|
|
|
// Create stage with reserved slots
|
|
stage := NewStage("test_stage")
|
|
server.stages["test_stage"] = stage
|
|
|
|
stage.reservedClientSlots[100] = false // Not ready
|
|
stage.reservedClientSlots[200] = true // Ready
|
|
|
|
pkt := &mhfpacket.MsgSysEnumerateClient{
|
|
AckHandle: 12345,
|
|
StageID: "test_stage",
|
|
Get: 2, // Ready
|
|
}
|
|
|
|
handleMsgSysEnumerateClient(session, pkt)
|
|
|
|
// Verify response packet was queued
|
|
select {
|
|
case p := <-session.sendPackets:
|
|
if len(p.data) == 0 {
|
|
t.Error("Response packet should have data")
|
|
}
|
|
default:
|
|
t.Error("No response packet queued")
|
|
}
|
|
}
|
|
|
|
func TestHandleMsgMhfShutClient(t *testing.T) {
|
|
server := createMockServer()
|
|
session := createMockSession(1, server)
|
|
|
|
// Should not panic (empty handler)
|
|
defer func() {
|
|
if r := recover(); r != nil {
|
|
t.Errorf("handleMsgMhfShutClient panicked: %v", r)
|
|
}
|
|
}()
|
|
|
|
handleMsgMhfShutClient(session, nil)
|
|
}
|
|
|
|
func TestHandleMsgSysHideClient(t *testing.T) {
|
|
server := createMockServer()
|
|
session := createMockSession(1, server)
|
|
|
|
// Should not panic (empty handler)
|
|
defer func() {
|
|
if r := recover(); r != nil {
|
|
t.Errorf("handleMsgSysHideClient panicked: %v", r)
|
|
}
|
|
}()
|
|
|
|
handleMsgSysHideClient(session, nil)
|
|
}
|