mirror of
https://github.com/ppy/osu.git
synced 2025-01-23 21:12:54 +08:00
Recreate beatmap every test run in ModTestScene
This commit is contained in:
parent
23ef8fd909
commit
5dffc322af
@ -29,7 +29,7 @@ namespace osu.Game.Rulesets.Catch.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 2,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 2,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -59,7 +59,7 @@ namespace osu.Game.Rulesets.Catch.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true,
|
PassCondition = () => true,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -99,7 +99,7 @@ namespace osu.Game.Rulesets.Catch.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true,
|
PassCondition = () => true,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -28,7 +28,7 @@ namespace osu.Game.Rulesets.Catch.Tests.Mods
|
|||||||
Mod = new CatchModRelax(),
|
Mod = new CatchModRelax(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
PassCondition = passCondition,
|
PassCondition = passCondition,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -24,7 +24,7 @@ namespace osu.Game.Rulesets.Catch.Tests
|
|||||||
{
|
{
|
||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -19,7 +19,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new ManiaBeatmap(new StageDefinition(1))
|
Beatmap = () => new ManiaBeatmap(new StageDefinition(1))
|
||||||
{
|
{
|
||||||
HitObjects = new List<ManiaHitObject>
|
HitObjects = new List<ManiaHitObject>
|
||||||
{
|
{
|
||||||
|
@ -29,7 +29,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
&& Precision.AlmostEquals(Player.ScoreProcessor.Accuracy.Value, 0.9836, 0.01)
|
&& Precision.AlmostEquals(Player.ScoreProcessor.Accuracy.Value, 0.9836, 0.01)
|
||||||
&& Player.ScoreProcessor.TotalScore.Value == 946_049,
|
&& Player.ScoreProcessor.TotalScore.Value == 946_049,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
BeatmapInfo = { Ruleset = new ManiaRuleset().RulesetInfo },
|
BeatmapInfo = { Ruleset = new ManiaRuleset().RulesetInfo },
|
||||||
Difficulty = { OverallDifficulty = 10 },
|
Difficulty = { OverallDifficulty = 10 },
|
||||||
@ -56,7 +56,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
&& Player.ScoreProcessor.Accuracy.Value == 1
|
&& Player.ScoreProcessor.Accuracy.Value == 1
|
||||||
&& Player.ScoreProcessor.TotalScore.Value == (long)(1_000_000 * doubleTime.ScoreMultiplier),
|
&& Player.ScoreProcessor.TotalScore.Value == (long)(1_000_000 * doubleTime.ScoreMultiplier),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
BeatmapInfo = { Ruleset = new ManiaRuleset().RulesetInfo },
|
BeatmapInfo = { Ruleset = new ManiaRuleset().RulesetInfo },
|
||||||
Difficulty = { OverallDifficulty = 10 },
|
Difficulty = { OverallDifficulty = 10 },
|
||||||
|
@ -74,7 +74,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Mod = new ManiaModHidden(),
|
Mod = new ManiaModHidden(),
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = Enumerable.Range(1, 100).Select(i => (HitObject)new Note { StartTime = 1000 + 200 * i }).ToList(),
|
HitObjects = Enumerable.Range(1, 100).Select(i => (HitObject)new Note { StartTime = 1000 + 200 * i }).ToList(),
|
||||||
Breaks = { new BreakPeriod(2000, 28000) }
|
Breaks = { new BreakPeriod(2000, 28000) }
|
||||||
|
@ -74,7 +74,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Mod = new ManiaModHidden(),
|
Mod = new ManiaModHidden(),
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = Enumerable.Range(1, 100).Select(i => (HitObject)new Note { StartTime = 1000 + 200 * i }).ToList(),
|
HitObjects = Enumerable.Range(1, 100).Select(i => (HitObject)new Note { StartTime = 1000 + 200 * i }).ToList(),
|
||||||
Breaks = { new BreakPeriod(2000, 28000) }
|
Breaks = { new BreakPeriod(2000, 28000) }
|
||||||
|
@ -36,7 +36,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
Mod = new ManiaModPerfect(),
|
Mod = new ManiaModPerfect(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -59,7 +59,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
Mod = new ManiaModPerfect(),
|
Mod = new ManiaModPerfect(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true) && Player.Results.Count == 2,
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true) && Player.Results.Count == 2,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -28,7 +28,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
Mod = new ManiaModSuddenDeath(),
|
Mod = new ManiaModSuddenDeath(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -51,7 +51,7 @@ namespace osu.Game.Rulesets.Mania.Tests.Mods
|
|||||||
Mod = new ManiaModSuddenDeath(),
|
Mod = new ManiaModSuddenDeath(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true) && Player.Results.Count == 2,
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true) && Player.Results.Count == 2,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -23,7 +23,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModAlternate(),
|
Mod = new OsuModAlternate(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 4,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 4,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -68,7 +68,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModAlternate(),
|
Mod = new OsuModAlternate(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 1,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 1,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -101,7 +101,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModAlternate(),
|
Mod = new OsuModAlternate(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 1,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 1,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -131,7 +131,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModAlternate(),
|
Mod = new OsuModAlternate(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 2,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 2,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
Breaks =
|
Breaks =
|
||||||
{
|
{
|
||||||
|
@ -60,7 +60,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -90,7 +90,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Mod = mod,
|
Mod = mod,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects =
|
HitObjects =
|
||||||
{
|
{
|
||||||
|
@ -21,7 +21,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
public void TestNoAdjustment() => CreateModTest(new ModTestData
|
public void TestNoAdjustment() => CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Mod = new OsuModDifficultyAdjust(),
|
Mod = new OsuModDifficultyAdjust(),
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
BeatmapInfo = new BeatmapInfo
|
BeatmapInfo = new BeatmapInfo
|
||||||
{
|
{
|
||||||
|
@ -68,7 +68,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Player.GameplayClockContainer.CurrentTime < 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
Player.GameplayClockContainer.CurrentTime < 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
||||||
return Player.GameplayState.HasPassed && !sliderDimmedBeforeStartTime;
|
return Player.GameplayState.HasPassed && !sliderDimmedBeforeStartTime;
|
||||||
},
|
},
|
||||||
Beatmap = new OsuBeatmap
|
Beatmap = () => new OsuBeatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<OsuHitObject>
|
HitObjects = new List<OsuHitObject>
|
||||||
{
|
{
|
||||||
@ -114,7 +114,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Player.GameplayClockContainer.CurrentTime >= 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
Player.GameplayClockContainer.CurrentTime >= 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
||||||
return Player.GameplayState.HasPassed && sliderDimmed;
|
return Player.GameplayState.HasPassed && sliderDimmed;
|
||||||
},
|
},
|
||||||
Beatmap = new OsuBeatmap
|
Beatmap = () => new OsuBeatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<OsuHitObject>
|
HitObjects = new List<OsuHitObject>
|
||||||
{
|
{
|
||||||
@ -153,7 +153,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Player.GameplayClockContainer.CurrentTime >= 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
Player.GameplayClockContainer.CurrentTime >= 1000 && Player.ChildrenOfType<ModFlashlight<OsuHitObject>.Flashlight>().Single().FlashlightDim > 0;
|
||||||
return Player.GameplayState.HasPassed && sliderDimmed;
|
return Player.GameplayState.HasPassed && sliderDimmed;
|
||||||
},
|
},
|
||||||
Beatmap = new OsuBeatmap
|
Beatmap = () => new OsuBeatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<OsuHitObject>
|
HitObjects = new List<OsuHitObject>
|
||||||
{
|
{
|
||||||
|
@ -28,7 +28,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TestOsuModHidden(),
|
Mod = new TestOsuModHidden(),
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -63,7 +63,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TestOsuModHidden(),
|
Mod = new TestOsuModHidden(),
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -98,7 +98,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TestOsuModHidden(),
|
Mod = new TestOsuModHidden(),
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -122,7 +122,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new OsuModHidden { OnlyFadeApproachCircles = { Value = true } },
|
Mod = new OsuModHidden { OnlyFadeApproachCircles = { Value = true } },
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -21,7 +21,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
public void TestCorrectReflections([Values] OsuModMirror.MirrorType type, [Values] bool withStrictTracking) => CreateModTest(new ModTestData
|
public void TestCorrectReflections([Values] OsuModMirror.MirrorType type, [Values] bool withStrictTracking) => CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
Beatmap = new OsuBeatmap
|
Beatmap = () => new OsuBeatmap
|
||||||
{
|
{
|
||||||
HitObjects =
|
HitObjects =
|
||||||
{
|
{
|
||||||
|
@ -31,7 +31,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true,
|
PassCondition = () => true,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -71,7 +71,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true,
|
PassCondition = () => true,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -113,7 +113,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
},
|
},
|
||||||
Autoplay = true,
|
Autoplay = true,
|
||||||
PassCondition = () => true,
|
PassCondition = () => true,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -61,7 +61,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModPerfect(),
|
Mod = new OsuModPerfect(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true),
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -55,10 +55,10 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
PassCondition = () => true
|
PassCondition = () => true
|
||||||
});
|
});
|
||||||
|
|
||||||
private OsuBeatmap jumpBeatmap =>
|
private OsuBeatmap jumpBeatmap() =>
|
||||||
createHitCircleBeatmap(new[] { 100, 200, 300, 400 }, 8, 300, 2 * 300);
|
createHitCircleBeatmap(new[] { 100, 200, 300, 400 }, 8, 300, 2 * 300);
|
||||||
|
|
||||||
private OsuBeatmap streamBeatmap =>
|
private OsuBeatmap streamBeatmap() =>
|
||||||
createHitCircleBeatmap(new[] { 10, 20, 30, 40, 50, 60, 70, 80 }, 16, 150, 4 * 150);
|
createHitCircleBeatmap(new[] { 10, 20, 30, 40, 50, 60, 70, 80 }, 16, 150, 4 * 150);
|
||||||
|
|
||||||
private OsuBeatmap createHitCircleBeatmap(IEnumerable<int> spacings, int objectsPerSpacing, int interval, int beatLength)
|
private OsuBeatmap createHitCircleBeatmap(IEnumerable<int> spacings, int objectsPerSpacing, int interval, int beatLength)
|
||||||
|
@ -22,7 +22,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSingleTap(),
|
Mod = new OsuModSingleTap(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 2,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 2,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -62,7 +62,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSingleTap(),
|
Mod = new OsuModSingleTap(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 1,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 1,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -100,7 +100,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSingleTap(),
|
Mod = new OsuModSingleTap(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 1,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 1,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -130,7 +130,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSingleTap(),
|
Mod = new OsuModSingleTap(),
|
||||||
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 2,
|
PassCondition = () => Player.ScoreProcessor.Combo.Value == 0 && Player.ScoreProcessor.HighestCombo.Value == 2,
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
Breaks =
|
Breaks =
|
||||||
{
|
{
|
||||||
|
@ -130,7 +130,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private Beatmap singleSpinnerBeatmap => new Beatmap
|
private Beatmap singleSpinnerBeatmap() => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -20,7 +20,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new OsuModStrictTracking(),
|
Mod = new OsuModStrictTracking(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -30,7 +30,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSuddenDeath(),
|
Mod = new OsuModSuddenDeath(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(false),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -55,7 +55,7 @@ namespace osu.Game.Rulesets.Osu.Tests.Mods
|
|||||||
Mod = new OsuModSuddenDeath(),
|
Mod = new OsuModSuddenDeath(),
|
||||||
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true),
|
PassCondition = () => ((ModFailConditionTestPlayer)Player).CheckFailed(true),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
|
@ -36,7 +36,7 @@ namespace osu.Game.Rulesets.Osu.Tests
|
|||||||
{
|
{
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Mod = new TestAutoMod(),
|
Mod = new TestAutoMod(),
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = { new HitCircle { Position = new Vector2(256, 192) } }
|
HitObjects = { new HitCircle { Position = new Vector2(256, 192) } }
|
||||||
},
|
},
|
||||||
@ -47,18 +47,16 @@ namespace osu.Game.Rulesets.Osu.Tests
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestMissViaNotHitting()
|
public void TestMissViaNotHitting()
|
||||||
{
|
{
|
||||||
var beatmap = new Beatmap
|
|
||||||
{
|
|
||||||
HitObjects = { new HitCircle { Position = new Vector2(256, 192) } }
|
|
||||||
};
|
|
||||||
|
|
||||||
var hitWindows = new OsuHitWindows();
|
var hitWindows = new OsuHitWindows();
|
||||||
hitWindows.SetDifficulty(beatmap.Difficulty.OverallDifficulty);
|
hitWindows.SetDifficulty(IBeatmapDifficultyInfo.DEFAULT_DIFFICULTY);
|
||||||
|
|
||||||
CreateModTest(new ModTestData
|
CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = beatmap,
|
Beatmap = () => new Beatmap
|
||||||
|
{
|
||||||
|
HitObjects = { new HitCircle { Position = new Vector2(256, 192) } }
|
||||||
|
},
|
||||||
PassCondition = () => Player.Results.Count > 0 && Player.Results[0].TimeOffset >= hitWindows.WindowFor(HitResult.Meh) && !Player.Results[0].IsHit
|
PassCondition = () => Player.Results.Count > 0 && Player.Results[0].TimeOffset >= hitWindows.WindowFor(HitResult.Meh) && !Player.Results[0].IsHit
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -31,6 +31,13 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
const double hit_time = 1;
|
const double hit_time = 1;
|
||||||
|
|
||||||
|
CreateModTest(new ModTestData
|
||||||
|
{
|
||||||
|
Mod = new TaikoModHidden(),
|
||||||
|
Autoplay = true,
|
||||||
|
PassCondition = checkAllMaxResultJudgements(2),
|
||||||
|
Beatmap = () =>
|
||||||
|
{
|
||||||
var beatmap = new Beatmap<TaikoHitObject>
|
var beatmap = new Beatmap<TaikoHitObject>
|
||||||
{
|
{
|
||||||
HitObjects = new List<TaikoHitObject>
|
HitObjects = new List<TaikoHitObject>
|
||||||
@ -58,13 +65,8 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
};
|
};
|
||||||
|
|
||||||
beatmap.ControlPointInfo.Add(0, new EffectControlPoint { ScrollSpeed = 0.1f });
|
beatmap.ControlPointInfo.Add(0, new EffectControlPoint { ScrollSpeed = 0.1f });
|
||||||
|
return beatmap;
|
||||||
CreateModTest(new ModTestData
|
},
|
||||||
{
|
|
||||||
Mod = new TaikoModHidden(),
|
|
||||||
Autoplay = true,
|
|
||||||
PassCondition = checkAllMaxResultJudgements(2),
|
|
||||||
Beatmap = beatmap,
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -15,7 +15,26 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestRelax()
|
public void TestRelax()
|
||||||
{
|
{
|
||||||
var beatmap = new TaikoBeatmap
|
var beatmapForReplay = createBeatmap();
|
||||||
|
|
||||||
|
foreach (var ho in beatmapForReplay.HitObjects)
|
||||||
|
ho.ApplyDefaults(beatmapForReplay.ControlPointInfo, beatmapForReplay.Difficulty);
|
||||||
|
|
||||||
|
var replay = new TaikoAutoGenerator(beatmapForReplay).Generate();
|
||||||
|
|
||||||
|
foreach (var frame in replay.Frames.OfType<TaikoReplayFrame>().Where(r => r.Actions.Any()))
|
||||||
|
frame.Actions = [TaikoAction.LeftCentre];
|
||||||
|
|
||||||
|
CreateModTest(new ModTestData
|
||||||
|
{
|
||||||
|
Mod = new TaikoModRelax(),
|
||||||
|
Beatmap = createBeatmap,
|
||||||
|
ReplayFrames = replay.Frames,
|
||||||
|
Autoplay = false,
|
||||||
|
PassCondition = () => Player.ScoreProcessor.HasCompleted.Value && Player.ScoreProcessor.Accuracy.Value == 1,
|
||||||
|
});
|
||||||
|
|
||||||
|
TaikoBeatmap createBeatmap() => new TaikoBeatmap
|
||||||
{
|
{
|
||||||
HitObjects =
|
HitObjects =
|
||||||
{
|
{
|
||||||
@ -25,22 +44,6 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
new Swell { StartTime = 1250, Duration = 500 },
|
new Swell { StartTime = 1250, Duration = 500 },
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
foreach (var ho in beatmap.HitObjects)
|
|
||||||
ho.ApplyDefaults(beatmap.ControlPointInfo, beatmap.Difficulty);
|
|
||||||
|
|
||||||
var replay = new TaikoAutoGenerator(beatmap).Generate();
|
|
||||||
|
|
||||||
foreach (var frame in replay.Frames.OfType<TaikoReplayFrame>().Where(r => r.Actions.Any()))
|
|
||||||
frame.Actions = [TaikoAction.LeftCentre];
|
|
||||||
|
|
||||||
CreateModTest(new ModTestData
|
|
||||||
{
|
|
||||||
Mod = new TaikoModRelax(),
|
|
||||||
Beatmap = beatmap,
|
|
||||||
ReplayFrames = replay.Frames,
|
|
||||||
Autoplay = false,
|
|
||||||
PassCondition = () => Player.ScoreProcessor.HasCompleted.Value && Player.ScoreProcessor.Accuracy.Value == 1,
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,7 +20,7 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TaikoModSingleTap(),
|
Mod = new TaikoModSingleTap(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -65,7 +65,7 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TaikoModSingleTap(),
|
Mod = new TaikoModSingleTap(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -110,7 +110,7 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TaikoModSingleTap(),
|
Mod = new TaikoModSingleTap(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -136,7 +136,7 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TaikoModSingleTap(),
|
Mod = new TaikoModSingleTap(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = new List<HitObject>
|
HitObjects = new List<HitObject>
|
||||||
{
|
{
|
||||||
@ -175,7 +175,7 @@ namespace osu.Game.Rulesets.Taiko.Tests.Mods
|
|||||||
{
|
{
|
||||||
Mod = new TaikoModSingleTap(),
|
Mod = new TaikoModSingleTap(),
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
Breaks =
|
Breaks =
|
||||||
{
|
{
|
||||||
|
@ -35,7 +35,7 @@ namespace osu.Game.Tests.Visual.Mods
|
|||||||
MinimumAccuracy = { Value = 0.6 }
|
MinimumAccuracy = { Value = 0.6 }
|
||||||
},
|
},
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = Enumerable.Range(0, 5).Select(i => new HitCircle
|
HitObjects = Enumerable.Range(0, 5).Select(i => new HitCircle
|
||||||
{
|
{
|
||||||
@ -56,7 +56,7 @@ namespace osu.Game.Tests.Visual.Mods
|
|||||||
AccuracyJudgeMode = { Value = ModAccuracyChallenge.AccuracyMode.Standard }
|
AccuracyJudgeMode = { Value = ModAccuracyChallenge.AccuracyMode.Standard }
|
||||||
},
|
},
|
||||||
Autoplay = false,
|
Autoplay = false,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
HitObjects = Enumerable.Range(0, 5).Select(i => new HitCircle
|
HitObjects = Enumerable.Range(0, 5).Select(i => new HitCircle
|
||||||
{
|
{
|
||||||
|
@ -20,7 +20,7 @@ namespace osu.Game.Tests.Visual
|
|||||||
protected void CreateHitObjectTest(HitObjectTestData testData, bool shouldMiss) => CreateModTest(new ModTestData
|
protected void CreateHitObjectTest(HitObjectTestData testData, bool shouldMiss) => CreateModTest(new ModTestData
|
||||||
{
|
{
|
||||||
Mod = mod,
|
Mod = mod,
|
||||||
Beatmap = new Beatmap
|
Beatmap = () => new Beatmap
|
||||||
{
|
{
|
||||||
BeatmapInfo = { Ruleset = CreatePlayerRuleset().RulesetInfo },
|
BeatmapInfo = { Ruleset = CreatePlayerRuleset().RulesetInfo },
|
||||||
HitObjects = { testData.HitObject }
|
HitObjects = { testData.HitObject }
|
||||||
|
@ -40,7 +40,7 @@ namespace osu.Game.Tests.Visual
|
|||||||
base.TearDownSteps();
|
base.TearDownSteps();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected sealed override IBeatmap CreateBeatmap(RulesetInfo ruleset) => CurrentTestData?.Beatmap ?? base.CreateBeatmap(ruleset);
|
protected sealed override IBeatmap CreateBeatmap(RulesetInfo ruleset) => CurrentTestData?.Beatmap?.Invoke() ?? base.CreateBeatmap(ruleset);
|
||||||
|
|
||||||
protected sealed override TestPlayer CreatePlayer(Ruleset ruleset)
|
protected sealed override TestPlayer CreatePlayer(Ruleset ruleset)
|
||||||
{
|
{
|
||||||
@ -107,7 +107,7 @@ namespace osu.Game.Tests.Visual
|
|||||||
/// The beatmap for this test case.
|
/// The beatmap for this test case.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[CanBeNull]
|
[CanBeNull]
|
||||||
public IBeatmap Beatmap;
|
public Func<IBeatmap> Beatmap;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The conditions that cause this test case to pass.
|
/// The conditions that cause this test case to pass.
|
||||||
|
Loading…
Reference in New Issue
Block a user