2019-05-31 13:40:53 +08:00
|
|
|
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
|
2019-01-24 16:43:03 +08:00
|
|
|
// See the LICENCE file in the repository root for full licence text.
|
2018-04-20 16:30:27 +08:00
|
|
|
|
2019-05-07 12:02:19 +08:00
|
|
|
using System;
|
2019-05-10 17:21:07 +08:00
|
|
|
using System.Collections.Generic;
|
2019-04-09 14:05:03 +08:00
|
|
|
using System.Linq;
|
2018-08-02 18:47:50 +08:00
|
|
|
using System.Threading;
|
2019-12-06 12:47:34 +08:00
|
|
|
using System.Threading.Tasks;
|
2019-04-09 12:50:54 +08:00
|
|
|
using NUnit.Framework;
|
2018-04-20 16:30:27 +08:00
|
|
|
using osu.Framework.Allocation;
|
2019-09-25 18:24:05 +08:00
|
|
|
using osu.Framework.Audio;
|
2019-02-12 18:53:08 +08:00
|
|
|
using osu.Framework.Graphics;
|
2019-09-25 18:24:05 +08:00
|
|
|
using osu.Framework.Graphics.Containers;
|
2020-01-09 12:43:44 +08:00
|
|
|
using osu.Framework.Utils;
|
2019-01-23 19:52:00 +08:00
|
|
|
using osu.Framework.Screens;
|
2020-10-20 06:08:26 +08:00
|
|
|
using osu.Framework.Testing;
|
2019-10-02 00:15:40 +08:00
|
|
|
using osu.Game.Configuration;
|
2019-09-25 18:24:05 +08:00
|
|
|
using osu.Game.Graphics.Containers;
|
|
|
|
using osu.Game.Overlays;
|
|
|
|
using osu.Game.Overlays.Notifications;
|
2019-04-09 14:05:03 +08:00
|
|
|
using osu.Game.Rulesets.Mods;
|
2019-04-19 18:45:17 +08:00
|
|
|
using osu.Game.Rulesets.Osu;
|
2019-12-06 12:47:34 +08:00
|
|
|
using osu.Game.Rulesets.Osu.Mods;
|
2019-04-09 14:05:03 +08:00
|
|
|
using osu.Game.Rulesets.Scoring;
|
2019-04-25 18:56:57 +08:00
|
|
|
using osu.Game.Scoring;
|
2018-04-20 16:30:27 +08:00
|
|
|
using osu.Game.Screens.Play;
|
2019-07-05 14:50:31 +08:00
|
|
|
using osu.Game.Screens.Play.PlayerSettings;
|
2021-04-09 07:34:35 +08:00
|
|
|
using osu.Game.Utils;
|
2019-09-25 18:24:05 +08:00
|
|
|
using osuTK.Input;
|
2018-04-20 16:30:27 +08:00
|
|
|
|
2019-03-25 00:02:36 +08:00
|
|
|
namespace osu.Game.Tests.Visual.Gameplay
|
2018-04-20 16:30:27 +08:00
|
|
|
{
|
2020-11-16 22:53:54 +08:00
|
|
|
public class TestScenePlayerLoader : ScreenTestScene
|
2018-04-20 16:30:27 +08:00
|
|
|
{
|
2019-07-05 14:50:31 +08:00
|
|
|
private TestPlayerLoader loader;
|
2019-09-25 18:24:05 +08:00
|
|
|
private TestPlayer player;
|
|
|
|
|
2020-10-20 05:53:41 +08:00
|
|
|
private bool epilepsyWarning;
|
2020-07-21 16:48:11 +08:00
|
|
|
|
2019-09-25 18:24:05 +08:00
|
|
|
[Resolved]
|
|
|
|
private AudioManager audioManager { get; set; }
|
|
|
|
|
2019-10-02 00:15:40 +08:00
|
|
|
[Resolved]
|
|
|
|
private SessionStatics sessionStatics { get; set; }
|
|
|
|
|
2020-11-16 22:53:54 +08:00
|
|
|
[Cached]
|
|
|
|
private readonly NotificationOverlay notificationOverlay;
|
|
|
|
|
|
|
|
[Cached]
|
|
|
|
private readonly VolumeOverlay volumeOverlay;
|
|
|
|
|
2021-04-10 05:55:41 +08:00
|
|
|
[Cached(typeof(PowerStatus))]
|
|
|
|
private readonly LocalPowerStatus powerStatus = new LocalPowerStatus();
|
2021-04-09 07:34:35 +08:00
|
|
|
|
2020-11-16 22:53:54 +08:00
|
|
|
private readonly ChangelogOverlay changelogOverlay;
|
|
|
|
|
|
|
|
public TestScenePlayerLoader()
|
|
|
|
{
|
|
|
|
AddRange(new Drawable[]
|
|
|
|
{
|
|
|
|
notificationOverlay = new NotificationOverlay
|
|
|
|
{
|
|
|
|
Anchor = Anchor.TopRight,
|
|
|
|
Origin = Anchor.TopRight,
|
|
|
|
},
|
|
|
|
volumeOverlay = new VolumeOverlay
|
|
|
|
{
|
|
|
|
Anchor = Anchor.TopLeft,
|
|
|
|
Origin = Anchor.TopLeft,
|
|
|
|
},
|
|
|
|
changelogOverlay = new ChangelogOverlay()
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
[SetUp]
|
|
|
|
public void Setup() => Schedule(() =>
|
|
|
|
{
|
|
|
|
player = null;
|
|
|
|
audioManager.Volume.SetDefault();
|
|
|
|
});
|
|
|
|
|
2019-09-25 18:24:05 +08:00
|
|
|
/// <summary>
|
|
|
|
/// Sets the input manager child to a new test player loader container instance.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="interactive">If the test player should behave like the production one.</param>
|
|
|
|
/// <param name="beforeLoadAction">An action to run before player load but after bindable leases are returned.</param>
|
2020-11-16 22:53:54 +08:00
|
|
|
private void resetPlayer(bool interactive, Action beforeLoadAction = null)
|
2019-02-25 21:05:49 +08:00
|
|
|
{
|
2019-09-25 18:24:05 +08:00
|
|
|
beforeLoadAction?.Invoke();
|
2020-08-13 11:59:00 +08:00
|
|
|
|
2019-05-31 13:40:53 +08:00
|
|
|
Beatmap.Value = CreateWorkingBeatmap(new OsuRuleset().RulesetInfo);
|
2020-10-20 05:53:41 +08:00
|
|
|
Beatmap.Value.BeatmapInfo.EpilepsyWarning = epilepsyWarning;
|
2019-09-25 18:24:05 +08:00
|
|
|
|
2019-12-13 20:45:38 +08:00
|
|
|
foreach (var mod in SelectedMods.Value.OfType<IApplicableToTrack>())
|
2019-12-09 16:34:04 +08:00
|
|
|
mod.ApplyToTrack(Beatmap.Value.Track);
|
2019-12-06 12:47:34 +08:00
|
|
|
|
2020-11-16 22:53:54 +08:00
|
|
|
LoadScreen(loader = new TestPlayerLoader(() => player = new TestPlayer(interactive, interactive)));
|
2019-09-25 18:24:05 +08:00
|
|
|
}
|
2019-02-25 21:05:49 +08:00
|
|
|
|
2020-08-13 12:05:00 +08:00
|
|
|
[Test]
|
|
|
|
public void TestEarlyExitBeforePlayerConstruction()
|
|
|
|
{
|
2020-11-16 22:53:54 +08:00
|
|
|
AddStep("load dummy beatmap", () => resetPlayer(false, () => SelectedMods.Value = new[] { new OsuModNightcore() }));
|
2020-08-13 12:05:00 +08:00
|
|
|
AddUntilStep("wait for current", () => loader.IsCurrentScreen());
|
|
|
|
AddStep("exit loader", () => loader.Exit());
|
|
|
|
AddUntilStep("wait for not current", () => !loader.IsCurrentScreen());
|
|
|
|
AddAssert("player did not load", () => player == null);
|
|
|
|
AddUntilStep("player disposed", () => loader.DisposalTask == null);
|
|
|
|
AddAssert("mod rate still applied", () => Beatmap.Value.Track.Rate != 1);
|
2019-09-25 18:24:05 +08:00
|
|
|
}
|
2019-02-25 21:05:49 +08:00
|
|
|
|
2019-12-06 12:47:34 +08:00
|
|
|
/// <summary>
|
|
|
|
/// When <see cref="PlayerLoader"/> exits early, it has to wait for the player load task
|
|
|
|
/// to complete before running disposal on player. This previously caused an issue where mod
|
|
|
|
/// speed adjustments were undone too late, causing cross-screen pollution.
|
|
|
|
/// </summary>
|
|
|
|
[Test]
|
2020-08-13 12:05:00 +08:00
|
|
|
public void TestEarlyExitAfterPlayerConstruction()
|
2019-12-06 12:47:34 +08:00
|
|
|
{
|
2020-11-16 22:53:54 +08:00
|
|
|
AddStep("load dummy beatmap", () => resetPlayer(false, () => SelectedMods.Value = new[] { new OsuModNightcore() }));
|
2019-12-06 12:47:34 +08:00
|
|
|
AddUntilStep("wait for current", () => loader.IsCurrentScreen());
|
|
|
|
AddAssert("mod rate applied", () => Beatmap.Value.Track.Rate != 1);
|
2020-08-13 12:05:00 +08:00
|
|
|
AddUntilStep("wait for non-null player", () => player != null);
|
2019-12-06 12:47:34 +08:00
|
|
|
AddStep("exit loader", () => loader.Exit());
|
|
|
|
AddUntilStep("wait for not current", () => !loader.IsCurrentScreen());
|
|
|
|
AddAssert("player did not load", () => !player.IsLoaded);
|
|
|
|
AddUntilStep("player disposed", () => loader.DisposalTask?.IsCompleted == true);
|
|
|
|
AddAssert("mod rate still applied", () => Beatmap.Value.Track.Rate != 1);
|
|
|
|
}
|
|
|
|
|
2019-07-05 14:50:31 +08:00
|
|
|
[Test]
|
|
|
|
public void TestBlockLoadViaMouseMovement()
|
|
|
|
{
|
2020-11-16 22:53:54 +08:00
|
|
|
AddStep("load dummy beatmap", () => resetPlayer(false));
|
2019-07-06 14:25:53 +08:00
|
|
|
AddUntilStep("wait for current", () => loader.IsCurrentScreen());
|
2020-02-14 18:02:11 +08:00
|
|
|
|
|
|
|
AddUntilStep("wait for load ready", () =>
|
|
|
|
{
|
|
|
|
moveMouse();
|
2020-08-13 11:53:37 +08:00
|
|
|
return player?.LoadState == LoadState.Ready;
|
2020-02-14 18:02:11 +08:00
|
|
|
});
|
|
|
|
AddRepeatStep("move mouse", moveMouse, 20);
|
|
|
|
|
|
|
|
AddAssert("loader still active", () => loader.IsCurrentScreen());
|
|
|
|
AddUntilStep("loads after idle", () => !loader.IsCurrentScreen());
|
|
|
|
|
|
|
|
void moveMouse()
|
|
|
|
{
|
|
|
|
InputManager.MoveMouseTo(
|
|
|
|
loader.VisualSettings.ScreenSpaceDrawQuad.TopLeft
|
|
|
|
+ (loader.VisualSettings.ScreenSpaceDrawQuad.BottomRight - loader.VisualSettings.ScreenSpaceDrawQuad.TopLeft)
|
|
|
|
* RNG.NextSingle());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void TestBlockLoadViaFocus()
|
|
|
|
{
|
2020-11-16 22:53:54 +08:00
|
|
|
AddStep("load dummy beatmap", () => resetPlayer(false));
|
2020-02-14 18:02:11 +08:00
|
|
|
AddUntilStep("wait for current", () => loader.IsCurrentScreen());
|
|
|
|
|
2020-11-16 22:53:54 +08:00
|
|
|
AddStep("show focused overlay", () => changelogOverlay.Show());
|
|
|
|
AddUntilStep("overlay visible", () => changelogOverlay.IsPresent);
|
2020-02-14 18:02:11 +08:00
|
|
|
|
2020-11-16 22:53:54 +08:00
|
|
|
AddUntilStep("wait for load ready", () => player?.LoadState == LoadState.Ready);
|
2020-02-14 18:02:11 +08:00
|
|
|
AddRepeatStep("twiddle thumbs", () => { }, 20);
|
|
|
|
|
2019-07-05 14:50:31 +08:00
|
|
|
AddAssert("loader still active", () => loader.IsCurrentScreen());
|
2020-02-14 18:02:11 +08:00
|
|
|
|
2020-11-16 22:53:54 +08:00
|
|
|
AddStep("hide overlay", () => changelogOverlay.Hide());
|
2019-07-05 14:50:31 +08:00
|
|
|
AddUntilStep("loads after idle", () => !loader.IsCurrentScreen());
|
|
|
|
}
|
|
|
|
|
2019-04-09 12:50:54 +08:00
|
|
|
[Test]
|
|
|
|
public void TestLoadContinuation()
|
2018-04-20 16:30:27 +08:00
|
|
|
{
|
2019-05-07 12:02:19 +08:00
|
|
|
SlowLoadPlayer slowPlayer = null;
|
|
|
|
|
2018-08-02 18:47:50 +08:00
|
|
|
AddStep("load slow dummy beatmap", () =>
|
|
|
|
{
|
2020-11-16 22:53:54 +08:00
|
|
|
LoadScreen(loader = new TestPlayerLoader(() => slowPlayer = new SlowLoadPlayer(false, false)));
|
2019-05-07 12:02:19 +08:00
|
|
|
Scheduler.AddDelayed(() => slowPlayer.AllowLoad.Set(), 5000);
|
2018-08-02 18:47:50 +08:00
|
|
|
});
|
|
|
|
|
2019-05-07 12:02:19 +08:00
|
|
|
AddUntilStep("wait for player to be current", () => slowPlayer.IsCurrentScreen());
|
2018-08-02 18:47:50 +08:00
|
|
|
}
|
|
|
|
|
2019-04-09 14:05:03 +08:00
|
|
|
[Test]
|
|
|
|
public void TestModReinstantiation()
|
|
|
|
{
|
|
|
|
TestMod gameMod = null;
|
|
|
|
TestMod playerMod1 = null;
|
|
|
|
TestMod playerMod2 = null;
|
|
|
|
|
2020-11-16 22:53:54 +08:00
|
|
|
AddStep("load player", () => { resetPlayer(true, () => SelectedMods.Value = new[] { gameMod = new TestMod() }); });
|
2019-04-09 14:05:03 +08:00
|
|
|
|
2019-04-19 18:45:17 +08:00
|
|
|
AddUntilStep("wait for loader to become current", () => loader.IsCurrentScreen());
|
|
|
|
AddStep("mouse in centre", () => InputManager.MoveMouseTo(loader.ScreenSpaceDrawQuad.Centre));
|
|
|
|
AddUntilStep("wait for player to be current", () => player.IsCurrentScreen());
|
|
|
|
AddStep("retrieve mods", () => playerMod1 = (TestMod)player.Mods.Value.Single());
|
2019-04-09 14:05:03 +08:00
|
|
|
AddAssert("game mods not applied", () => gameMod.Applied == false);
|
|
|
|
AddAssert("player mods applied", () => playerMod1.Applied);
|
|
|
|
|
|
|
|
AddStep("restart player", () =>
|
|
|
|
{
|
2019-04-19 18:45:17 +08:00
|
|
|
var lastPlayer = player;
|
2019-04-09 14:05:03 +08:00
|
|
|
player = null;
|
2019-04-19 18:45:17 +08:00
|
|
|
lastPlayer.Restart();
|
2019-04-09 14:05:03 +08:00
|
|
|
});
|
|
|
|
|
2019-04-19 18:45:17 +08:00
|
|
|
AddUntilStep("wait for player to be current", () => player.IsCurrentScreen());
|
|
|
|
AddStep("retrieve mods", () => playerMod2 = (TestMod)player.Mods.Value.Single());
|
2019-04-09 14:05:03 +08:00
|
|
|
AddAssert("game mods not applied", () => gameMod.Applied == false);
|
|
|
|
AddAssert("player has different mods", () => playerMod1 != playerMod2);
|
|
|
|
AddAssert("player mods applied", () => playerMod2.Applied);
|
|
|
|
}
|
|
|
|
|
2020-01-09 02:55:35 +08:00
|
|
|
[Test]
|
|
|
|
public void TestModDisplayChanges()
|
|
|
|
{
|
|
|
|
var testMod = new TestMod();
|
|
|
|
|
2020-11-16 22:53:54 +08:00
|
|
|
AddStep("load player", () => resetPlayer(true));
|
2020-01-09 02:55:35 +08:00
|
|
|
|
|
|
|
AddUntilStep("wait for loader to become current", () => loader.IsCurrentScreen());
|
|
|
|
AddStep("set test mod in loader", () => loader.Mods.Value = new[] { testMod });
|
|
|
|
AddAssert("test mod is displayed", () => (TestMod)loader.DisplayedMods.Single() == testMod);
|
|
|
|
}
|
|
|
|
|
2019-09-25 18:24:05 +08:00
|
|
|
[Test]
|
2020-02-14 18:27:32 +08:00
|
|
|
public void TestMutedNotificationMasterVolume()
|
|
|
|
{
|
2020-08-13 11:59:00 +08:00
|
|
|
addVolumeSteps("master volume", () => audioManager.Volume.Value = 0, () => audioManager.Volume.IsDefault);
|
2020-02-14 18:27:32 +08:00
|
|
|
}
|
2019-09-26 20:05:43 +08:00
|
|
|
|
|
|
|
[Test]
|
2020-02-14 18:27:32 +08:00
|
|
|
public void TestMutedNotificationTrackVolume()
|
|
|
|
{
|
2020-08-13 11:59:00 +08:00
|
|
|
addVolumeSteps("music volume", () => audioManager.VolumeTrack.Value = 0, () => audioManager.VolumeTrack.IsDefault);
|
2020-02-14 18:27:32 +08:00
|
|
|
}
|
2019-09-26 20:05:43 +08:00
|
|
|
|
|
|
|
[Test]
|
2020-02-14 18:27:32 +08:00
|
|
|
public void TestMutedNotificationMuteButton()
|
|
|
|
{
|
2020-11-16 22:53:54 +08:00
|
|
|
addVolumeSteps("mute button", () => volumeOverlay.IsMuted.Value = true, () => !volumeOverlay.IsMuted.Value);
|
2020-02-14 18:27:32 +08:00
|
|
|
}
|
2019-09-26 20:05:43 +08:00
|
|
|
|
|
|
|
/// <remarks>
|
|
|
|
/// Created for avoiding copy pasting code for the same steps.
|
|
|
|
/// </remarks>
|
|
|
|
/// <param name="volumeName">What part of the volume system is checked</param>
|
|
|
|
/// <param name="beforeLoad">The action to be invoked to set the volume before loading</param>
|
|
|
|
/// <param name="assert">The function to be invoked and checked</param>
|
2020-08-13 11:59:00 +08:00
|
|
|
private void addVolumeSteps(string volumeName, Action beforeLoad, Func<bool> assert)
|
2019-09-25 18:24:05 +08:00
|
|
|
{
|
2019-10-02 00:15:40 +08:00
|
|
|
AddStep("reset notification lock", () => sessionStatics.GetBindable<bool>(Static.MutedAudioNotificationShownOnce).Value = false);
|
2019-09-25 18:24:05 +08:00
|
|
|
|
2020-11-16 22:53:54 +08:00
|
|
|
AddStep("load player", () => resetPlayer(false, beforeLoad));
|
2020-08-13 11:53:37 +08:00
|
|
|
AddUntilStep("wait for player", () => player?.LoadState == LoadState.Ready);
|
2019-09-25 18:24:05 +08:00
|
|
|
|
2020-11-16 22:53:54 +08:00
|
|
|
AddAssert("check for notification", () => notificationOverlay.UnreadCount.Value == 1);
|
2019-09-25 18:24:05 +08:00
|
|
|
AddStep("click notification", () =>
|
|
|
|
{
|
2020-11-16 22:53:54 +08:00
|
|
|
var scrollContainer = (OsuScrollContainer)notificationOverlay.Children.Last();
|
2019-09-25 18:24:05 +08:00
|
|
|
var flowContainer = scrollContainer.Children.OfType<FillFlowContainer<NotificationSection>>().First();
|
|
|
|
var notification = flowContainer.First();
|
|
|
|
|
|
|
|
InputManager.MoveMouseTo(notification);
|
|
|
|
InputManager.Click(MouseButton.Left);
|
|
|
|
});
|
|
|
|
|
2019-09-26 20:05:43 +08:00
|
|
|
AddAssert("check " + volumeName, assert);
|
2020-02-14 18:27:32 +08:00
|
|
|
|
|
|
|
AddUntilStep("wait for player load", () => player.IsLoaded);
|
2019-09-25 18:24:05 +08:00
|
|
|
}
|
|
|
|
|
2020-07-21 16:48:11 +08:00
|
|
|
[TestCase(true)]
|
|
|
|
[TestCase(false)]
|
|
|
|
public void TestEpilepsyWarning(bool warning)
|
|
|
|
{
|
2020-10-20 05:53:41 +08:00
|
|
|
AddStep("change epilepsy warning", () => epilepsyWarning = warning);
|
2020-11-16 22:53:54 +08:00
|
|
|
AddStep("load dummy beatmap", () => resetPlayer(false));
|
2020-10-20 06:08:26 +08:00
|
|
|
|
2020-07-21 16:48:11 +08:00
|
|
|
AddUntilStep("wait for current", () => loader.IsCurrentScreen());
|
2020-10-20 06:08:26 +08:00
|
|
|
|
|
|
|
AddAssert($"epilepsy warning {(warning ? "present" : "absent")}", () => this.ChildrenOfType<EpilepsyWarning>().Any() == warning);
|
2020-10-21 00:27:03 +08:00
|
|
|
|
|
|
|
if (warning)
|
|
|
|
{
|
|
|
|
AddUntilStep("sound volume decreased", () => Beatmap.Value.Track.AggregateVolume.Value == 0.25);
|
|
|
|
AddUntilStep("sound volume restored", () => Beatmap.Value.Track.AggregateVolume.Value == 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-10 05:55:41 +08:00
|
|
|
[TestCase(false, 1.0)] // not charging, above cutoff --> no warning
|
2021-04-09 07:34:35 +08:00
|
|
|
[TestCase(false, 0.2)] // not charging, at cutoff --> warning
|
2021-04-10 05:55:41 +08:00
|
|
|
[TestCase(true, 0.1)] // charging, below cutoff --> no warning
|
2021-04-09 07:34:35 +08:00
|
|
|
public void TestLowBatteryNotification(bool isCharging, double chargeLevel)
|
|
|
|
{
|
2021-04-10 05:55:41 +08:00
|
|
|
AddStep("reset notification lock", () => sessionStatics.GetBindable<bool>(Static.LowBatteryNotificationShownOnce).Value = false);
|
2021-04-09 07:34:35 +08:00
|
|
|
|
|
|
|
// set charge status and level
|
2021-04-09 08:28:23 +08:00
|
|
|
AddStep("load player", () => resetPlayer(false, () =>
|
2021-04-09 08:38:16 +08:00
|
|
|
{
|
2021-04-10 05:55:41 +08:00
|
|
|
powerStatus.SetCharging(isCharging);
|
|
|
|
powerStatus.SetChargeLevel(chargeLevel);
|
2021-04-09 08:28:23 +08:00
|
|
|
}));
|
2021-04-09 07:34:35 +08:00
|
|
|
AddUntilStep("wait for player", () => player?.LoadState == LoadState.Ready);
|
2021-04-10 05:55:41 +08:00
|
|
|
int warning = !isCharging && chargeLevel <= powerStatus.BatteryCutoff ? 1 : 0;
|
|
|
|
AddAssert($"notification {(warning == 1 ? "triggered" : "not triggered")}", () => notificationOverlay.UnreadCount.Value == warning);
|
2021-04-09 07:34:35 +08:00
|
|
|
AddStep("click notification", () =>
|
2021-04-09 09:53:42 +08:00
|
|
|
{
|
|
|
|
var scrollContainer = (OsuScrollContainer)notificationOverlay.Children.Last();
|
|
|
|
var flowContainer = scrollContainer.Children.OfType<FillFlowContainer<NotificationSection>>().First();
|
|
|
|
var notification = flowContainer.First();
|
2021-04-09 07:34:35 +08:00
|
|
|
|
2021-04-09 09:53:42 +08:00
|
|
|
InputManager.MoveMouseTo(notification);
|
|
|
|
InputManager.Click(MouseButton.Left);
|
|
|
|
});
|
2021-04-09 07:34:35 +08:00
|
|
|
AddUntilStep("wait for player load", () => player.IsLoaded);
|
|
|
|
}
|
|
|
|
|
2020-10-21 00:27:03 +08:00
|
|
|
[Test]
|
|
|
|
public void TestEpilepsyWarningEarlyExit()
|
|
|
|
{
|
|
|
|
AddStep("set epilepsy warning", () => epilepsyWarning = true);
|
2020-11-16 22:53:54 +08:00
|
|
|
AddStep("load dummy beatmap", () => resetPlayer(false));
|
2020-10-21 00:27:03 +08:00
|
|
|
|
|
|
|
AddUntilStep("wait for current", () => loader.IsCurrentScreen());
|
|
|
|
|
|
|
|
AddUntilStep("wait for epilepsy warning", () => loader.ChildrenOfType<EpilepsyWarning>().Single().Alpha > 0);
|
|
|
|
AddStep("exit early", () => loader.Exit());
|
|
|
|
|
|
|
|
AddUntilStep("sound volume restored", () => Beatmap.Value.Track.AggregateVolume.Value == 1);
|
2020-07-21 16:48:11 +08:00
|
|
|
}
|
|
|
|
|
2019-07-05 14:50:31 +08:00
|
|
|
private class TestPlayerLoader : PlayerLoader
|
|
|
|
{
|
|
|
|
public new VisualSettings VisualSettings => base.VisualSettings;
|
|
|
|
|
2019-12-06 12:47:34 +08:00
|
|
|
public new Task DisposalTask => base.DisposalTask;
|
|
|
|
|
2020-01-09 03:10:43 +08:00
|
|
|
public IReadOnlyList<Mod> DisplayedMods => MetadataInfo.Mods.Value;
|
2020-01-09 02:55:35 +08:00
|
|
|
|
2019-07-05 14:50:31 +08:00
|
|
|
public TestPlayerLoader(Func<Player> createPlayer)
|
|
|
|
: base(createPlayer)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-09 14:05:03 +08:00
|
|
|
private class TestMod : Mod, IApplicableToScoreProcessor
|
|
|
|
{
|
|
|
|
public override string Name => string.Empty;
|
|
|
|
public override string Acronym => string.Empty;
|
|
|
|
public override double ScoreMultiplier => 1;
|
|
|
|
|
|
|
|
public bool Applied { get; private set; }
|
|
|
|
|
|
|
|
public void ApplyToScoreProcessor(ScoreProcessor scoreProcessor)
|
|
|
|
{
|
|
|
|
Applied = true;
|
|
|
|
}
|
2019-04-25 18:56:57 +08:00
|
|
|
|
|
|
|
public ScoreRank AdjustRank(ScoreRank rank, double accuracy) => rank;
|
2019-04-09 14:05:03 +08:00
|
|
|
}
|
|
|
|
|
2020-03-05 10:25:07 +08:00
|
|
|
protected class SlowLoadPlayer : TestPlayer
|
2018-08-02 18:47:50 +08:00
|
|
|
{
|
2019-05-07 12:02:19 +08:00
|
|
|
public readonly ManualResetEventSlim AllowLoad = new ManualResetEventSlim(false);
|
2018-08-02 18:47:50 +08:00
|
|
|
|
2019-03-26 15:53:44 +08:00
|
|
|
public SlowLoadPlayer(bool allowPause = true, bool showResults = true)
|
|
|
|
: base(allowPause, showResults)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2018-08-02 18:47:50 +08:00
|
|
|
[BackgroundDependencyLoader]
|
|
|
|
private void load()
|
|
|
|
{
|
2019-05-07 12:02:19 +08:00
|
|
|
if (!AllowLoad.Wait(TimeSpan.FromSeconds(10)))
|
|
|
|
throw new TimeoutException();
|
2018-08-02 18:47:50 +08:00
|
|
|
}
|
2018-04-20 16:30:27 +08:00
|
|
|
}
|
2021-04-10 05:55:41 +08:00
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Mutable dummy PowerStatus class for <see cref="TestScenePlayerLoader.TestLowBatteryNotification"/>
|
|
|
|
/// </summary>
|
|
|
|
/// <inheritdoc/>
|
|
|
|
private class LocalPowerStatus : PowerStatus
|
|
|
|
{
|
|
|
|
private bool isCharging = true;
|
|
|
|
private double chargeLevel = 1;
|
|
|
|
|
|
|
|
public override double BatteryCutoff => 0.2;
|
|
|
|
|
|
|
|
public override bool IsCharging => isCharging;
|
|
|
|
|
|
|
|
public override double ChargeLevel => chargeLevel;
|
|
|
|
|
|
|
|
public void SetCharging(bool value)
|
|
|
|
{
|
|
|
|
isCharging = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void SetChargeLevel(double value)
|
|
|
|
{
|
|
|
|
chargeLevel = value;
|
|
|
|
}
|
|
|
|
}
|
2018-04-20 16:30:27 +08:00
|
|
|
}
|
|
|
|
}
|