1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-28 17:32:54 +08:00
osu-lazer/osu.Game.Tests/Visual/UserInterface/TestSceneDeleteLocalScore.cs

185 lines
7.2 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.
using System;
using System.Collections.Generic;
using System.Linq;
2020-01-06 16:15:59 +08:00
using NUnit.Framework;
using osu.Framework.Allocation;
using osu.Framework.Audio;
using osu.Framework.Extensions;
using osu.Framework.Graphics;
2020-01-06 16:15:59 +08:00
using osu.Framework.Graphics.Cursor;
using osu.Framework.Platform;
using osu.Framework.Testing;
2020-01-10 01:38:03 +08:00
using osu.Framework.Utils;
using osu.Game.Beatmaps;
using osu.Game.Database;
2020-01-06 16:15:59 +08:00
using osu.Game.Graphics.Cursor;
using osu.Game.Graphics.UserInterface;
using osu.Game.Models;
using osu.Game.Online.API.Requests.Responses;
using osu.Game.Online.Leaderboards;
using osu.Game.Overlays;
2020-01-06 16:15:59 +08:00
using osu.Game.Rulesets;
using osu.Game.Scoring;
using osu.Game.Screens.Select.Leaderboards;
2020-01-06 16:15:59 +08:00
using osu.Game.Tests.Resources;
using osuTK;
2020-01-06 16:15:59 +08:00
using osuTK.Input;
namespace osu.Game.Tests.Visual.UserInterface
{
public class TestSceneDeleteLocalScore : OsuManualInputManagerTestScene
{
2020-01-06 16:15:59 +08:00
private readonly ContextMenuContainer contextMenuContainer;
private readonly BeatmapLeaderboard leaderboard;
private RulesetStore rulesetStore;
private BeatmapManager beatmapManager;
private ScoreManager scoreManager;
private readonly List<ScoreInfo> importedScores = new List<ScoreInfo>();
2021-10-02 23:55:29 +08:00
private BeatmapInfo beatmapInfo;
2021-12-13 18:01:20 +08:00
[Resolved]
private RealmContextFactory realmFactory { get; set; }
[Cached]
2019-12-20 13:57:14 +08:00
private readonly DialogOverlay dialogOverlay;
public TestSceneDeleteLocalScore()
{
2020-01-06 16:15:59 +08:00
Children = new Drawable[]
{
2020-01-06 16:15:59 +08:00
contextMenuContainer = new OsuContextMenuContainer
{
2020-01-06 16:15:59 +08:00
RelativeSizeAxes = Axes.Both,
Child = leaderboard = new BeatmapLeaderboard
{
2020-01-06 16:15:59 +08:00
Origin = Anchor.Centre,
Anchor = Anchor.Centre,
Size = new Vector2(550f, 450f),
Scope = BeatmapLeaderboardScope.Local,
2021-10-02 23:55:29 +08:00
BeatmapInfo = new BeatmapInfo
{
ID = Guid.NewGuid(),
2020-01-06 16:15:59 +08:00
Metadata = new BeatmapMetadata
{
Title = "TestSong",
Artist = "TestArtist",
Author = new RealmUser
2020-01-06 16:15:59 +08:00
{
Username = "TestAuthor"
},
},
DifficultyName = "Insane"
},
2020-01-06 16:15:59 +08:00
}
},
2020-01-06 16:15:59 +08:00
dialogOverlay = new DialogOverlay()
};
}
2020-01-06 16:15:59 +08:00
protected override IReadOnlyDependencyContainer CreateChildDependencies(IReadOnlyDependencyContainer parent)
{
2020-01-06 16:15:59 +08:00
var dependencies = new DependencyContainer(base.CreateChildDependencies(parent));
2020-01-06 16:15:59 +08:00
dependencies.Cache(rulesetStore = new RulesetStore(ContextFactory));
dependencies.Cache(beatmapManager = new BeatmapManager(LocalStorage, ContextFactory, rulesetStore, null, dependencies.Get<AudioManager>(), Resources, dependencies.Get<GameHost>(), Beatmap.Default));
dependencies.Cache(scoreManager = new ScoreManager(dependencies.Get<RulesetStore>(), () => beatmapManager, LocalStorage, dependencies.Get<RealmContextFactory>(), Scheduler));
2022-01-06 21:54:43 +08:00
beatmapInfo = beatmapManager.Import(new ImportTask(TestResources.GetQuickTestBeatmapForImport())).GetResultSafely().Value.Beatmaps[0];
2020-01-06 16:15:59 +08:00
for (int i = 0; i < 50; i++)
{
2020-01-06 16:15:59 +08:00
var score = new ScoreInfo
{
2021-12-10 14:37:12 +08:00
OnlineID = i,
BeatmapInfo = beatmapInfo,
2020-01-06 16:15:59 +08:00
Accuracy = RNG.NextDouble(),
TotalScore = RNG.Next(1, 1000000),
MaxCombo = RNG.Next(1, 1000),
Rank = ScoreRank.XH,
User = new APIUser { Username = "TestUser" },
2020-01-06 16:15:59 +08:00
};
2022-01-06 21:54:43 +08:00
importedScores.Add(scoreManager.Import(score).GetResultSafely().Value);
}
2020-01-06 16:15:59 +08:00
return dependencies;
}
2020-01-06 16:15:59 +08:00
[SetUp]
public void Setup() => Schedule(() =>
{
2021-12-13 18:01:20 +08:00
using (var realm = realmFactory.CreateContext())
{
// Due to soft deletions, we can re-use deleted scores between test runs
scoreManager.Undelete(realm.All<ScoreInfo>().Where(s => s.DeletePending).ToList());
}
leaderboard.Scores = null;
leaderboard.FinishTransforms(true); // After setting scores, we may be waiting for transforms to expire drawables
2021-10-02 23:55:29 +08:00
leaderboard.BeatmapInfo = beatmapInfo;
leaderboard.RefreshScores(); // Required in the case that the beatmap hasn't changed
2020-01-06 16:15:59 +08:00
});
[SetUpSteps]
public void SetupSteps()
2020-01-06 16:15:59 +08:00
{
// Ensure the leaderboard has finished async-loading drawables
AddUntilStep("wait for drawables", () => leaderboard.ChildrenOfType<LeaderboardScore>().Any());
2020-01-06 16:15:59 +08:00
// Ensure the leaderboard items have finished showing up
AddStep("finish transforms", () => leaderboard.FinishTransforms(true));
}
[Test]
public void TestDeleteViaRightClick()
{
ScoreInfo scoreBeingDeleted = null;
2020-01-06 16:15:59 +08:00
AddStep("open menu for top score", () =>
{
var leaderboardScore = leaderboard.ChildrenOfType<LeaderboardScore>().First();
scoreBeingDeleted = leaderboardScore.Score;
InputManager.MoveMouseTo(leaderboardScore);
2020-01-06 16:15:59 +08:00
InputManager.Click(MouseButton.Right);
});
2020-01-06 16:15:59 +08:00
// Ensure the context menu has finished showing
AddStep("finish transforms", () => contextMenuContainer.FinishTransforms(true));
2020-01-06 16:15:59 +08:00
AddStep("click delete option", () =>
{
InputManager.MoveMouseTo(contextMenuContainer.ChildrenOfType<DrawableOsuMenuItem>().First(i => i.Item.Text.Value.ToString().ToLowerInvariant() == "delete"));
2020-01-06 16:15:59 +08:00
InputManager.Click(MouseButton.Left);
});
2020-01-06 16:15:59 +08:00
// Ensure the dialog has finished showing
AddStep("finish transforms", () => dialogOverlay.FinishTransforms(true));
2020-01-06 16:15:59 +08:00
AddStep("click delete button", () =>
{
2020-01-06 16:15:59 +08:00
InputManager.MoveMouseTo(dialogOverlay.ChildrenOfType<DialogButton>().First());
InputManager.Click(MouseButton.Left);
});
AddUntilStep("wait for fetch", () => leaderboard.Scores != null);
AddUntilStep("score removed from leaderboard", () => leaderboard.Scores.All(s => s.OnlineID != scoreBeingDeleted.OnlineID));
}
2020-01-06 16:15:59 +08:00
[Test]
public void TestDeleteViaDatabase()
{
AddStep("delete top score", () => scoreManager.Delete(importedScores[0]));
2021-10-08 14:26:25 +08:00
AddUntilStep("wait for fetch", () => leaderboard.Scores != null);
AddUntilStep("score removed from leaderboard", () => leaderboard.Scores.All(s => s.OnlineID != importedScores[0].OnlineID));
}
}
}