2020-01-28 08:59:14 +00:00
|
|
|
// 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.
|
|
|
|
|
2022-08-12 05:15:12 +00:00
|
|
|
using System.Collections.Generic;
|
2020-09-10 22:12:05 +00:00
|
|
|
using System.Linq;
|
2020-01-28 08:59:14 +00:00
|
|
|
using NUnit.Framework;
|
2022-08-12 05:15:12 +00:00
|
|
|
using osu.Framework.Allocation;
|
2020-01-28 08:59:14 +00:00
|
|
|
using osu.Framework.Graphics;
|
|
|
|
using osu.Framework.Graphics.Containers;
|
2022-08-12 05:15:12 +00:00
|
|
|
using osu.Framework.Platform;
|
2020-09-10 22:12:05 +00:00
|
|
|
using osu.Framework.Testing;
|
2020-01-28 08:59:14 +00:00
|
|
|
using osu.Game.Beatmaps;
|
2022-08-12 05:15:12 +00:00
|
|
|
using osu.Game.Collections;
|
2022-01-26 03:19:05 +00:00
|
|
|
using osu.Game.Database;
|
2020-01-28 08:59:14 +00:00
|
|
|
using osu.Game.Overlays.Music;
|
2022-08-12 05:15:12 +00:00
|
|
|
using osu.Game.Rulesets;
|
2021-11-24 08:59:23 +00:00
|
|
|
using osu.Game.Tests.Resources;
|
2020-01-28 08:59:14 +00:00
|
|
|
using osuTK;
|
2020-09-10 22:12:05 +00:00
|
|
|
using osuTK.Input;
|
2020-01-28 08:59:14 +00:00
|
|
|
|
|
|
|
namespace osu.Game.Tests.Visual.UserInterface
|
|
|
|
{
|
2020-09-10 22:12:05 +00:00
|
|
|
public partial class TestScenePlaylistOverlay : OsuManualInputManagerTestScene
|
2020-01-28 08:59:14 +00:00
|
|
|
{
|
2022-08-12 05:15:12 +00:00
|
|
|
protected override bool UseFreshStoragePerRun => true;
|
|
|
|
|
|
|
|
private PlaylistOverlay playlistOverlay = null!;
|
|
|
|
|
|
|
|
private BeatmapManager beatmapManager = null!;
|
2020-09-10 22:12:05 +00:00
|
|
|
|
2022-08-12 05:15:12 +00:00
|
|
|
private const int item_count = 20;
|
2021-11-24 08:59:23 +00:00
|
|
|
|
2022-08-12 05:15:12 +00:00
|
|
|
private List<BeatmapSetInfo> beatmapSets => beatmapManager.GetAllUsableBeatmapSets();
|
|
|
|
|
|
|
|
[BackgroundDependencyLoader]
|
|
|
|
private void load(GameHost host)
|
|
|
|
{
|
|
|
|
Dependencies.Cache(new RealmRulesetStore(Realm));
|
|
|
|
Dependencies.Cache(beatmapManager = new BeatmapManager(LocalStorage, Realm, null, Audio, Resources, host, Beatmap.Default));
|
|
|
|
Dependencies.Cache(Realm);
|
|
|
|
}
|
2022-06-26 17:58:01 +00:00
|
|
|
|
2020-01-28 08:59:14 +00:00
|
|
|
[SetUp]
|
|
|
|
public void Setup() => Schedule(() =>
|
|
|
|
{
|
|
|
|
Child = new Container
|
|
|
|
{
|
|
|
|
Anchor = Anchor.Centre,
|
|
|
|
Origin = Anchor.Centre,
|
|
|
|
Size = new Vector2(300, 500),
|
2020-09-10 22:12:05 +00:00
|
|
|
Child = playlistOverlay = new PlaylistOverlay
|
2020-01-28 08:59:14 +00:00
|
|
|
{
|
|
|
|
Anchor = Anchor.Centre,
|
|
|
|
Origin = Anchor.Centre,
|
|
|
|
RelativeSizeAxes = Axes.X,
|
|
|
|
State = { Value = Visibility.Visible }
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-06-26 17:58:01 +00:00
|
|
|
for (int i = 0; i < item_count; i++)
|
2020-01-28 08:59:14 +00:00
|
|
|
{
|
2022-08-12 05:15:12 +00:00
|
|
|
beatmapManager.Import(TestResources.CreateTestBeatmapSetInfo());
|
2020-01-28 08:59:14 +00:00
|
|
|
}
|
|
|
|
|
2022-08-12 05:44:19 +00:00
|
|
|
beatmapSets.First().ToLive(Realm);
|
2022-08-23 08:00:00 +00:00
|
|
|
|
|
|
|
// Ensure all the initial imports are present before running any tests.
|
|
|
|
Realm.Run(r => r.Refresh());
|
2020-01-28 08:59:14 +00:00
|
|
|
});
|
2020-09-10 22:12:05 +00:00
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void TestRearrangeItems()
|
|
|
|
{
|
2022-06-26 17:58:01 +00:00
|
|
|
AddUntilStep("wait for load complete", () =>
|
|
|
|
{
|
|
|
|
return this
|
|
|
|
.ChildrenOfType<PlaylistItem>()
|
|
|
|
.Count(i => i.ChildrenOfType<DelayedLoadWrapper>().First().DelayedLoadCompleted) > 6;
|
|
|
|
});
|
|
|
|
|
2020-09-10 22:12:05 +00:00
|
|
|
AddUntilStep("wait for animations to complete", () => !playlistOverlay.Transforms.Any());
|
|
|
|
|
2022-08-12 05:15:12 +00:00
|
|
|
PlaylistItem firstItem = null!;
|
|
|
|
|
2020-09-10 22:12:05 +00:00
|
|
|
AddStep("hold 1st item handle", () =>
|
|
|
|
{
|
2022-08-12 05:15:12 +00:00
|
|
|
firstItem = this.ChildrenOfType<PlaylistItem>().First();
|
|
|
|
var handle = firstItem.ChildrenOfType<PlaylistItem.PlaylistItemHandle>().First();
|
|
|
|
|
2020-09-10 22:12:05 +00:00
|
|
|
InputManager.MoveMouseTo(handle.ScreenSpaceDrawQuad.Centre);
|
|
|
|
InputManager.PressButton(MouseButton.Left);
|
|
|
|
});
|
|
|
|
|
|
|
|
AddStep("drag to 5th", () =>
|
|
|
|
{
|
|
|
|
var item = this.ChildrenOfType<PlaylistItem>().ElementAt(4);
|
2022-01-21 17:39:01 +00:00
|
|
|
InputManager.MoveMouseTo(item.ScreenSpaceDrawQuad.BottomLeft);
|
2020-09-10 22:12:05 +00:00
|
|
|
});
|
|
|
|
|
2022-08-12 05:15:12 +00:00
|
|
|
AddAssert("first is moved", () => playlistOverlay.ChildrenOfType<Playlist>().Single().Items.ElementAt(4).Value.Equals(firstItem.Model.Value));
|
2020-09-10 22:12:05 +00:00
|
|
|
|
|
|
|
AddStep("release handle", () => InputManager.ReleaseButton(MouseButton.Left));
|
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void TestFiltering()
|
|
|
|
{
|
|
|
|
AddStep("set filter to \"10\"", () =>
|
|
|
|
{
|
|
|
|
var filterControl = playlistOverlay.ChildrenOfType<FilterControl>().Single();
|
|
|
|
filterControl.Search.Current.Value = "10";
|
|
|
|
});
|
|
|
|
|
|
|
|
AddAssert("results filtered correctly",
|
|
|
|
() => playlistOverlay.ChildrenOfType<PlaylistItem>()
|
|
|
|
.Where(item => item.MatchingFilter)
|
2022-05-18 01:56:42 +00:00
|
|
|
.All(item => item.FilterTerms.Any(term => term.ToString().Contains("10"))));
|
2022-08-12 05:44:19 +00:00
|
|
|
|
|
|
|
AddStep("Import new non-matching beatmap", () =>
|
|
|
|
{
|
|
|
|
var testBeatmapSetInfo = TestResources.CreateTestBeatmapSetInfo(1);
|
|
|
|
testBeatmapSetInfo.Beatmaps.Single().Metadata.Title = "no guid";
|
|
|
|
beatmapManager.Import(testBeatmapSetInfo);
|
|
|
|
});
|
|
|
|
|
|
|
|
AddStep("Force realm refresh", () => Realm.Run(r => r.Refresh()));
|
|
|
|
|
|
|
|
AddAssert("results filtered correctly",
|
|
|
|
() => playlistOverlay.ChildrenOfType<PlaylistItem>()
|
|
|
|
.Where(item => item.MatchingFilter)
|
|
|
|
.All(item => item.FilterTerms.Any(term => term.ToString().Contains("10"))));
|
|
|
|
}
|
|
|
|
|
|
|
|
[Test]
|
|
|
|
public void TestCollectionFiltering()
|
|
|
|
{
|
|
|
|
NowPlayingCollectionDropdown collectionDropdown() => playlistOverlay.ChildrenOfType<NowPlayingCollectionDropdown>().Single();
|
|
|
|
|
|
|
|
AddStep("Add collection", () =>
|
|
|
|
{
|
2022-08-23 08:06:32 +00:00
|
|
|
Realm.Write(r =>
|
2022-08-12 05:44:19 +00:00
|
|
|
{
|
|
|
|
r.RemoveAll<BeatmapCollection>();
|
|
|
|
r.Add(new BeatmapCollection("wang"));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
AddUntilStep("wait for dropdown to have new collection", () => collectionDropdown().Items.Count() == 2);
|
|
|
|
|
|
|
|
AddStep("Filter to collection", () =>
|
|
|
|
{
|
|
|
|
collectionDropdown().Current.Value = collectionDropdown().Items.Last();
|
|
|
|
});
|
|
|
|
|
|
|
|
AddUntilStep("No items present", () => !playlistOverlay.ChildrenOfType<PlaylistItem>().Any(i => i.MatchingFilter));
|
|
|
|
|
|
|
|
AddStep("Import new non-matching beatmap", () =>
|
|
|
|
{
|
|
|
|
beatmapManager.Import(TestResources.CreateTestBeatmapSetInfo(1));
|
|
|
|
});
|
|
|
|
|
|
|
|
AddStep("Force realm refresh", () => Realm.Run(r => r.Refresh()));
|
|
|
|
|
|
|
|
AddUntilStep("No items matching", () => !playlistOverlay.ChildrenOfType<PlaylistItem>().Any(i => i.MatchingFilter));
|
|
|
|
|
|
|
|
BeatmapSetInfo collectionAddedBeatmapSet = null!;
|
|
|
|
|
|
|
|
AddStep("Import new matching beatmap", () =>
|
|
|
|
{
|
|
|
|
collectionAddedBeatmapSet = TestResources.CreateTestBeatmapSetInfo(1);
|
|
|
|
|
|
|
|
beatmapManager.Import(collectionAddedBeatmapSet);
|
|
|
|
Realm.Write(r => r.All<BeatmapCollection>().First().BeatmapMD5Hashes.Add(collectionAddedBeatmapSet.Beatmaps.First().MD5Hash));
|
|
|
|
});
|
|
|
|
|
|
|
|
AddStep("Force realm refresh", () => Realm.Run(r => r.Refresh()));
|
|
|
|
|
|
|
|
AddUntilStep("Only matching item",
|
|
|
|
() => playlistOverlay.ChildrenOfType<PlaylistItem>().Where(i => i.MatchingFilter).Select(i => i.Model.ID), () => Is.EquivalentTo(new[] { collectionAddedBeatmapSet.ID }));
|
2020-09-10 22:12:05 +00:00
|
|
|
}
|
2020-01-28 08:59:14 +00:00
|
|
|
}
|
|
|
|
}
|