branchrust_reboot/main/parallel_validatemovecancel

27 Commits over 0 Days - ∞cph!

Yesterday
Bugfix: fix transform cache rebuild loop Previously threw away dirty indices too early, missing on some player cache changes Tests: played back the staging demo - no more error logs about transfomr cache inconsistency
Yesterday
Clean: fixing broken whitespaces that I spotted with the merge Tests: none, trivial change
Yesterday
Merge: from main Tests: none, no conflicts
Yesterday
Bugfix: PlayerCache now tracks players that are removed from the server Original impl left a space where it could miss some of the players, leading to rogue nulls. Tests: played back staging demo - had same numbers
3 Days Ago
Bugfix: one of validation checks was doing nothing Tests: none, trivial change
3 Days Ago
Clean: removing BasePlayer OnDisable/-Destroy logs for UsePlayerUpdateJobs Got confirmation that it's not Unity nuking the objects, so something else must be afoot. Tests: built server locally
3 Days Ago
Merge: from main Tests: none, no conflicts
3 Days Ago
Clean: fixing broken formatting that snuck in on main Tests: none, trivial changes
3 Days Ago
Merge: from main Tests: none, no conflicts
3 Days Ago
Debug: adding sanity debug error logs to baseplayer OnDisable and OnDestroy Hoping to catch where it's coming from Tests: local build tests
4 Days Ago
Bugfix: ServerDemoPlayer - handle player reconnecting multiple times Not 100% sure it's the correct way, but I think it works for now. Tests: played back new staging demo 3 times
4 Days Ago
Tests: replace Assert.AreEqual with Assert.IsTrue - Brings TickIntrpolatorCache test from 30s+ down to 6s Turns out AreEqual is slow and inflates the test times by quite a bit. Tests: ran unit test
4 Days Ago
Optim: TickInterpolatorCache reduce number of segments being copied when growing Unit test is still slow, need to dig a bit more Tests: ran unit tests
4 Days Ago
Clean: fixing whitespace issues after auto-merge Tests: none, trivial changes
4 Days Ago
Merge: from main Tests: none, no conflicts
4 Days Ago
Debug: sprinkling additional validation checks in ServerUpdateParallel Trying to narrow down at which point this null sneaks in Tests: none, trivial change
5 Days Ago
New: TickInterpolatorCache - a sparse, bulk TickInterpolator array - Comes with it's own stress tests (they pass, but need to investigate perf) - Depends on PlayerCache, but I need to modify it to provide more stability Building block towards jobifying tick history processing. Tests: ran unit tests
5 Days Ago
Optim: replace couple managed loops with a burst job Tests: none, trivial changes
5 Days Ago
Buildfix: move ValidateTransformCache to SERVER region - also fixed missing Profiler.EndSample() Tests: built client and server in editor
5 Days Ago
Merge: from main Tests: none, trivial merge
5 Days Ago
Clean: promote server var to a const - no codegen since I didn't do one when I added this It's temp code, but it makes things safer while I investigate, so no reason to disable it at runtime Tests: none, trivial change
5 Days Ago
Bugfix: purge player cache when player update jobs has emergency shutdown Allows to restart player update jobs cleanly in the same session Tests: in editor with debugger forced an emergency scenario, confirmed the cache was empty and rebuilt
5 Days Ago
Update: move player transform cache updates to be first step of parallel player processing - Bugfix - using Steam networking backend can have temporary outtages, which can cause gaps in processing and player cache desyncing - also enables us to compose parallel flows better in the future Tests: local editor session on craggy
5 Days Ago
Update: add temp emergency disable of player job processing - Only active on staging servers while I investigate the crashes Tests: forced an error via debugger - confirmed fallback is working
5 Days Ago
Tests: move the PlayerCache stress test to it's relvant tests file and clean up - commented out the expected-to-fail case Tests: ran the tests
8 Days Ago
Update: adding throw away tests to investigate how I cuased a native crash yesterday So far everything points to BasePlayer being removed after we cache all transforms for the burst jobs and before the first RecacheTransform invoke, but I haven't tracked where it's coming from. Tests: ran the hacky unit test
9 Days Ago
Merge: from main