Prod do_matching captures (data_dumps/captures/traffic_prod_tk2_*) send the node URL as host:port/socket.io/ with no scheme prefix — e.g. "node06.shadowverse.jp:13560/socket.io/". BestHTTP's SocketManager expects this exact shape; the leading ws:// we were sending plus the missing /socket.io/ path was preventing the client from completing the post-do_matching connect (eventually times out with "connection timed out"). Update BattleNodeOptions default, Program.cs override, and both controller and bridge tests to use "localhost:5148/socket.io/". Discovered during v1 smoke walkthrough. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
47 lines
1.5 KiB
C#
47 lines
1.5 KiB
C#
using NUnit.Framework;
|
|
using SVSim.BattleNode.Bridge;
|
|
using SVSim.BattleNode.Sessions;
|
|
|
|
namespace SVSim.UnitTests.BattleNode.Bridge;
|
|
|
|
[TestFixture]
|
|
public class MatchingBridgeTests
|
|
{
|
|
[Test]
|
|
public void RegisterPendingBattle_RegistersInStoreAndReturnsNodeUrl()
|
|
{
|
|
var store = new InMemoryBattleSessionStore();
|
|
var bridge = new MatchingBridge(store, new BattleNodeOptions { NodeServerUrl = "localhost:5148/socket.io/" });
|
|
|
|
var match = bridge.RegisterPendingBattle(viewerId: 906243102);
|
|
|
|
Assert.That(match.NodeServerUrl, Is.EqualTo("localhost:5148/socket.io/"));
|
|
Assert.That(match.BattleId, Is.Not.Empty);
|
|
var pending = store.TryGetPending(match.BattleId);
|
|
Assert.That(pending, Is.Not.Null);
|
|
Assert.That(pending!.ViewerId, Is.EqualTo(906243102));
|
|
}
|
|
|
|
[Test]
|
|
public void RegisterPendingBattle_MintsUniqueBattleIds()
|
|
{
|
|
var bridge = new MatchingBridge(new InMemoryBattleSessionStore(), new BattleNodeOptions());
|
|
|
|
var a = bridge.RegisterPendingBattle(1);
|
|
var b = bridge.RegisterPendingBattle(2);
|
|
|
|
Assert.That(a.BattleId, Is.Not.EqualTo(b.BattleId));
|
|
}
|
|
|
|
[Test]
|
|
public void RegisterPendingBattle_ProducesTwelveDigitDecimalBattleId()
|
|
{
|
|
var bridge = new MatchingBridge(new InMemoryBattleSessionStore(), new BattleNodeOptions());
|
|
|
|
var match = bridge.RegisterPendingBattle(viewerId: 1);
|
|
|
|
Assert.That(match.BattleId, Has.Length.EqualTo(12));
|
|
Assert.That(match.BattleId, Does.Match("^[0-9]{12}$"));
|
|
}
|
|
}
|