mirror of
https://github.com/renorris/openfsd
synced 2026-04-05 14:55:33 +08:00
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)
This commit is contained in:
@@ -3,6 +3,7 @@ package protocol
|
||||
import (
|
||||
"github.com/go-playground/validator/v10"
|
||||
"github.com/stretchr/testify/assert"
|
||||
"strings"
|
||||
"testing"
|
||||
)
|
||||
|
||||
@@ -54,26 +55,26 @@ func TestParseAuthChallengePDU(t *testing.T) {
|
||||
{
|
||||
name: "Missing From Field",
|
||||
packet: "$ZC:CLIENT:abcd1234ef\r\n",
|
||||
want: nil,
|
||||
wantErr: NewGenericFSDError(SyntaxError),
|
||||
want: &AuthChallengePDU{},
|
||||
wantErr: NewGenericFSDError(SyntaxError, "", "validation error"),
|
||||
},
|
||||
{
|
||||
name: "Missing To Field",
|
||||
packet: "$ZCSERVER::abcd1234ef\r\n",
|
||||
want: nil,
|
||||
wantErr: NewGenericFSDError(SyntaxError),
|
||||
want: &AuthChallengePDU{},
|
||||
wantErr: NewGenericFSDError(SyntaxError, "", "validation error"),
|
||||
},
|
||||
{
|
||||
name: "Invalid Challenge Length",
|
||||
name: "Invalid Challenge Len",
|
||||
packet: "$ZCSERVER:CLIENT:ab\r\n",
|
||||
want: nil,
|
||||
wantErr: NewGenericFSDError(SyntaxError),
|
||||
want: &AuthChallengePDU{},
|
||||
wantErr: NewGenericFSDError(SyntaxError, "", "validation error"),
|
||||
},
|
||||
{
|
||||
name: "Invalid Hexadecimal Challenge",
|
||||
packet: "$ZCSERVER:CLIENT:ghij7890\r\n",
|
||||
want: nil,
|
||||
wantErr: NewGenericFSDError(SyntaxError),
|
||||
want: &AuthChallengePDU{},
|
||||
wantErr: NewGenericFSDError(SyntaxError, "", "validation error"),
|
||||
},
|
||||
}
|
||||
|
||||
@@ -81,9 +82,19 @@ func TestParseAuthChallengePDU(t *testing.T) {
|
||||
|
||||
for _, tc := range tests {
|
||||
t.Run(tc.name, func(t *testing.T) {
|
||||
result, err := ParseAuthChallengePDU(tc.packet)
|
||||
assert.Equal(t, tc.want, result)
|
||||
assert.Equal(t, tc.wantErr, err)
|
||||
pdu := AuthChallengePDU{}
|
||||
err := pdu.Parse(tc.packet)
|
||||
assert.Equal(t, tc.want, &pdu)
|
||||
// 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)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user