mirror of
https://github.com/ppy/osu.git
synced 2025-01-21 20:33:01 +08:00
Rename classes to reduce redundant naming
This commit is contained in:
parent
7d5d7088cd
commit
4c5d4752b1
@ -12,20 +12,20 @@ using osu.Game.Tests.Visual;
|
|||||||
namespace osu.Game.Tests.OnlinePlay
|
namespace osu.Game.Tests.OnlinePlay
|
||||||
{
|
{
|
||||||
[HeadlessTest]
|
[HeadlessTest]
|
||||||
public class MultiplayerCatchUpSyncManagerTest : OsuTestScene
|
public class TestCaseCatchUpSyncManager : OsuTestScene
|
||||||
{
|
{
|
||||||
private TestManualClock master;
|
private TestManualClock master;
|
||||||
private SpectatorCatchUpSyncManager syncManager;
|
private CatchUpSyncManager syncManager;
|
||||||
|
|
||||||
private TestSpectatorSlaveClock slave1;
|
private TestSlaveClock slave1;
|
||||||
private TestSpectatorSlaveClock slave2;
|
private TestSlaveClock slave2;
|
||||||
|
|
||||||
[SetUp]
|
[SetUp]
|
||||||
public void Setup()
|
public void Setup()
|
||||||
{
|
{
|
||||||
syncManager = new SpectatorCatchUpSyncManager(master = new TestManualClock());
|
syncManager = new CatchUpSyncManager(master = new TestManualClock());
|
||||||
syncManager.AddSlave(slave1 = new TestSpectatorSlaveClock(1));
|
syncManager.AddSlave(slave1 = new TestSlaveClock(1));
|
||||||
syncManager.AddSlave(slave2 = new TestSpectatorSlaveClock(2));
|
syncManager.AddSlave(slave2 = new TestSlaveClock(2));
|
||||||
|
|
||||||
Schedule(() => Child = syncManager);
|
Schedule(() => Child = syncManager);
|
||||||
}
|
}
|
||||||
@ -47,7 +47,7 @@ namespace osu.Game.Tests.OnlinePlay
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestMasterClockDoesNotStartWhenNoneReadyForMaximumDelayTime()
|
public void TestMasterClockDoesNotStartWhenNoneReadyForMaximumDelayTime()
|
||||||
{
|
{
|
||||||
AddWaitStep($"wait {SpectatorCatchUpSyncManager.MAXIMUM_START_DELAY} milliseconds", (int)Math.Ceiling(SpectatorCatchUpSyncManager.MAXIMUM_START_DELAY / TimePerAction));
|
AddWaitStep($"wait {CatchUpSyncManager.MAXIMUM_START_DELAY} milliseconds", (int)Math.Ceiling(CatchUpSyncManager.MAXIMUM_START_DELAY / TimePerAction));
|
||||||
assertMasterState(false);
|
assertMasterState(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -55,7 +55,7 @@ namespace osu.Game.Tests.OnlinePlay
|
|||||||
public void TestMasterClockStartsWhenAnyReadyForMaximumDelayTime()
|
public void TestMasterClockStartsWhenAnyReadyForMaximumDelayTime()
|
||||||
{
|
{
|
||||||
setWaiting(() => slave1, false);
|
setWaiting(() => slave1, false);
|
||||||
AddWaitStep($"wait {SpectatorCatchUpSyncManager.MAXIMUM_START_DELAY} milliseconds", (int)Math.Ceiling(SpectatorCatchUpSyncManager.MAXIMUM_START_DELAY / TimePerAction));
|
AddWaitStep($"wait {CatchUpSyncManager.MAXIMUM_START_DELAY} milliseconds", (int)Math.Ceiling(CatchUpSyncManager.MAXIMUM_START_DELAY / TimePerAction));
|
||||||
assertMasterState(true);
|
assertMasterState(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -64,7 +64,7 @@ namespace osu.Game.Tests.OnlinePlay
|
|||||||
{
|
{
|
||||||
setAllWaiting(false);
|
setAllWaiting(false);
|
||||||
|
|
||||||
setMasterTime(SpectatorCatchUpSyncManager.SYNC_TARGET + 1);
|
setMasterTime(CatchUpSyncManager.SYNC_TARGET + 1);
|
||||||
assertCatchingUp(() => slave1, false);
|
assertCatchingUp(() => slave1, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -73,7 +73,7 @@ namespace osu.Game.Tests.OnlinePlay
|
|||||||
{
|
{
|
||||||
setAllWaiting(false);
|
setAllWaiting(false);
|
||||||
|
|
||||||
setMasterTime(SpectatorCatchUpSyncManager.MAX_SYNC_OFFSET + 1);
|
setMasterTime(CatchUpSyncManager.MAX_SYNC_OFFSET + 1);
|
||||||
assertCatchingUp(() => slave1, true);
|
assertCatchingUp(() => slave1, true);
|
||||||
assertCatchingUp(() => slave2, true);
|
assertCatchingUp(() => slave2, true);
|
||||||
}
|
}
|
||||||
@ -83,8 +83,8 @@ namespace osu.Game.Tests.OnlinePlay
|
|||||||
{
|
{
|
||||||
setAllWaiting(false);
|
setAllWaiting(false);
|
||||||
|
|
||||||
setMasterTime(SpectatorCatchUpSyncManager.MAX_SYNC_OFFSET + 1);
|
setMasterTime(CatchUpSyncManager.MAX_SYNC_OFFSET + 1);
|
||||||
setSlaveTime(() => slave1, SpectatorCatchUpSyncManager.SYNC_TARGET + 1);
|
setSlaveTime(() => slave1, CatchUpSyncManager.SYNC_TARGET + 1);
|
||||||
assertCatchingUp(() => slave1, true);
|
assertCatchingUp(() => slave1, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -93,8 +93,8 @@ namespace osu.Game.Tests.OnlinePlay
|
|||||||
{
|
{
|
||||||
setAllWaiting(false);
|
setAllWaiting(false);
|
||||||
|
|
||||||
setMasterTime(SpectatorCatchUpSyncManager.MAX_SYNC_OFFSET + 2);
|
setMasterTime(CatchUpSyncManager.MAX_SYNC_OFFSET + 2);
|
||||||
setSlaveTime(() => slave1, SpectatorCatchUpSyncManager.SYNC_TARGET);
|
setSlaveTime(() => slave1, CatchUpSyncManager.SYNC_TARGET);
|
||||||
assertCatchingUp(() => slave1, false);
|
assertCatchingUp(() => slave1, false);
|
||||||
assertCatchingUp(() => slave2, true);
|
assertCatchingUp(() => slave2, true);
|
||||||
}
|
}
|
||||||
@ -104,7 +104,7 @@ namespace osu.Game.Tests.OnlinePlay
|
|||||||
{
|
{
|
||||||
setAllWaiting(false);
|
setAllWaiting(false);
|
||||||
|
|
||||||
setSlaveTime(() => slave1, -SpectatorCatchUpSyncManager.SYNC_TARGET);
|
setSlaveTime(() => slave1, -CatchUpSyncManager.SYNC_TARGET);
|
||||||
assertCatchingUp(() => slave1, false);
|
assertCatchingUp(() => slave1, false);
|
||||||
assertSlaveState(() => slave1, true);
|
assertSlaveState(() => slave1, true);
|
||||||
}
|
}
|
||||||
@ -114,7 +114,7 @@ namespace osu.Game.Tests.OnlinePlay
|
|||||||
{
|
{
|
||||||
setAllWaiting(false);
|
setAllWaiting(false);
|
||||||
|
|
||||||
setSlaveTime(() => slave1, -SpectatorCatchUpSyncManager.SYNC_TARGET - 1);
|
setSlaveTime(() => slave1, -CatchUpSyncManager.SYNC_TARGET - 1);
|
||||||
|
|
||||||
// This is a silent catchup, where IsCatchingUp = false but IsRunning = false also.
|
// This is a silent catchup, where IsCatchingUp = false but IsRunning = false also.
|
||||||
assertCatchingUp(() => slave1, false);
|
assertCatchingUp(() => slave1, false);
|
||||||
@ -135,7 +135,7 @@ namespace osu.Game.Tests.OnlinePlay
|
|||||||
assertSlaveState(() => slave1, false);
|
assertSlaveState(() => slave1, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setWaiting(Func<TestSpectatorSlaveClock> slave, bool waiting)
|
private void setWaiting(Func<TestSlaveClock> slave, bool waiting)
|
||||||
=> AddStep($"set slave {slave().Id} waiting = {waiting}", () => slave().WaitingOnFrames.Value = waiting);
|
=> AddStep($"set slave {slave().Id} waiting = {waiting}", () => slave().WaitingOnFrames.Value = waiting);
|
||||||
|
|
||||||
private void setAllWaiting(bool waiting) => AddStep($"set all slaves waiting = {waiting}", () =>
|
private void setAllWaiting(bool waiting) => AddStep($"set all slaves waiting = {waiting}", () =>
|
||||||
@ -150,28 +150,28 @@ namespace osu.Game.Tests.OnlinePlay
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// slave.Time = master.Time - offsetFromMaster
|
/// slave.Time = master.Time - offsetFromMaster
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private void setSlaveTime(Func<TestSpectatorSlaveClock> slave, double offsetFromMaster)
|
private void setSlaveTime(Func<TestSlaveClock> slave, double offsetFromMaster)
|
||||||
=> AddStep($"set slave {slave().Id} = master - {offsetFromMaster}", () => slave().Seek(master.CurrentTime - offsetFromMaster));
|
=> AddStep($"set slave {slave().Id} = master - {offsetFromMaster}", () => slave().Seek(master.CurrentTime - offsetFromMaster));
|
||||||
|
|
||||||
private void assertMasterState(bool running)
|
private void assertMasterState(bool running)
|
||||||
=> AddAssert($"master clock {(running ? "is" : "is not")} running", () => master.IsRunning == running);
|
=> AddAssert($"master clock {(running ? "is" : "is not")} running", () => master.IsRunning == running);
|
||||||
|
|
||||||
private void assertCatchingUp(Func<TestSpectatorSlaveClock> slave, bool catchingUp) =>
|
private void assertCatchingUp(Func<TestSlaveClock> slave, bool catchingUp) =>
|
||||||
AddAssert($"slave {slave().Id} {(catchingUp ? "is" : "is not")} catching up", () => slave().IsCatchingUp == catchingUp);
|
AddAssert($"slave {slave().Id} {(catchingUp ? "is" : "is not")} catching up", () => slave().IsCatchingUp == catchingUp);
|
||||||
|
|
||||||
private void assertSlaveState(Func<TestSpectatorSlaveClock> slave, bool running)
|
private void assertSlaveState(Func<TestSlaveClock> slave, bool running)
|
||||||
=> AddAssert($"slave {slave().Id} {(running ? "is" : "is not")} running", () => slave().IsRunning == running);
|
=> AddAssert($"slave {slave().Id} {(running ? "is" : "is not")} running", () => slave().IsRunning == running);
|
||||||
|
|
||||||
private class TestSpectatorSlaveClock : TestManualClock, ISpectatorSlaveClock
|
private class TestSlaveClock : TestManualClock, ISlaveClock
|
||||||
{
|
{
|
||||||
public readonly Bindable<bool> WaitingOnFrames = new Bindable<bool>(true);
|
public readonly Bindable<bool> WaitingOnFrames = new Bindable<bool>(true);
|
||||||
IBindable<bool> ISpectatorSlaveClock.WaitingOnFrames => WaitingOnFrames;
|
IBindable<bool> ISlaveClock.WaitingOnFrames => WaitingOnFrames;
|
||||||
|
|
||||||
public bool IsCatchingUp { get; set; }
|
public bool IsCatchingUp { get; set; }
|
||||||
|
|
||||||
public readonly int Id;
|
public readonly int Id;
|
||||||
|
|
||||||
public TestSpectatorSlaveClock(int id)
|
public TestSlaveClock(int id)
|
||||||
{
|
{
|
||||||
Id = id;
|
Id = id;
|
||||||
|
|
@ -25,7 +25,7 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate
|
|||||||
|
|
||||||
private readonly PlayerInstance[] instances;
|
private readonly PlayerInstance[] instances;
|
||||||
private MasterGameplayClockContainer masterClockContainer;
|
private MasterGameplayClockContainer masterClockContainer;
|
||||||
private ISpectatorSyncManager syncManager;
|
private ISyncManager syncManager;
|
||||||
private PlayerGrid grid;
|
private PlayerGrid grid;
|
||||||
private MultiplayerSpectatorLeaderboard leaderboard;
|
private MultiplayerSpectatorLeaderboard leaderboard;
|
||||||
|
|
||||||
@ -66,12 +66,12 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate
|
|||||||
|
|
||||||
InternalChildren = new[]
|
InternalChildren = new[]
|
||||||
{
|
{
|
||||||
(Drawable)(syncManager = new SpectatorCatchUpSyncManager(masterClockContainer)),
|
(Drawable)(syncManager = new CatchUpSyncManager(masterClockContainer)),
|
||||||
masterClockContainer
|
masterClockContainer
|
||||||
};
|
};
|
||||||
|
|
||||||
for (int i = 0; i < UserIds.Length; i++)
|
for (int i = 0; i < UserIds.Length; i++)
|
||||||
grid.Add(instances[i] = new PlayerInstance(UserIds[i], new SpectatorCatchUpSlaveClock(masterClockContainer.GameplayClock)));
|
grid.Add(instances[i] = new PlayerInstance(UserIds[i], new CatchUpSlaveClock(masterClockContainer.GameplayClock)));
|
||||||
|
|
||||||
// Todo: This is not quite correct - it should be per-user to adjust for other mod combinations.
|
// Todo: This is not quite correct - it should be per-user to adjust for other mod combinations.
|
||||||
var playableBeatmap = Beatmap.Value.GetPlayableBeatmap(Ruleset.Value);
|
var playableBeatmap = Beatmap.Value.GetPlayableBeatmap(Ruleset.Value);
|
||||||
|
@ -12,9 +12,9 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate
|
|||||||
{
|
{
|
||||||
public class MultiplayerSpectatorPlayer : SpectatorPlayer
|
public class MultiplayerSpectatorPlayer : SpectatorPlayer
|
||||||
{
|
{
|
||||||
private readonly ISpectatorSlaveClock gameplayClock;
|
private readonly ISlaveClock gameplayClock;
|
||||||
|
|
||||||
public MultiplayerSpectatorPlayer(Score score, ISpectatorSlaveClock gameplayClock)
|
public MultiplayerSpectatorPlayer(Score score, ISlaveClock gameplayClock)
|
||||||
: base(score)
|
: base(score)
|
||||||
{
|
{
|
||||||
this.gameplayClock = gameplayClock;
|
this.gameplayClock = gameplayClock;
|
||||||
|
@ -18,7 +18,7 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate
|
|||||||
public bool PlayerLoaded => stack?.CurrentScreen is Player;
|
public bool PlayerLoaded => stack?.CurrentScreen is Player;
|
||||||
|
|
||||||
public readonly int UserId;
|
public readonly int UserId;
|
||||||
public readonly SpectatorCatchUpSlaveClock GameplayClock;
|
public readonly CatchUpSlaveClock GameplayClock;
|
||||||
|
|
||||||
public Score Score { get; private set; }
|
public Score Score { get; private set; }
|
||||||
|
|
||||||
@ -29,7 +29,7 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate
|
|||||||
private readonly LoadingLayer loadingLayer;
|
private readonly LoadingLayer loadingLayer;
|
||||||
private OsuScreenStack stack;
|
private OsuScreenStack stack;
|
||||||
|
|
||||||
public PlayerInstance(int userId, SpectatorCatchUpSlaveClock gameplayClock)
|
public PlayerInstance(int userId, CatchUpSlaveClock gameplayClock)
|
||||||
{
|
{
|
||||||
UserId = userId;
|
UserId = userId;
|
||||||
GameplayClock = gameplayClock;
|
GameplayClock = gameplayClock;
|
||||||
|
@ -8,9 +8,9 @@ using osu.Framework.Timing;
|
|||||||
namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate.Sync
|
namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate.Sync
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// A <see cref="ISpectatorSlaveClock"/> which catches up using rate adjustment.
|
/// A <see cref="ISlaveClock"/> which catches up using rate adjustment.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class SpectatorCatchUpSlaveClock : ISpectatorSlaveClock
|
public class CatchUpSlaveClock : ISlaveClock
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The catch up rate.
|
/// The catch up rate.
|
||||||
@ -19,7 +19,7 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate.Sync
|
|||||||
|
|
||||||
private readonly IFrameBasedClock masterClock;
|
private readonly IFrameBasedClock masterClock;
|
||||||
|
|
||||||
public SpectatorCatchUpSlaveClock(IFrameBasedClock masterClock)
|
public CatchUpSlaveClock(IFrameBasedClock masterClock)
|
||||||
{
|
{
|
||||||
this.masterClock = masterClock;
|
this.masterClock = masterClock;
|
||||||
}
|
}
|
@ -10,9 +10,9 @@ using osu.Framework.Timing;
|
|||||||
namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate.Sync
|
namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate.Sync
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// A <see cref="ISpectatorSyncManager"/> which synchronises de-synced slave clocks through catchup.
|
/// A <see cref="ISyncManager"/> which synchronises de-synced slave clocks through catchup.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public class SpectatorCatchUpSyncManager : Component, ISpectatorSyncManager
|
public class CatchUpSyncManager : Component, ISyncManager
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The offset from the master clock to which slaves should be synchronised to.
|
/// The offset from the master clock to which slaves should be synchronised to.
|
||||||
@ -37,19 +37,19 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate.Sync
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// The slave clocks.
|
/// The slave clocks.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private readonly List<ISpectatorSlaveClock> slaves = new List<ISpectatorSlaveClock>();
|
private readonly List<ISlaveClock> slaves = new List<ISlaveClock>();
|
||||||
|
|
||||||
private bool hasStarted;
|
private bool hasStarted;
|
||||||
private double? firstStartAttemptTime;
|
private double? firstStartAttemptTime;
|
||||||
|
|
||||||
public SpectatorCatchUpSyncManager(IAdjustableClock master)
|
public CatchUpSyncManager(IAdjustableClock master)
|
||||||
{
|
{
|
||||||
Master = master;
|
Master = master;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void AddSlave(ISpectatorSlaveClock clock) => slaves.Add(clock);
|
public void AddSlave(ISlaveClock clock) => slaves.Add(clock);
|
||||||
|
|
||||||
public void RemoveSlave(ISpectatorSlaveClock clock) => slaves.Remove(clock);
|
public void RemoveSlave(ISlaveClock clock) => slaves.Remove(clock);
|
||||||
|
|
||||||
protected override void Update()
|
protected override void Update()
|
||||||
{
|
{
|
@ -7,9 +7,9 @@ using osu.Framework.Timing;
|
|||||||
namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate.Sync
|
namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate.Sync
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// A clock which is used by <see cref="MultiplayerSpectatorPlayer"/>s and managed by an <see cref="ISpectatorSyncManager"/>.
|
/// A clock which is used by <see cref="MultiplayerSpectatorPlayer"/>s and managed by an <see cref="ISyncManager"/>.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public interface ISpectatorSlaveClock : IFrameBasedClock, IAdjustableClock
|
public interface ISlaveClock : IFrameBasedClock, IAdjustableClock
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Whether this clock is waiting on frames to continue playback.
|
/// Whether this clock is waiting on frames to continue playback.
|
@ -6,9 +6,9 @@ using osu.Framework.Timing;
|
|||||||
namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate.Sync
|
namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate.Sync
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Manages the synchronisation between one or more <see cref="ISpectatorSlaveClock"/>s in relation to a master clock.
|
/// Manages the synchronisation between one or more <see cref="ISlaveClock"/>s in relation to a master clock.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public interface ISpectatorSyncManager
|
public interface ISyncManager
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The master clock which slaves should synchronise to.
|
/// The master clock which slaves should synchronise to.
|
||||||
@ -16,15 +16,15 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Spectate.Sync
|
|||||||
IAdjustableClock Master { get; }
|
IAdjustableClock Master { get; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Adds an <see cref="ISpectatorSlaveClock"/> to manage.
|
/// Adds an <see cref="ISlaveClock"/> to manage.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="clock">The <see cref="ISpectatorSlaveClock"/> to add.</param>
|
/// <param name="clock">The <see cref="ISlaveClock"/> to add.</param>
|
||||||
void AddSlave(ISpectatorSlaveClock clock);
|
void AddSlave(ISlaveClock clock);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Removes an <see cref="ISpectatorSlaveClock"/>, stopping it from being managed by this <see cref="ISpectatorSyncManager"/>.
|
/// Removes an <see cref="ISlaveClock"/>, stopping it from being managed by this <see cref="ISyncManager"/>.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="clock">The <see cref="ISpectatorSlaveClock"/> to remove.</param>
|
/// <param name="clock">The <see cref="ISlaveClock"/> to remove.</param>
|
||||||
void RemoveSlave(ISpectatorSlaveClock clock);
|
void RemoveSlave(ISlaveClock clock);
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user