1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-19 17:03:02 +08:00

Fix tests failing due to timings

This commit is contained in:
smoogipoo 2020-09-08 13:23:50 +09:00
parent 0e93bbb62d
commit 525026e7f0
2 changed files with 16 additions and 11 deletions

View File

@ -19,30 +19,30 @@ namespace osu.Game.Tests.Visual.Collections
{ {
public class TestSceneManageCollectionsDialog : OsuManualInputManagerTestScene public class TestSceneManageCollectionsDialog : OsuManualInputManagerTestScene
{ {
[Cached]
private readonly DialogOverlay dialogOverlay;
protected override Container<Drawable> Content => content; protected override Container<Drawable> Content => content;
private readonly Container content; private readonly Container content;
private readonly DialogOverlay dialogOverlay;
private readonly BeatmapCollectionManager manager;
private BeatmapCollectionManager manager;
private ManageCollectionsDialog dialog; private ManageCollectionsDialog dialog;
public TestSceneManageCollectionsDialog() public TestSceneManageCollectionsDialog()
{ {
base.Content.AddRange(new Drawable[] base.Content.AddRange(new Drawable[]
{ {
manager = new BeatmapCollectionManager(LocalStorage),
content = new Container { RelativeSizeAxes = Axes.Both }, content = new Container { RelativeSizeAxes = Axes.Both },
dialogOverlay = new DialogOverlay() dialogOverlay = new DialogOverlay()
}); });
} }
[BackgroundDependencyLoader] protected override IReadOnlyDependencyContainer CreateChildDependencies(IReadOnlyDependencyContainer parent)
private void load()
{ {
Dependencies.Cache(manager = new BeatmapCollectionManager(LocalStorage)); var dependencies = new DependencyContainer(base.CreateChildDependencies(parent));
Add(manager); dependencies.Cache(manager);
dependencies.Cache(dialogOverlay);
return dependencies;
} }
[SetUp] [SetUp]
@ -120,6 +120,8 @@ namespace osu.Game.Tests.Visual.Collections
new BeatmapCollection { Name = { Value = "2" } }, new BeatmapCollection { Name = { Value = "2" } },
})); }));
assertCollectionCount(2);
AddStep("click first delete button", () => AddStep("click first delete button", () =>
{ {
InputManager.MoveMouseTo(dialog.ChildrenOfType<DrawableCollectionListItem.DeleteButton>().First(), new Vector2(5, 0)); InputManager.MoveMouseTo(dialog.ChildrenOfType<DrawableCollectionListItem.DeleteButton>().First(), new Vector2(5, 0));
@ -146,6 +148,8 @@ namespace osu.Game.Tests.Visual.Collections
new BeatmapCollection { Name = { Value = "2" } }, new BeatmapCollection { Name = { Value = "2" } },
})); }));
assertCollectionCount(2);
AddStep("click first delete button", () => AddStep("click first delete button", () =>
{ {
InputManager.MoveMouseTo(dialog.ChildrenOfType<DrawableCollectionListItem.DeleteButton>().First(), new Vector2(5, 0)); InputManager.MoveMouseTo(dialog.ChildrenOfType<DrawableCollectionListItem.DeleteButton>().First(), new Vector2(5, 0));
@ -185,14 +189,16 @@ namespace osu.Game.Tests.Visual.Collections
new BeatmapCollection { Name = { Value = "2" } }, new BeatmapCollection { Name = { Value = "2" } },
})); }));
assertCollectionCount(2);
AddStep("change first collection name", () => dialog.ChildrenOfType<TextBox>().First().Text = "First"); AddStep("change first collection name", () => dialog.ChildrenOfType<TextBox>().First().Text = "First");
AddAssert("collection has new name", () => manager.Collections[0].Name.Value == "First"); AddAssert("collection has new name", () => manager.Collections[0].Name.Value == "First");
} }
private void assertCollectionCount(int count) private void assertCollectionCount(int count)
=> AddAssert($"{count} collections shown", () => dialog.ChildrenOfType<DrawableCollectionListItem>().Count() == count); => AddUntilStep($"{count} collections shown", () => dialog.ChildrenOfType<DrawableCollectionListItem>().Count() == count);
private void assertCollectionName(int index, string name) private void assertCollectionName(int index, string name)
=> AddAssert($"item {index + 1} has correct name", () => dialog.ChildrenOfType<DrawableCollectionListItem>().ElementAt(index).ChildrenOfType<TextBox>().First().Text == name); => AddUntilStep($"item {index + 1} has correct name", () => dialog.ChildrenOfType<DrawableCollectionListItem>().ElementAt(index).ChildrenOfType<TextBox>().First().Text == name);
} }
} }

View File

@ -26,7 +26,6 @@ namespace osu.Game.Tests.Visual.SongSelect
protected override Container<Drawable> Content => content; protected override Container<Drawable> Content => content;
private readonly Container content; private readonly Container content;
[Cached]
private readonly BeatmapCollectionManager collectionManager; private readonly BeatmapCollectionManager collectionManager;
private RulesetStore rulesets; private RulesetStore rulesets;