diff options
author | crupest <crupest@outlook.com> | 2022-04-16 19:52:50 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2022-04-16 19:52:50 +0800 |
commit | 8c797c5b4f822ee815357fc358d6b8de38b86dd9 (patch) | |
tree | 99ba523264beeb56f92f9f58d86d03678c2cc369 /BackEnd/Timeline.Tests/IntegratedTests2/UserTest.cs | |
parent | 7715ddd0d70efc32bf3d04d2b2c356c333328344 (diff) | |
download | timeline-8c797c5b4f822ee815357fc358d6b8de38b86dd9.tar.gz timeline-8c797c5b4f822ee815357fc358d6b8de38b86dd9.tar.bz2 timeline-8c797c5b4f822ee815357fc358d6b8de38b86dd9.zip |
...
Diffstat (limited to 'BackEnd/Timeline.Tests/IntegratedTests2/UserTest.cs')
-rw-r--r-- | BackEnd/Timeline.Tests/IntegratedTests2/UserTest.cs | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/BackEnd/Timeline.Tests/IntegratedTests2/UserTest.cs b/BackEnd/Timeline.Tests/IntegratedTests2/UserTest.cs new file mode 100644 index 00000000..c5ec4c58 --- /dev/null +++ b/BackEnd/Timeline.Tests/IntegratedTests2/UserTest.cs @@ -0,0 +1,76 @@ +using System.Net; +using System.Net.Http; +using System.Threading.Tasks; +using FluentAssertions; +using Timeline.Models; +using Timeline.Models.Http; +using Xunit; +using Xunit.Abstractions; + +namespace Timeline.Tests.IntegratedTests2 +{ + public class UserTest : IntegratedTestBase + { + public UserTest(ITestOutputHelper testOutput) : base(testOutput) + { + } + + [Fact] + public async Task ListTest() + { + using var client = CreateDefaultClient(); + + var a = await client.TestJsonSendAsync<Page<HttpUser>>(HttpMethod.Get, "v2/users", expectedStatusCode: HttpStatusCode.OK); + a.TotalCount.Should().Be(3); + } + + [Fact] + public async Task GetTest() + { + using var client = CreateDefaultClient(); + + var a = await client.TestJsonSendAsync<HttpUser>(HttpMethod.Get, "v2/users/user", expectedStatusCode: HttpStatusCode.OK); + a.Username.Should().Be("user"); + } + + [Fact] + public async Task CreateTest() + { + using var client = CreateClientAsAdmin(); + + var a = await client.TestJsonSendAsync<HttpUser>(HttpMethod.Post, "v2/users", new HttpUserPostRequest + { + Username = "user2", + Password = "user2pw", + Nickname = "nickname" + }, expectedStatusCode: HttpStatusCode.Created); + + a.Username.Should().Be("user2"); + a.Nickname.Should().Be("nickname"); + } + + [Fact] + public async Task CreateNotLogin() + { + using var client = CreateDefaultClient(); + + await client.TestJsonSendAsync(HttpMethod.Post, "v2/users", new HttpUserPostRequest + { + Username = "user2", + Password = "user2pw", + }, expectedStatusCode: HttpStatusCode.Unauthorized); + } + + [Fact] + public async Task CreateForbid() + { + using var client = CreateClientAsUser(); + + await client.TestJsonSendAsync(HttpMethod.Post, "v2/users", new HttpUserPostRequest + { + Username = "user2", + Password = "user2pw", + }, expectedStatusCode: HttpStatusCode.Forbidden); + } + } +} |