Files
openfsd/protocol/kill_request_test.go
Reese Norris 57d54d6705 v0.1.0-alpha
Changes:
- Implement bootstrapping library for managing several concurrent internal services
- Refactor concurrency model for connections/logical clients and their associated I/O
- Refactor server context singleton
- Refactor error handling
    - Most errors are now gracefully sent to the FSD client directly encoded as an $ER packet,
      enhancing visibility and debugging
    - Most errors are now rightfully treated as non-fatal
- Refactor package/dependency graph
- Refactor calling conventions/interfaces for many packages
- Refactor database package
- Refactor post office

Features:
- Add VATSIM-esque HTTP/JSON "data feed"
- Add ephemeral in-memory database option
- Add user management REST API
- Add improved web interface
- Add MySQL support (drop SQLite support)
2024-10-07 12:50:39 -07:00

118 lines
2.5 KiB
Go

package protocol
import (
"github.com/go-playground/validator/v10"
"github.com/stretchr/testify/assert"
"strings"
"testing"
)
func TestParseKillRequestPDU(t *testing.T) {
V = validator.New()
tests := []struct {
name string
packet string
want *KillRequestPDU
wantErr error
}{
{
name: "Valid Reason",
packet: "$!!JOHN:DOE:you're banned: reason\r\n",
want: &KillRequestPDU{
From: "JOHN",
To: "DOE",
Reason: "you're banned: reason",
},
wantErr: nil,
},
{
name: "Valid with no Reason",
packet: "$!!JOHN:DOE\r\n",
want: &KillRequestPDU{
From: "JOHN",
To: "DOE",
Reason: "",
},
wantErr: nil,
},
{
name: "Invalid from field",
packet: "$!!JOHN99999JOHN99999JOHN99999JOHN99999:DOE:you're banned: reason\r\n",
want: &KillRequestPDU{},
wantErr: NewGenericFSDError(SyntaxError, "", "validation error"),
},
{
name: "Invalid to field",
packet: "$!!JOHN:DOE1234567DOE1234567DOE1234567DOE1234567:you're banned: reason\r\n",
want: &KillRequestPDU{},
wantErr: NewGenericFSDError(SyntaxError, "", "validation error"),
},
{
name: "Missing to field",
packet: "$!!JOHN::Hello, world!\r\n",
want: &KillRequestPDU{},
wantErr: NewGenericFSDError(SyntaxError, "", "validation error"),
},
}
for _, tc := range tests {
t.Run(tc.name, func(t *testing.T) {
// Perform the parsing
pdu := KillRequestPDU{}
err := pdu.Parse(tc.packet)
// Check the error
if tc.wantErr != nil {
if strings.Contains(tc.wantErr.Error(), "validation error") {
assert.Contains(t, err.Error(), "validation error")
} else {
assert.EqualError(t, err, tc.wantErr.Error())
}
} else {
assert.NoError(t, err)
}
// Verify the result
assert.Equal(t, tc.want, &pdu)
})
}
}
func TestKillRequestPDU_Serialize(t *testing.T) {
tests := []struct {
name string
textPDU KillRequestPDU
wantOutput string
}{
{
name: "Valid",
textPDU: KillRequestPDU{
From: "ALPHA1",
To: "BRAVO2",
Reason: "Hello, this is a test Reason.",
},
wantOutput: "$!!ALPHA1:BRAVO2:Hello, this is a test Reason.\r\n",
},
{
name: "Valid without Reason",
textPDU: KillRequestPDU{
From: "ALPHA1",
To: "BRAVO2",
Reason: "",
},
wantOutput: "$!!ALPHA1:BRAVO2\r\n",
},
}
for _, tc := range tests {
t.Run(tc.name, func(t *testing.T) {
// Perform serialization
output := tc.textPDU.Serialize()
// Verify the output
assert.Equal(t, tc.wantOutput, output)
})
}
}