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:
Reese Norris
2024-10-07 12:50:39 -07:00
parent de94e668f0
commit 57d54d6705
138 changed files with 8279 additions and 4095 deletions

View File

@@ -39,49 +39,54 @@ func TestParseMetarResponsePDU(t *testing.T) {
{
"Missing To field",
"$ARSERVER::KSEE 091847Z 25007KT 10SM SKC 24/04 A3006\r\n",
nil,
NewGenericFSDError(SyntaxError),
&MetarResponsePDU{},
NewGenericFSDError(SyntaxError, "", "validation error"),
},
{
"From Field too long",
"$ARSERVERTOLONG:CLIENT:KSEE 091847Z 25007KT 10SM SKC 24/04 A3006\r\n",
nil,
NewGenericFSDError(SyntaxError),
"$ARSERVERTOLONGSERVERTOLONGSERVERTOLONG:CLIENT:KSEE 091847Z 25007KT 10SM SKC 24/04 A3006\r\n",
&MetarResponsePDU{},
NewGenericFSDError(SyntaxError, "", "validation error"),
},
{
"Metar too long",
"$ARSERVER:CLIENT:" + strings.Repeat("A", 257) + "\r\n",
nil,
NewGenericFSDError(SyntaxError),
"$ARSERVER:CLIENT:" + strings.Repeat("A", 1024) + "\r\n",
&MetarResponsePDU{},
NewGenericFSDError(SyntaxError, "", "validation error"),
},
{
"Incomplete packet format",
"$ARSERVER:CLIENT\r\n",
nil,
NewGenericFSDError(SyntaxError),
&MetarResponsePDU{},
NewGenericFSDError(SyntaxError, "", "invalid parameter count"),
},
{
"Empty metar field",
"$ARSERVER:CLIENT:\r\n",
nil,
NewGenericFSDError(SyntaxError),
&MetarResponsePDU{},
NewGenericFSDError(SyntaxError, "", "validation error"),
},
}
for _, tc := range tests {
t.Run(tc.name, func(t *testing.T) {
// Perform the parsing
result, err := ParseMetarResponsePDU(tc.packet)
pdu := MetarResponsePDU{}
err := pdu.Parse(tc.packet)
// Check the error
if tc.wantErr != nil {
assert.EqualError(t, err, tc.wantErr.Error())
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, result)
assert.Equal(t, tc.want, &pdu)
})
}
}