mirror of
https://github.com/ppy/osu.git
synced 2025-01-28 02:02:53 +08:00
Fix Autoplay = false and AllowFail behavior
This commit is contained in:
parent
7a71a48892
commit
c3f840cc1a
@ -42,14 +42,14 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
PassCondition = () => ((ScoreAccessibleTestPlayer)Player).ScoreProcessor.JudgedHits >= 2
|
PassCondition = () => ((ScoreAccessibleTestPlayer)Player).ScoreProcessor.JudgedHits >= 2
|
||||||
});
|
});
|
||||||
|
|
||||||
protected override TestPlayer CreateReplayPlayer(Score score) => new ScoreAccessibleTestPlayer(score);
|
protected override TestPlayer CreateReplayPlayer(Score score, bool allowFail) => new ScoreAccessibleTestPlayer(score, allowFail);
|
||||||
|
|
||||||
private class ScoreAccessibleTestPlayer : TestPlayer
|
private class ScoreAccessibleTestPlayer : TestPlayer
|
||||||
{
|
{
|
||||||
public new ScoreProcessor ScoreProcessor => base.ScoreProcessor;
|
public new ScoreProcessor ScoreProcessor => base.ScoreProcessor;
|
||||||
|
|
||||||
public ScoreAccessibleTestPlayer(Score score)
|
public ScoreAccessibleTestPlayer(Score score, bool allowFail)
|
||||||
: base(score)
|
: base(score, allowFail)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,6 @@ using System.Collections.Generic;
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using JetBrains.Annotations;
|
using JetBrains.Annotations;
|
||||||
using osu.Game.Beatmaps;
|
using osu.Game.Beatmaps;
|
||||||
using osu.Game.Replays;
|
|
||||||
using osu.Game.Rulesets;
|
using osu.Game.Rulesets;
|
||||||
using osu.Game.Rulesets.Mods;
|
using osu.Game.Rulesets.Mods;
|
||||||
using osu.Game.Scoring;
|
using osu.Game.Scoring;
|
||||||
@ -56,22 +55,26 @@ namespace osu.Game.Tests.Visual
|
|||||||
|
|
||||||
var score = currentTest.Autoplay
|
var score = currentTest.Autoplay
|
||||||
? ruleset.GetAutoplayMod().CreateReplayScore(Beatmap.Value.GetPlayableBeatmap(ruleset.RulesetInfo, SelectedMods.Value))
|
? ruleset.GetAutoplayMod().CreateReplayScore(Beatmap.Value.GetPlayableBeatmap(ruleset.RulesetInfo, SelectedMods.Value))
|
||||||
: new Score { Replay = new Replay() };
|
: null;
|
||||||
|
|
||||||
return CreateReplayPlayer(score);
|
return CreateReplayPlayer(score, AllowFail);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Creates the <see cref="TestPlayer"/> for a test case.
|
/// Creates the <see cref="TestPlayer"/> for a test case.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="score">The <see cref="Score"/>.</param>
|
/// <param name="score">The <see cref="Score"/>.</param>
|
||||||
protected virtual TestPlayer CreateReplayPlayer(Score score) => new TestPlayer(score);
|
/// <param name="allowFail">Whether the player can fail.</param>
|
||||||
|
protected virtual TestPlayer CreateReplayPlayer(Score score, bool allowFail) => new TestPlayer(score, allowFail);
|
||||||
|
|
||||||
protected class TestPlayer : TestReplayPlayer
|
protected class TestPlayer : TestReplayPlayer
|
||||||
{
|
{
|
||||||
public TestPlayer(Score score)
|
protected override bool AllowFail { get; }
|
||||||
|
|
||||||
|
public TestPlayer(Score score, bool allowFail)
|
||||||
: base(score, false, false)
|
: base(score, false, false)
|
||||||
{
|
{
|
||||||
|
AllowFail = allowFail;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,6 +68,8 @@ namespace osu.Game.Tests.Visual
|
|||||||
|
|
||||||
Beatmap.Value = CreateWorkingBeatmap(beatmap);
|
Beatmap.Value = CreateWorkingBeatmap(beatmap);
|
||||||
|
|
||||||
|
SelectedMods.Value = Array.Empty<Mod>();
|
||||||
|
|
||||||
if (!AllowFail)
|
if (!AllowFail)
|
||||||
{
|
{
|
||||||
var noFailMod = ruleset.GetAllMods().FirstOrDefault(m => m is ModNoFail);
|
var noFailMod = ruleset.GetAllMods().FirstOrDefault(m => m is ModNoFail);
|
||||||
|
Loading…
Reference in New Issue
Block a user