osu/osu.Game.Tests/Visual/SongSelect/TestSceneBeatmapInfoWedge.cs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

318 lines
12 KiB
C#
Raw Normal View History

// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
2018-04-13 09:19:50 +00:00
2022-06-17 07:37:17 +00:00
#nullable disable
2023-12-22 17:11:37 +00:00
using System;
using System.Collections.Generic;
using System.Linq;
using JetBrains.Annotations;
2018-03-02 06:34:31 +00:00
using NUnit.Framework;
2017-12-12 13:44:12 +00:00
using osu.Framework.Allocation;
using osu.Framework.Graphics;
2021-05-05 16:50:49 +00:00
using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.UserInterface;
using osu.Framework.Testing;
2017-12-12 13:44:12 +00:00
using osu.Game.Beatmaps;
2021-08-22 17:01:26 +00:00
using osu.Game.Beatmaps.ControlPoints;
2023-12-23 07:25:52 +00:00
using osu.Game.Extensions;
using osu.Game.Graphics.Sprites;
using osu.Game.Resources.Localisation.Web;
using osu.Game.Rulesets;
using osu.Game.Rulesets.Catch;
using osu.Game.Rulesets.Mania;
using osu.Game.Rulesets.Objects;
using osu.Game.Rulesets.Objects.Legacy;
using osu.Game.Rulesets.Objects.Types;
using osu.Game.Rulesets.Osu;
2021-08-22 17:01:26 +00:00
using osu.Game.Rulesets.Osu.Mods;
using osu.Game.Rulesets.Taiko;
2017-12-12 13:44:12 +00:00
using osu.Game.Screens.Select;
2019-03-24 16:02:36 +00:00
using osuTK;
2018-04-13 09:19:50 +00:00
2019-03-24 16:02:36 +00:00
namespace osu.Game.Tests.Visual.SongSelect
2017-12-12 13:44:12 +00:00
{
2018-03-02 06:34:31 +00:00
[TestFixture]
public partial class TestSceneBeatmapInfoWedge : OsuTestScene
2017-12-12 13:44:12 +00:00
{
private RulesetStore rulesets;
private TestBeatmapInfoWedge infoWedge;
2018-04-19 11:44:38 +00:00
private readonly List<IBeatmap> beatmaps = new List<IBeatmap>();
2018-04-13 09:19:50 +00:00
[BackgroundDependencyLoader]
private void load(RulesetStore rulesets)
2017-12-12 13:44:12 +00:00
{
this.rulesets = rulesets;
}
2018-04-13 09:19:50 +00:00
protected override void LoadComplete()
{
base.LoadComplete();
2018-04-13 09:19:50 +00:00
Add(infoWedge = new TestBeatmapInfoWedge
2017-12-12 13:44:12 +00:00
{
Size = new Vector2(0.5f, 245),
RelativeSizeAxes = Axes.X,
2017-12-26 11:18:47 +00:00
Margin = new MarginPadding { Top = 20 }
2017-12-12 13:44:12 +00:00
});
2018-04-13 09:19:50 +00:00
AddStep("show", () => infoWedge.Show());
2018-04-13 09:19:50 +00:00
selectBeatmap(Beatmap.Value.Beatmap);
2019-03-19 08:24:26 +00:00
AddWaitStep("wait for select", 3);
2018-04-13 09:19:50 +00:00
AddStep("hide", () => { infoWedge.Hide(); });
2018-04-13 09:19:50 +00:00
2019-03-19 08:24:26 +00:00
AddWaitStep("wait for hide", 3);
2018-04-13 09:19:50 +00:00
AddStep("show", () => { infoWedge.Show(); });
2018-04-13 09:19:50 +00:00
AddSliderStep("change star difficulty", 0, 11.9, 5.55, v =>
{
foreach (var hasCurrentValue in infoWedge.Info.ChildrenOfType<IHasCurrentValue<StarDifficulty>>())
hasCurrentValue.Current.Value = new StarDifficulty(v, 0);
});
foreach (var rulesetInfo in rulesets.AvailableRulesets)
2017-12-12 13:44:12 +00:00
{
2018-06-26 09:59:13 +00:00
var instance = rulesetInfo.CreateInstance();
2018-04-23 17:07:16 +00:00
var testBeatmap = createTestBeatmap(rulesetInfo);
2018-04-23 17:07:16 +00:00
beatmaps.Add(testBeatmap);
2018-04-13 09:19:50 +00:00
setRuleset(rulesetInfo);
2018-06-26 09:59:13 +00:00
2018-04-23 17:07:16 +00:00
selectBeatmap(testBeatmap);
2018-04-13 09:19:50 +00:00
2018-06-26 09:59:13 +00:00
testBeatmapLabels(instance);
2018-06-26 09:59:13 +00:00
switch (instance)
{
2022-06-24 12:25:23 +00:00
case OsuRuleset:
testInfoLabels(5);
break;
2019-04-01 03:44:46 +00:00
2022-06-24 12:25:23 +00:00
case TaikoRuleset:
2017-12-23 10:56:53 +00:00
testInfoLabels(5);
break;
2019-04-01 03:44:46 +00:00
2022-06-24 12:25:23 +00:00
case CatchRuleset:
testInfoLabels(5);
break;
2019-04-01 03:44:46 +00:00
2022-06-24 12:25:23 +00:00
case ManiaRuleset:
testInfoLabels(4);
break;
2019-04-01 03:44:46 +00:00
2017-12-23 10:56:53 +00:00
default:
testInfoLabels(2);
break;
}
}
}
2018-04-13 09:19:50 +00:00
private void testBeatmapLabels(Ruleset ruleset)
{
AddAssert("check version", () => infoWedge.Info.VersionLabel.Current.Value == $"{ruleset.ShortName}Version");
AddAssert("check title", () => infoWedge.Info.TitleLabel.Current.Value == $"{ruleset.ShortName}Title");
AddAssert("check artist", () => infoWedge.Info.ArtistLabel.Current.Value == $"{ruleset.ShortName}Artist");
2021-04-19 17:24:58 +00:00
AddAssert("check author", () => infoWedge.Info.MapperContainer.ChildrenOfType<OsuSpriteText>().Any(s => s.Current.Value == $"{ruleset.ShortName}Author"));
2017-12-23 10:56:53 +00:00
}
2018-04-13 09:19:50 +00:00
2017-12-23 10:56:53 +00:00
private void testInfoLabels(int expectedCount)
{
2021-04-19 21:41:51 +00:00
AddAssert("check info labels exists", () => infoWedge.Info.ChildrenOfType<BeatmapInfoWedge.WedgeInfoText.InfoLabel>().Any());
AddAssert("check info labels count", () => infoWedge.Info.ChildrenOfType<BeatmapInfoWedge.WedgeInfoText.InfoLabel>().Count() == expectedCount);
}
2018-04-13 09:19:50 +00:00
2022-05-20 14:29:37 +00:00
[SetUpSteps]
public void SetUpSteps()
{
AddStep("reset mods", () => SelectedMods.SetDefault());
}
2019-09-24 23:23:36 +00:00
[Test]
2019-09-24 23:48:22 +00:00
public void TestNullBeatmap()
{
selectBeatmap(null);
AddAssert("check empty version", () => string.IsNullOrEmpty(infoWedge.Info.VersionLabel.Current.Value));
AddAssert("check default title", () => infoWedge.Info.TitleLabel.Current.Value == Beatmap.Default.BeatmapInfo.Metadata.Title);
AddAssert("check default artist", () => infoWedge.Info.ArtistLabel.Current.Value == Beatmap.Default.BeatmapInfo.Metadata.Artist);
2021-04-19 17:24:58 +00:00
AddAssert("check empty author", () => !infoWedge.Info.MapperContainer.ChildrenOfType<OsuSpriteText>().Any());
2021-04-19 21:41:51 +00:00
AddAssert("check no info labels", () => !infoWedge.Info.ChildrenOfType<BeatmapInfoWedge.WedgeInfoText.InfoLabel>().Any());
}
2018-04-13 09:19:50 +00:00
2019-09-24 23:21:08 +00:00
[Test]
2019-09-24 23:48:22 +00:00
public void TestTruncation()
2019-09-24 23:21:08 +00:00
{
selectBeatmap(createLongMetadata());
}
2021-08-22 17:01:26 +00:00
[Test]
public void TestBPMUpdates()
{
2022-05-20 14:29:37 +00:00
const double bpm = 120;
2021-08-22 17:01:26 +00:00
IBeatmap beatmap = createTestBeatmap(new OsuRuleset().RulesetInfo);
beatmap.ControlPointInfo.Add(0, new TimingControlPoint { BeatLength = 60 * 1000 / bpm });
OsuModDoubleTime doubleTime = null;
selectBeatmap(beatmap);
2022-05-20 14:29:37 +00:00
checkDisplayedBPM($"{bpm}");
2021-08-22 17:01:26 +00:00
AddStep("select DT", () => SelectedMods.Value = new[] { doubleTime = new OsuModDoubleTime() });
2022-05-20 14:29:37 +00:00
checkDisplayedBPM($"{bpm * 1.5f}");
2021-08-22 17:01:26 +00:00
AddStep("change DT rate", () => doubleTime.SpeedChange.Value = 2);
2022-05-20 14:29:37 +00:00
checkDisplayedBPM($"{bpm * 2}");
}
[TestCase(120, 125, null, "120-125 (mostly 120)")]
[TestCase(120, 120.6, null, "120-121 (mostly 120)")]
[TestCase(120, 120.4, null, "120")]
[TestCase(120, 120.6, "DT", "180-182 (mostly 180)")]
[TestCase(120, 120.4, "DT", "180")]
public void TestVaryingBPM(double commonBpm, double otherBpm, string mod, string expectedDisplay)
2022-05-20 14:29:37 +00:00
{
IBeatmap beatmap = createTestBeatmap(new OsuRuleset().RulesetInfo);
beatmap.ControlPointInfo.Add(0, new TimingControlPoint { BeatLength = 60 * 1000 / commonBpm });
beatmap.ControlPointInfo.Add(100, new TimingControlPoint { BeatLength = 60 * 1000 / otherBpm });
beatmap.ControlPointInfo.Add(200, new TimingControlPoint { BeatLength = 60 * 1000 / commonBpm });
2021-08-22 17:01:26 +00:00
if (mod != null)
AddStep($"select {mod}", () => SelectedMods.Value = new[] { Ruleset.Value.CreateInstance().CreateModFromAcronym(mod) });
2022-05-20 14:29:37 +00:00
selectBeatmap(beatmap);
checkDisplayedBPM(expectedDisplay);
}
private void checkDisplayedBPM(string target)
{
AddUntilStep($"displayed bpm is {target}", () =>
{
var label = infoWedge.DisplayedContent.ChildrenOfType<BeatmapInfoWedge.WedgeInfoText.InfoLabel>().Single(l => l.Statistic.Name == BeatmapsetsStrings.ShowStatsBpm);
2022-05-20 14:29:37 +00:00
return label.Statistic.Content == target;
});
2021-08-22 17:01:26 +00:00
}
2023-12-22 17:11:37 +00:00
[TestCase]
public void TestLengthUpdates()
{
IBeatmap beatmap = createTestBeatmap(new OsuRuleset().RulesetInfo);
double drain = beatmap.CalculateDrainLength();
beatmap.BeatmapInfo.Length = drain;
OsuModDoubleTime doubleTime = null;
selectBeatmap(beatmap);
checkDisplayedLength(drain);
AddStep("select DT", () => SelectedMods.Value = new[] { doubleTime = new OsuModDoubleTime() });
checkDisplayedLength(Math.Round(drain / 1.5f));
AddStep("change DT rate", () => doubleTime.SpeedChange.Value = 2);
checkDisplayedLength(Math.Round(drain / 2));
}
private void checkDisplayedLength(double drain)
{
var displayedLength = drain.ToFormattedDuration();
AddUntilStep($"check map drain ({displayedLength})", () =>
{
var label = infoWedge.DisplayedContent.ChildrenOfType<BeatmapInfoWedge.WedgeInfoText.InfoLabel>().Single(l => l.Statistic.Name == BeatmapsetsStrings.ShowStatsTotalLength(displayedLength));
return label.Statistic.Content == displayedLength.ToString();
});
}
private void setRuleset(RulesetInfo rulesetInfo)
{
Container containerBefore = null;
AddStep("set ruleset", () =>
{
// wedge content is only refreshed if the ruleset changes, so only wait for load in that case.
if (!rulesetInfo.Equals(Ruleset.Value))
containerBefore = infoWedge.DisplayedContent;
Ruleset.Value = rulesetInfo;
});
AddUntilStep("wait for async load", () => infoWedge.DisplayedContent != containerBefore);
}
private void selectBeatmap([CanBeNull] IBeatmap b)
{
2021-05-05 16:50:49 +00:00
Container containerBefore = null;
2018-04-13 09:19:50 +00:00
AddStep($"select {b?.Metadata.Title ?? "null"} beatmap", () =>
{
2021-05-05 17:14:04 +00:00
containerBefore = infoWedge.DisplayedContent;
infoWedge.Beatmap = Beatmap.Value = b == null ? Beatmap.Default : CreateWorkingBeatmap(b);
2017-12-12 13:44:12 +00:00
});
2018-04-13 09:19:50 +00:00
2021-05-05 17:14:04 +00:00
AddUntilStep("wait for async load", () => infoWedge.DisplayedContent != containerBefore);
2017-12-12 13:44:12 +00:00
}
2018-04-13 09:19:50 +00:00
2018-04-19 11:44:38 +00:00
private IBeatmap createTestBeatmap(RulesetInfo ruleset)
2017-12-12 13:44:12 +00:00
{
2017-12-23 10:56:53 +00:00
List<HitObject> objects = new List<HitObject>();
for (double i = 0; i < 50000; i += 1000)
objects.Add(new TestHitObject { StartTime = i });
2018-04-13 09:19:50 +00:00
return new Beatmap
{
BeatmapInfo = new BeatmapInfo
{
Metadata = new BeatmapMetadata
{
2022-01-18 14:30:40 +00:00
Author = { Username = $"{ruleset.ShortName}Author" },
Artist = $"{ruleset.ShortName}Artist",
Source = $"{ruleset.ShortName}Source",
Title = $"{ruleset.ShortName}Title"
},
Ruleset = ruleset,
StarRating = 6,
DifficultyName = $"{ruleset.ShortName}Version",
Difficulty = new BeatmapDifficulty()
},
2017-12-23 10:56:53 +00:00
HitObjects = objects
};
}
2018-04-13 09:19:50 +00:00
2019-09-24 23:21:08 +00:00
private IBeatmap createLongMetadata()
{
return new Beatmap
{
BeatmapInfo = new BeatmapInfo
{
Metadata = new BeatmapMetadata
{
2022-01-18 14:30:40 +00:00
Author = { Username = "WWWWWWWWWWWWWWW" },
2019-09-24 23:48:22 +00:00
Artist = "Verrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrry long Artist",
Source = "Verrrrry long Source",
Title = "Verrrrry long Title"
2019-09-24 23:21:08 +00:00
},
DifficultyName = "Verrrrrrrrrrrrrrrrrrrrrrrrrrrrry long Version",
Status = BeatmapOnlineStatus.Graveyard,
2019-09-24 23:21:08 +00:00
},
};
}
private partial class TestBeatmapInfoWedge : BeatmapInfoWedge
{
2021-05-05 17:14:04 +00:00
public new Container DisplayedContent => base.DisplayedContent;
2021-05-05 16:50:49 +00:00
public new WedgeInfoText Info => base.Info;
2017-12-12 13:44:12 +00:00
}
private class TestHitObject : ConvertHitObject, IHasPosition
{
2020-11-01 19:51:23 +00:00
public float X => 0;
public float Y => 0;
public Vector2 Position { get; } = Vector2.Zero;
}
2017-12-12 13:44:12 +00:00
}
}