mirror of
https://github.com/ppy/osu
synced 2025-01-06 22:30:12 +00:00
Fix utterly broken test
- Was on wrong ruleset, so the mod/free mod sets did literally nothing - `assertHasFreeModButton` had a param that did nothing - Was checking `MatchingFilter` rather than `Visible`
This commit is contained in:
parent
4c78144d10
commit
9758e5f840
@ -94,6 +94,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
[TestCase(typeof(OsuModHidden), typeof(OsuModTraceable))] // Incompatible.
|
[TestCase(typeof(OsuModHidden), typeof(OsuModTraceable))] // Incompatible.
|
||||||
public void TestAllowedModDeselectedWhenRequired(Type allowedMod, Type requiredMod)
|
public void TestAllowedModDeselectedWhenRequired(Type allowedMod, Type requiredMod)
|
||||||
{
|
{
|
||||||
|
AddStep("change ruleset", () => Ruleset.Value = new OsuRuleset().RulesetInfo);
|
||||||
AddStep($"select {allowedMod.ReadableName()} as allowed", () => songSelect.FreeMods.Value = new[] { (Mod)Activator.CreateInstance(allowedMod) });
|
AddStep($"select {allowedMod.ReadableName()} as allowed", () => songSelect.FreeMods.Value = new[] { (Mod)Activator.CreateInstance(allowedMod) });
|
||||||
AddStep($"select {requiredMod.ReadableName()} as required", () => songSelect.Mods.Value = new[] { (Mod)Activator.CreateInstance(requiredMod) });
|
AddStep($"select {requiredMod.ReadableName()} as required", () => songSelect.Mods.Value = new[] { (Mod)Activator.CreateInstance(requiredMod) });
|
||||||
|
|
||||||
@ -102,17 +103,17 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
// A previous test's mod overlay could still be fading out.
|
// A previous test's mod overlay could still be fading out.
|
||||||
AddUntilStep("wait for only one freemod overlay", () => this.ChildrenOfType<FreeModSelectOverlay>().Count() == 1);
|
AddUntilStep("wait for only one freemod overlay", () => this.ChildrenOfType<FreeModSelectOverlay>().Count() == 1);
|
||||||
|
|
||||||
assertHasFreeModButton(allowedMod, false);
|
assertFreeModNotShown(allowedMod);
|
||||||
assertHasFreeModButton(requiredMod, false);
|
assertFreeModNotShown(requiredMod);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertHasFreeModButton(Type type, bool hasButton = true)
|
private void assertFreeModNotShown(Type type)
|
||||||
{
|
{
|
||||||
AddAssert($"{type.ReadableName()} {(hasButton ? "displayed" : "not displayed")} in freemod overlay",
|
AddAssert($"{type.ReadableName()} not displayed in freemod overlay",
|
||||||
() => this.ChildrenOfType<FreeModSelectOverlay>()
|
() => this.ChildrenOfType<FreeModSelectOverlay>()
|
||||||
.Single()
|
.Single()
|
||||||
.ChildrenOfType<ModPanel>()
|
.ChildrenOfType<ModPanel>()
|
||||||
.Where(panel => panel.MatchingFilter)
|
.Where(panel => panel.Visible)
|
||||||
.All(b => b.Mod.GetType() != type));
|
.All(b => b.Mod.GetType() != type));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user