Add failing test coverage of user pausing or quick exiting during cooldown

This commit is contained in:
Dean Herbert 2021-02-15 14:36:14 +09:00
parent 2b69c7b325
commit 25f5120fdf
1 changed files with 37 additions and 5 deletions

View File

@ -90,19 +90,47 @@ public void TestResumeWithResumeOverlaySkipped()
}
[Test]
public void TestPauseDuringCooldownTooSoon()
public void TestExternalPauseDuringCooldownTooSoon()
{
AddStep("move cursor outside", () => InputManager.MoveMouseTo(Player.ScreenSpaceDrawQuad.TopLeft - new Vector2(10)));
pauseAndConfirm();
resume();
pause();
pauseExternally();
confirmResumed();
AddAssert("not exited", () => Player.IsCurrentScreen());
}
[Test]
public void TestUserPauseDuringCooldownTooSoon()
{
AddStep("move cursor outside", () => InputManager.MoveMouseTo(Player.ScreenSpaceDrawQuad.TopLeft - new Vector2(10)));
pauseAndConfirm();
resume();
AddStep("pause via exit key", () => Player.ExitViaPause());
confirmResumed();
AddAssert("not exited", () => Player.IsCurrentScreen());
}
[Test]
public void TestQuickExitDuringCooldownTooSoon()
{
AddStep("move cursor outside", () => InputManager.MoveMouseTo(Player.ScreenSpaceDrawQuad.TopLeft - new Vector2(10)));
pauseAndConfirm();
resume();
AddStep("pause via exit key", () => Player.ExitViaQuickExit());
confirmResumed();
AddAssert("exited", () => !Player.IsCurrentScreen());
}
[Test]
public void TestExitSoonAfterResumeSucceeds()
{
@ -125,7 +153,7 @@ public void TestPauseAfterFail()
confirmClockRunning(false);
pause();
pauseExternally();
confirmPausedWithNoOverlay();
AddAssert("fail overlay still shown", () => Player.FailOverlayVisible);
@ -237,7 +265,7 @@ public void TestPauseSoundLoop()
private void pauseAndConfirm()
{
pause();
pauseExternally();
confirmPaused();
}
@ -286,7 +314,7 @@ private void confirmNoTrackAdjustments()
}
private void restart() => AddStep("restart", () => Player.Restart());
private void pause() => AddStep("pause", () => Player.Pause());
private void pauseExternally() => AddStep("pause", () => Player.Pause());
private void resume() => AddStep("resume", () => Player.Resume());
private void confirmPauseOverlayShown(bool isShown) =>
@ -305,6 +333,10 @@ protected class PausePlayer : TestPlayer
public bool PauseOverlayVisible => PauseOverlay.State.Value == Visibility.Visible;
public void ExitViaPause() => PerformExit(true);
public void ExitViaQuickExit() => PerformExit(false);
public override void OnEntering(IScreen last)
{
base.OnEntering(last);