mirror of
https://github.com/ppy/osu.git
synced 2025-01-08 01:23:05 +08:00
Merge pull request #8297 from TheWildTree/improve-chat-test
Chat overlay test scene improvements
This commit is contained in:
commit
91439ea2cc
@ -54,7 +54,8 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
.Select(index => new Channel(new User())
|
.Select(index => new Channel(new User())
|
||||||
{
|
{
|
||||||
Name = $"Channel no. {index}",
|
Name = $"Channel no. {index}",
|
||||||
Topic = index == 3 ? null : $"We talk about the number {index} here"
|
Topic = index == 3 ? null : $"We talk about the number {index} here",
|
||||||
|
Type = index % 2 == 0 ? ChannelType.PM : ChannelType.Temporary
|
||||||
})
|
})
|
||||||
.ToList();
|
.ToList();
|
||||||
}
|
}
|
||||||
@ -100,28 +101,11 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
AddAssert("Channel selector was closed", () => chatOverlay.SelectionOverlayState == Visibility.Hidden);
|
AddAssert("Channel selector was closed", () => chatOverlay.SelectionOverlayState == Visibility.Hidden);
|
||||||
}
|
}
|
||||||
|
|
||||||
[Test]
|
|
||||||
public void TestCloseChannelWhileSelectorClosed()
|
|
||||||
{
|
|
||||||
AddStep("Join channel 1", () => channelManager.JoinChannel(channel1));
|
|
||||||
AddStep("Join channel 2", () => channelManager.JoinChannel(channel2));
|
|
||||||
|
|
||||||
AddStep("Switch to channel 2", () => clickDrawable(chatOverlay.TabMap[channel2]));
|
|
||||||
AddStep("Close channel 2", () => clickDrawable(((TestPrivateChannelTabItem)chatOverlay.TabMap[channel2]).CloseButton.Child));
|
|
||||||
|
|
||||||
AddAssert("Selector remained closed", () => chatOverlay.SelectionOverlayState == Visibility.Hidden);
|
|
||||||
AddAssert("Current channel is channel 1", () => currentChannel == channel1);
|
|
||||||
|
|
||||||
AddStep("Close channel 1", () => clickDrawable(((TestPrivateChannelTabItem)chatOverlay.TabMap[channel1]).CloseButton.Child));
|
|
||||||
|
|
||||||
AddAssert("Selector is visible", () => chatOverlay.SelectionOverlayState == Visibility.Visible);
|
|
||||||
}
|
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestSearchInSelector()
|
public void TestSearchInSelector()
|
||||||
{
|
{
|
||||||
AddStep("search for 'no. 2'", () => chatOverlay.ChildrenOfType<SearchTextBox>().First().Text = "no. 2");
|
AddStep("Search for 'no. 2'", () => chatOverlay.ChildrenOfType<SearchTextBox>().First().Text = "no. 2");
|
||||||
AddUntilStep("only channel 2 visible", () =>
|
AddUntilStep("Only channel 2 visible", () =>
|
||||||
{
|
{
|
||||||
var listItems = chatOverlay.ChildrenOfType<ChannelListItem>().Where(c => c.IsPresent);
|
var listItems = chatOverlay.ChildrenOfType<ChannelListItem>().Where(c => c.IsPresent);
|
||||||
return listItems.Count() == 1 && listItems.Single().Channel == channel2;
|
return listItems.Count() == 1 && listItems.Single().Channel == channel2;
|
||||||
@ -131,28 +115,28 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
[Test]
|
[Test]
|
||||||
public void TestChannelShortcutKeys()
|
public void TestChannelShortcutKeys()
|
||||||
{
|
{
|
||||||
AddStep("join 10 channels", () => channels.ForEach(channel => channelManager.JoinChannel(channel)));
|
AddStep("Join channels", () => channels.ForEach(channel => channelManager.JoinChannel(channel)));
|
||||||
AddStep("close channel selector", () =>
|
AddStep("Close channel selector", () =>
|
||||||
{
|
{
|
||||||
InputManager.PressKey(Key.Escape);
|
InputManager.PressKey(Key.Escape);
|
||||||
InputManager.ReleaseKey(Key.Escape);
|
InputManager.ReleaseKey(Key.Escape);
|
||||||
});
|
});
|
||||||
AddUntilStep("wait for close", () => chatOverlay.SelectionOverlayState == Visibility.Hidden);
|
AddUntilStep("Wait for close", () => chatOverlay.SelectionOverlayState == Visibility.Hidden);
|
||||||
|
|
||||||
for (int zeroBasedIndex = 0; zeroBasedIndex < 10; ++zeroBasedIndex)
|
for (int zeroBasedIndex = 0; zeroBasedIndex < 10; ++zeroBasedIndex)
|
||||||
{
|
{
|
||||||
var oneBasedIndex = zeroBasedIndex + 1;
|
var oneBasedIndex = zeroBasedIndex + 1;
|
||||||
var targetNumberKey = oneBasedIndex % 10;
|
var targetNumberKey = oneBasedIndex % 10;
|
||||||
var targetChannel = channels[zeroBasedIndex];
|
var targetChannel = channels[zeroBasedIndex];
|
||||||
AddStep($"press Alt+{targetNumberKey}", () => pressChannelHotkey(targetNumberKey));
|
AddStep($"Press Alt+{targetNumberKey}", () => pressChannelHotkey(targetNumberKey));
|
||||||
AddAssert($"channel #{oneBasedIndex} is selected", () => currentChannel == targetChannel);
|
AddAssert($"Channel #{oneBasedIndex} is selected", () => currentChannel == targetChannel);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Channel expectedChannel;
|
private Channel expectedChannel;
|
||||||
|
|
||||||
[Test]
|
[Test]
|
||||||
public void TestCloseChannelWhileActive()
|
public void TestCloseChannelBehaviour()
|
||||||
{
|
{
|
||||||
AddUntilStep("Join until dropdown has channels", () =>
|
AddUntilStep("Join until dropdown has channels", () =>
|
||||||
{
|
{
|
||||||
@ -160,8 +144,11 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
return true;
|
return true;
|
||||||
|
|
||||||
// Using temporary channels because they don't hide their names when not active
|
// Using temporary channels because they don't hide their names when not active
|
||||||
Channel toAdd = new Channel { Name = $"test channel {joinedChannels.Count()}", Type = ChannelType.Temporary };
|
channelManager.JoinChannel(new Channel
|
||||||
channelManager.JoinChannel(toAdd);
|
{
|
||||||
|
Name = $"Channel no. {joinedChannels.Count() + 11}",
|
||||||
|
Type = ChannelType.Temporary
|
||||||
|
});
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
@ -176,6 +163,7 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
chatOverlay.ChannelTabControl.RemoveChannel(currentChannel);
|
chatOverlay.ChannelTabControl.RemoveChannel(currentChannel);
|
||||||
});
|
});
|
||||||
AddAssert("Next channel selected", () => currentChannel == expectedChannel);
|
AddAssert("Next channel selected", () => currentChannel == expectedChannel);
|
||||||
|
AddAssert("Selector remained closed", () => chatOverlay.SelectionOverlayState == Visibility.Hidden);
|
||||||
|
|
||||||
// Depending on the window size, one more channel might need to be closed for the selectorTab to appear
|
// Depending on the window size, one more channel might need to be closed for the selectorTab to appear
|
||||||
AddUntilStep("Close channels until selector visible", () =>
|
AddUntilStep("Close channels until selector visible", () =>
|
||||||
@ -194,7 +182,7 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
expectedChannel = previousChannel;
|
expectedChannel = previousChannel;
|
||||||
chatOverlay.ChannelTabControl.RemoveChannel(currentChannel);
|
chatOverlay.ChannelTabControl.RemoveChannel(currentChannel);
|
||||||
});
|
});
|
||||||
AddAssert("Channel changed to previous", () => currentChannel == expectedChannel);
|
AddAssert("Previous channel selected", () => currentChannel == expectedChannel);
|
||||||
|
|
||||||
// Standard channel closing
|
// Standard channel closing
|
||||||
AddStep("Switch to previous channel", () => chatOverlay.ChannelTabControl.SwitchTab(-1));
|
AddStep("Switch to previous channel", () => chatOverlay.ChannelTabControl.SwitchTab(-1));
|
||||||
@ -203,7 +191,38 @@ namespace osu.Game.Tests.Visual.Online
|
|||||||
expectedChannel = nextChannel;
|
expectedChannel = nextChannel;
|
||||||
chatOverlay.ChannelTabControl.RemoveChannel(currentChannel);
|
chatOverlay.ChannelTabControl.RemoveChannel(currentChannel);
|
||||||
});
|
});
|
||||||
AddAssert("Channel changed to next", () => currentChannel == expectedChannel);
|
AddAssert("Next channel selected", () => currentChannel == expectedChannel);
|
||||||
|
|
||||||
|
// Selector reappearing after all channels closed
|
||||||
|
AddUntilStep("Close all channels", () =>
|
||||||
|
{
|
||||||
|
if (!joinedChannels.Any())
|
||||||
|
return true;
|
||||||
|
|
||||||
|
chatOverlay.ChannelTabControl.RemoveChannel(joinedChannels.Last());
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
AddAssert("Selector is visible", () => chatOverlay.SelectionOverlayState == Visibility.Visible);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Test]
|
||||||
|
public void TestChannelCloseButton()
|
||||||
|
{
|
||||||
|
AddStep("Join 2 channels", () =>
|
||||||
|
{
|
||||||
|
channelManager.JoinChannel(channel1);
|
||||||
|
channelManager.JoinChannel(channel2);
|
||||||
|
});
|
||||||
|
|
||||||
|
// PM channel close button only appears when active
|
||||||
|
AddStep("Select PM channel", () => clickDrawable(chatOverlay.TabMap[channel2]));
|
||||||
|
AddStep("Click PM close button", () => clickDrawable(((TestPrivateChannelTabItem)chatOverlay.TabMap[channel2]).CloseButton.Child));
|
||||||
|
AddAssert("PM channel closed", () => !channelManager.JoinedChannels.Contains(channel2));
|
||||||
|
|
||||||
|
// Non-PM chat channel close button only appears when hovered
|
||||||
|
AddStep("Hover normal channel tab", () => InputManager.MoveMouseTo(chatOverlay.TabMap[channel1]));
|
||||||
|
AddStep("Click normal close button", () => clickDrawable(((TestChannelTabItem)chatOverlay.TabMap[channel1]).CloseButton.Child));
|
||||||
|
AddAssert("All channels closed", () => !channelManager.JoinedChannels.Any());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void pressChannelHotkey(int number)
|
private void pressChannelHotkey(int number)
|
||||||
|
Loading…
Reference in New Issue
Block a user