1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-07 21:32:57 +08:00

Add test coverage

This commit is contained in:
Salman Ahmed 2024-02-14 03:49:29 +03:00
parent 4d3b605e04
commit c24af5bfeb
3 changed files with 103 additions and 56 deletions

View File

@ -170,6 +170,24 @@ namespace osu.Game.Tests.Visual.Online
}); });
} }
[Test]
public void TestPostAsOwner()
{
setUpCommentsResponse(getExampleComments());
AddStep("show comments", () => commentsContainer.ShowComments(CommentableType.Beatmapset, 123));
setUpPostResponse(true);
AddStep("enter text", () => editorTextBox.Current.Value = "comm");
AddStep("submit", () => commentsContainer.ChildrenOfType<CommentEditor>().Single().ChildrenOfType<RoundedButton>().First().TriggerClick());
AddUntilStep("comment sent", () =>
{
string writtenText = editorTextBox.Current.Value;
var comment = commentsContainer.ChildrenOfType<DrawableComment>().LastOrDefault();
return comment != null && comment.ChildrenOfType<SpriteText>().Any(y => y.Text == writtenText) && comment.ChildrenOfType<SpriteText>().Any(y => y.Text == "MAPPER");
});
}
private void setUpCommentsResponse(CommentBundle commentBundle) private void setUpCommentsResponse(CommentBundle commentBundle)
=> AddStep("set up response", () => => AddStep("set up response", () =>
{ {
@ -183,7 +201,7 @@ namespace osu.Game.Tests.Visual.Online
}; };
}); });
private void setUpPostResponse() private void setUpPostResponse(bool asOwner = false)
=> AddStep("set up response", () => => AddStep("set up response", () =>
{ {
dummyAPI.HandleRequest = request => dummyAPI.HandleRequest = request =>
@ -191,7 +209,7 @@ namespace osu.Game.Tests.Visual.Online
if (!(request is CommentPostRequest req)) if (!(request is CommentPostRequest req))
return false; return false;
req.TriggerSuccess(new CommentBundle var bundle = new CommentBundle
{ {
Comments = new List<Comment> Comments = new List<Comment>
{ {
@ -202,9 +220,26 @@ namespace osu.Game.Tests.Visual.Online
LegacyName = "FirstUser", LegacyName = "FirstUser",
CreatedAt = DateTimeOffset.Now, CreatedAt = DateTimeOffset.Now,
VotesCount = 98, VotesCount = 98,
CommentableId = 2001,
CommentableType = "test",
} }
} }
};
if (asOwner)
{
bundle.Comments[0].UserId = 1001;
bundle.Comments[0].User = new APIUser { Id = 1001, Username = "FirstUser" };
bundle.CommentableMeta.Add(new CommentableMeta
{
Id = 2001,
OwnerId = 1001,
OwnerTitle = "MAPPER",
Type = "test",
}); });
}
req.TriggerSuccess(bundle);
return true; return true;
}; };
}); });

View File

@ -4,62 +4,66 @@
#nullable disable #nullable disable
using System; using System;
using NUnit.Framework; using System.Linq;
using osu.Framework.Allocation;
using osu.Framework.Graphics; using osu.Framework.Graphics;
using osu.Framework.Graphics.Containers; using osu.Framework.Graphics.Containers;
using osu.Framework.Graphics.Shapes; using osu.Game.Graphics.Containers;
using osu.Game.Online.API.Requests.Responses; using osu.Game.Online.API.Requests.Responses;
using osu.Game.Overlays;
using osu.Game.Overlays.Comments; using osu.Game.Overlays.Comments;
using osu.Game.Tests.Visual.UserInterface;
namespace osu.Game.Tests.Visual.Online namespace osu.Game.Tests.Visual.Online
{ {
public partial class TestSceneDrawableComment : OsuTestScene public partial class TestSceneDrawableComment : ThemeComparisonTestScene
{ {
[Cached] public TestSceneDrawableComment()
private readonly OverlayColourProvider colourProvider = new OverlayColourProvider(OverlayColourScheme.Purple); : base(false)
{
}
private Container container; protected override Drawable CreateContent() => new OsuScrollContainer(Direction.Vertical)
[SetUp]
public void SetUp() => Schedule(() =>
{
Children = new Drawable[]
{
new Box
{ {
RelativeSizeAxes = Axes.Both, RelativeSizeAxes = Axes.Both,
Colour = colourProvider.Background4, Child = new FillFlowContainer
},
container = new Container
{ {
RelativeSizeAxes = Axes.X, RelativeSizeAxes = Axes.X,
AutoSizeAxes = Axes.Y, AutoSizeAxes = Axes.Y,
}, Direction = FillDirection.Vertical,
}; ChildrenEnumerable = comments.Select(info =>
});
[TestCaseSource(nameof(comments))]
public void TestComment(string description, string text)
{ {
AddStep(description, () => var comment = new Comment
{
comment.Pinned = description == "Pinned";
comment.Message = text;
container.Add(new DrawableComment(comment));
});
}
private static readonly Comment comment = new Comment
{ {
Id = 1, Id = 1,
LegacyName = "Test User", UserId = 1000,
User = new APIUser { Id = 1000, Username = "Someone" },
CreatedAt = DateTimeOffset.Now, CreatedAt = DateTimeOffset.Now,
VotesCount = 0, VotesCount = 0,
Pinned = info[0] == "Pinned",
Message = info[1],
CommentableId = 2001,
CommentableType = "test"
}; };
private static object[] comments = return new[]
{
new DrawableComment(comment, Array.Empty<CommentableMeta>()),
new DrawableComment(comment, new[]
{
new CommentableMeta
{
Id = 2001,
OwnerId = comment.UserId,
OwnerTitle = "MAPPER",
Type = "test",
},
new CommentableMeta { Title = "Other Meta" },
}),
};
}).SelectMany(c => c)
}
};
private static readonly string[][] comments =
{ {
new[] { "Plain", "This is plain comment" }, new[] { "Plain", "This is plain comment" },
new[] { "Pinned", "This is pinned comment" }, new[] { "Pinned", "This is pinned comment" },

View File

@ -14,13 +14,18 @@ namespace osu.Game.Tests.Visual.UserInterface
{ {
public abstract partial class ThemeComparisonTestScene : OsuGridTestScene public abstract partial class ThemeComparisonTestScene : OsuGridTestScene
{ {
protected ThemeComparisonTestScene() private readonly bool showNoColourProvider;
: base(1, 2)
protected ThemeComparisonTestScene(bool showNoColourProvider = true)
: base(1, showNoColourProvider ? 2 : 1)
{ {
this.showNoColourProvider = showNoColourProvider;
} }
[BackgroundDependencyLoader] [BackgroundDependencyLoader]
private void load(OsuColour colours) private void load(OsuColour colours)
{
if (showNoColourProvider)
{ {
Cell(0, 0).AddRange(new[] Cell(0, 0).AddRange(new[]
{ {
@ -32,13 +37,16 @@ namespace osu.Game.Tests.Visual.UserInterface
CreateContent() CreateContent()
}); });
} }
}
protected void CreateThemedContent(OverlayColourScheme colourScheme) protected void CreateThemedContent(OverlayColourScheme colourScheme)
{ {
var colourProvider = new OverlayColourProvider(colourScheme); var colourProvider = new OverlayColourProvider(colourScheme);
Cell(0, 1).Clear(); int col = showNoColourProvider ? 1 : 0;
Cell(0, 1).Add(new DependencyProvidingContainer
Cell(0, col).Clear();
Cell(0, col).Add(new DependencyProvidingContainer
{ {
RelativeSizeAxes = Axes.Both, RelativeSizeAxes = Axes.Both,
CachedDependencies = new (Type, object)[] CachedDependencies = new (Type, object)[]