mirror of
https://github.com/ppy/osu.git
synced 2025-01-15 12:42:54 +08:00
Fix exception when updating the room's visual playlist
This commit is contained in:
parent
01ca9eb81c
commit
740a6f16c7
@ -30,6 +30,7 @@ using osu.Game.Screens.OnlinePlay.Lounge.Components;
|
|||||||
using osu.Game.Screens.OnlinePlay.Match;
|
using osu.Game.Screens.OnlinePlay.Match;
|
||||||
using osu.Game.Screens.OnlinePlay.Multiplayer;
|
using osu.Game.Screens.OnlinePlay.Multiplayer;
|
||||||
using osu.Game.Screens.OnlinePlay.Multiplayer.Match;
|
using osu.Game.Screens.OnlinePlay.Multiplayer.Match;
|
||||||
|
using osu.Game.Screens.OnlinePlay.Multiplayer.Match.Playlist;
|
||||||
using osu.Game.Screens.Play;
|
using osu.Game.Screens.Play;
|
||||||
using osu.Game.Screens.Ranking;
|
using osu.Game.Screens.Ranking;
|
||||||
using osu.Game.Screens.Spectate;
|
using osu.Game.Screens.Spectate;
|
||||||
@ -594,9 +595,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
pressReadyButton();
|
enterGameplay();
|
||||||
pressReadyButton();
|
|
||||||
AddUntilStep("wait for player", () => multiplayerScreenStack.CurrentScreen is Player);
|
|
||||||
|
|
||||||
// Gameplay runs in real-time, so we need to incrementally check if gameplay has finished in order to not time out.
|
// Gameplay runs in real-time, so we need to incrementally check if gameplay has finished in order to not time out.
|
||||||
for (double i = 1000; i < TestResources.QUICK_BEATMAP_LENGTH; i += 1000)
|
for (double i = 1000; i < TestResources.QUICK_BEATMAP_LENGTH; i += 1000)
|
||||||
@ -656,6 +655,44 @@ namespace osu.Game.Tests.Visual.Multiplayer
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestItemAddedAndDeletedByOtherUserDuringGameplay()
|
||||||
|
{
|
||||||
|
createRoom(() => new Room
|
||||||
|
{
|
||||||
|
Name = { Value = "Test Room" },
|
||||||
|
QueueMode = { Value = QueueMode.AllPlayers },
|
||||||
|
Playlist =
|
||||||
|
{
|
||||||
|
new PlaylistItem
|
||||||
|
{
|
||||||
|
Beatmap = { Value = beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.RulesetID == 0)).BeatmapInfo },
|
||||||
|
Ruleset = { Value = new OsuRuleset().RulesetInfo },
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
enterGameplay();
|
||||||
|
|
||||||
|
AddStep("join other user", () => client.AddUser(new APIUser { Id = 1234 }));
|
||||||
|
AddStep("add item as other user", () => client.AddUserPlaylistItem(1234, new MultiplayerPlaylistItem(new PlaylistItem
|
||||||
|
{
|
||||||
|
BeatmapID = beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.RulesetID == 0)).BeatmapInfo.OnlineID ?? -1
|
||||||
|
})));
|
||||||
|
AddStep("delete item as other user", () => client.RemoveUserPlaylistItem(1234, 2));
|
||||||
|
|
||||||
|
AddUntilStep("wait for item to be deleted", () => client.Room?.Playlist.Count == 1);
|
||||||
|
AddStep("exit gameplay as initial user", () => multiplayerScreenStack.MultiplayerScreen.MakeCurrent());
|
||||||
|
AddUntilStep("queue is empty", () => this.ChildrenOfType<MultiplayerQueueList>().Single().Items.Count == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void enterGameplay()
|
||||||
|
{
|
||||||
|
pressReadyButton();
|
||||||
|
pressReadyButton();
|
||||||
|
AddUntilStep("wait for player", () => multiplayerScreenStack.CurrentScreen is Player);
|
||||||
|
}
|
||||||
|
|
||||||
private ReadyButton readyButton => this.ChildrenOfType<ReadyButton>().Single();
|
private ReadyButton readyButton => this.ChildrenOfType<ReadyButton>().Single();
|
||||||
|
|
||||||
private void pressReadyButton()
|
private void pressReadyButton()
|
||||||
|
@ -121,7 +121,11 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Match.Playlist
|
|||||||
|
|
||||||
private void addItemToLists(MultiplayerPlaylistItem item)
|
private void addItemToLists(MultiplayerPlaylistItem item)
|
||||||
{
|
{
|
||||||
var apiItem = Playlist.Single(i => i.ID == item.ID);
|
var apiItem = Playlist.SingleOrDefault(i => i.ID == item.ID);
|
||||||
|
|
||||||
|
// Item could have been removed from the playlist while the local player was in gameplay.
|
||||||
|
if (apiItem == null)
|
||||||
|
return;
|
||||||
|
|
||||||
if (item.Expired)
|
if (item.Expired)
|
||||||
historyList.Items.Add(apiItem);
|
historyList.Items.Add(apiItem);
|
||||||
|
Loading…
Reference in New Issue
Block a user