mirror of
https://github.com/Mezeporta/Erupe.git
synced 2026-03-27 10:03:06 +01:00
test(channelserver): add mock-based handler unit tests
Leverage the new repository interfaces to test handler logic without a database. Adds shared mock implementations (achievement, mail, character, goocoo, guild) and 32 new handler tests covering achievement, mail, cafe/boost, and goocoo handlers.
This commit is contained in:
@@ -2,6 +2,7 @@ package channelserver
|
||||
|
||||
import (
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
"erupe-ce/network/mhfpacket"
|
||||
)
|
||||
@@ -108,3 +109,228 @@ func TestCafeBonusStruct(t *testing.T) {
|
||||
t.Error("Claimed should be false")
|
||||
}
|
||||
}
|
||||
|
||||
// --- Mock-based handler tests ---
|
||||
|
||||
func TestHandleMsgMhfUpdateCafepoint(t *testing.T) {
|
||||
server := createMockServer()
|
||||
charMock := newMockCharacterRepo()
|
||||
charMock.ints["netcafe_points"] = 150
|
||||
server.charRepo = charMock
|
||||
session := createMockSession(1, server)
|
||||
|
||||
pkt := &mhfpacket.MsgMhfUpdateCafepoint{AckHandle: 100}
|
||||
|
||||
handleMsgMhfUpdateCafepoint(session, pkt)
|
||||
|
||||
select {
|
||||
case p := <-session.sendPackets:
|
||||
if len(p.data) < 4 {
|
||||
t.Fatal("Response too short")
|
||||
}
|
||||
default:
|
||||
t.Error("No response packet queued")
|
||||
}
|
||||
}
|
||||
|
||||
func TestHandleMsgMhfAcquireCafeItem(t *testing.T) {
|
||||
server := createMockServer()
|
||||
charMock := newMockCharacterRepo()
|
||||
charMock.ints["netcafe_points"] = 500
|
||||
server.charRepo = charMock
|
||||
session := createMockSession(1, server)
|
||||
|
||||
pkt := &mhfpacket.MsgMhfAcquireCafeItem{
|
||||
AckHandle: 100,
|
||||
PointCost: 200,
|
||||
}
|
||||
|
||||
handleMsgMhfAcquireCafeItem(session, pkt)
|
||||
|
||||
if charMock.ints["netcafe_points"] != 300 {
|
||||
t.Errorf("netcafe_points = %d, want 300 (500-200)", charMock.ints["netcafe_points"])
|
||||
}
|
||||
|
||||
select {
|
||||
case p := <-session.sendPackets:
|
||||
if len(p.data) < 4 {
|
||||
t.Fatal("Response too short")
|
||||
}
|
||||
default:
|
||||
t.Error("No response packet queued")
|
||||
}
|
||||
}
|
||||
|
||||
func TestHandleMsgMhfStartBoostTime_Disabled(t *testing.T) {
|
||||
server := createMockServer()
|
||||
server.erupeConfig.GameplayOptions.DisableBoostTime = true
|
||||
charMock := newMockCharacterRepo()
|
||||
server.charRepo = charMock
|
||||
session := createMockSession(1, server)
|
||||
|
||||
pkt := &mhfpacket.MsgMhfStartBoostTime{AckHandle: 100}
|
||||
|
||||
handleMsgMhfStartBoostTime(session, pkt)
|
||||
|
||||
// When disabled, boost_time should NOT be saved
|
||||
if _, ok := charMock.times["boost_time"]; ok {
|
||||
t.Error("boost_time should not be saved when disabled")
|
||||
}
|
||||
|
||||
select {
|
||||
case p := <-session.sendPackets:
|
||||
if len(p.data) < 4 {
|
||||
t.Fatal("Response too short")
|
||||
}
|
||||
default:
|
||||
t.Error("No response packet queued")
|
||||
}
|
||||
}
|
||||
|
||||
func TestHandleMsgMhfStartBoostTime_Enabled(t *testing.T) {
|
||||
server := createMockServer()
|
||||
server.erupeConfig.GameplayOptions.DisableBoostTime = false
|
||||
server.erupeConfig.GameplayOptions.BoostTimeDuration = 3600
|
||||
charMock := newMockCharacterRepo()
|
||||
server.charRepo = charMock
|
||||
session := createMockSession(1, server)
|
||||
|
||||
pkt := &mhfpacket.MsgMhfStartBoostTime{AckHandle: 100}
|
||||
|
||||
handleMsgMhfStartBoostTime(session, pkt)
|
||||
|
||||
savedTime, ok := charMock.times["boost_time"]
|
||||
if !ok {
|
||||
t.Fatal("boost_time should be saved")
|
||||
}
|
||||
if savedTime.Before(time.Now()) {
|
||||
t.Error("boost_time should be in the future")
|
||||
}
|
||||
|
||||
select {
|
||||
case p := <-session.sendPackets:
|
||||
if len(p.data) < 4 {
|
||||
t.Fatal("Response too short")
|
||||
}
|
||||
default:
|
||||
t.Error("No response packet queued")
|
||||
}
|
||||
}
|
||||
|
||||
func TestHandleMsgMhfGetBoostTimeLimit(t *testing.T) {
|
||||
server := createMockServer()
|
||||
charMock := newMockCharacterRepo()
|
||||
future := time.Now().Add(1 * time.Hour)
|
||||
charMock.times["boost_time"] = future
|
||||
server.charRepo = charMock
|
||||
session := createMockSession(1, server)
|
||||
|
||||
pkt := &mhfpacket.MsgMhfGetBoostTimeLimit{AckHandle: 100}
|
||||
|
||||
handleMsgMhfGetBoostTimeLimit(session, pkt)
|
||||
|
||||
// This handler sends two responses (doAckBufSucceed + doAckSimpleSucceed)
|
||||
count := 0
|
||||
for {
|
||||
select {
|
||||
case <-session.sendPackets:
|
||||
count++
|
||||
default:
|
||||
goto done
|
||||
}
|
||||
}
|
||||
done:
|
||||
if count != 2 {
|
||||
t.Errorf("Expected 2 response packets, got %d", count)
|
||||
}
|
||||
}
|
||||
|
||||
func TestHandleMsgMhfGetBoostTimeLimit_NoBoost(t *testing.T) {
|
||||
server := createMockServer()
|
||||
charMock := newMockCharacterRepo()
|
||||
charMock.readErr = errNotFound
|
||||
server.charRepo = charMock
|
||||
session := createMockSession(1, server)
|
||||
|
||||
pkt := &mhfpacket.MsgMhfGetBoostTimeLimit{AckHandle: 100}
|
||||
|
||||
handleMsgMhfGetBoostTimeLimit(session, pkt)
|
||||
|
||||
// Should still send responses even on error
|
||||
count := 0
|
||||
for {
|
||||
select {
|
||||
case <-session.sendPackets:
|
||||
count++
|
||||
default:
|
||||
goto done2
|
||||
}
|
||||
}
|
||||
done2:
|
||||
if count < 1 {
|
||||
t.Error("Should queue at least one response packet")
|
||||
}
|
||||
}
|
||||
|
||||
func TestHandleMsgMhfGetBoostRight_Active(t *testing.T) {
|
||||
server := createMockServer()
|
||||
charMock := newMockCharacterRepo()
|
||||
charMock.times["boost_time"] = time.Now().Add(1 * time.Hour) // Future = active
|
||||
server.charRepo = charMock
|
||||
session := createMockSession(1, server)
|
||||
|
||||
pkt := &mhfpacket.MsgMhfGetBoostRight{AckHandle: 100}
|
||||
|
||||
handleMsgMhfGetBoostRight(session, pkt)
|
||||
|
||||
select {
|
||||
case p := <-session.sendPackets:
|
||||
if len(p.data) < 4 {
|
||||
t.Fatal("Response too short")
|
||||
}
|
||||
default:
|
||||
t.Error("No response packet queued")
|
||||
}
|
||||
}
|
||||
|
||||
func TestHandleMsgMhfGetBoostRight_Expired(t *testing.T) {
|
||||
server := createMockServer()
|
||||
charMock := newMockCharacterRepo()
|
||||
charMock.times["boost_time"] = time.Now().Add(-1 * time.Hour) // Past = expired
|
||||
server.charRepo = charMock
|
||||
session := createMockSession(1, server)
|
||||
|
||||
pkt := &mhfpacket.MsgMhfGetBoostRight{AckHandle: 100}
|
||||
|
||||
handleMsgMhfGetBoostRight(session, pkt)
|
||||
|
||||
select {
|
||||
case p := <-session.sendPackets:
|
||||
if len(p.data) < 4 {
|
||||
t.Fatal("Response too short")
|
||||
}
|
||||
default:
|
||||
t.Error("No response packet queued")
|
||||
}
|
||||
}
|
||||
|
||||
func TestHandleMsgMhfGetBoostRight_NoRecord(t *testing.T) {
|
||||
server := createMockServer()
|
||||
charMock := newMockCharacterRepo()
|
||||
charMock.readErr = errNotFound
|
||||
server.charRepo = charMock
|
||||
session := createMockSession(1, server)
|
||||
|
||||
pkt := &mhfpacket.MsgMhfGetBoostRight{AckHandle: 100}
|
||||
|
||||
handleMsgMhfGetBoostRight(session, pkt)
|
||||
|
||||
select {
|
||||
case p := <-session.sendPackets:
|
||||
if len(p.data) < 4 {
|
||||
t.Fatal("Response too short")
|
||||
}
|
||||
default:
|
||||
t.Error("No response packet queued")
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user