From bab2b1d568a7273b6800dbe6ffd31972d5cedd24 Mon Sep 17 00:00:00 2001 From: crupest Date: Fri, 8 Apr 2022 23:07:56 +0800 Subject: ... --- .../IntegratedTests2/TimelinePostTest3.cs | 97 ++++++++++++++++++++++ 1 file changed, 97 insertions(+) create mode 100644 BackEnd/Timeline.Tests/IntegratedTests2/TimelinePostTest3.cs (limited to 'BackEnd') diff --git a/BackEnd/Timeline.Tests/IntegratedTests2/TimelinePostTest3.cs b/BackEnd/Timeline.Tests/IntegratedTests2/TimelinePostTest3.cs new file mode 100644 index 00000000..345a8e81 --- /dev/null +++ b/BackEnd/Timeline.Tests/IntegratedTests2/TimelinePostTest3.cs @@ -0,0 +1,97 @@ +using System; +using System.Collections.Generic; +using System.Net; +using System.Net.Http; +using System.Text; +using System.Threading.Tasks; +using FluentAssertions; +using Timeline.Models; +using Timeline.Models.Http; +using Timeline.Tests.Helpers; +using Xunit; +using Xunit.Abstractions; + +namespace Timeline.Tests.IntegratedTests2 +{ + public class TimelinePostTest3 : IntegratedTestBase + { + public TimelinePostTest3(ITestOutputHelper testOutput) : base(testOutput) + { + } + + protected override async Task OnInitializeAsync() + { + using var client = CreateClientAsUser(); + await client.TestJsonSendAsync(HttpMethod.Post, "v2/timelines", new HttpTimelineCreateRequest + { + Name = "hello" + }, expectedStatusCode: HttpStatusCode.Created); + + await client.TestJsonSendAsync(HttpMethod.Patch, "v2/timelines/user/hello", new HttpTimelinePatchRequest + { + Visibility = TimelineVisibility.Private + }); + + + await client.TestJsonSendAsync(HttpMethod.Post, "v2/timelines/user/hello/posts", new HttpTimelinePostCreateRequest + { + DataList = new List + { + new HttpTimelinePostCreateRequestData + { + ContentType = MimeTypes.TextPlain, + Data = Convert.ToBase64String(Encoding.UTF8.GetBytes("hello1")) + }, + new HttpTimelinePostCreateRequestData + { + ContentType = MimeTypes.TextMarkdown, + Data = Convert.ToBase64String(Encoding.UTF8.GetBytes("hello*2*")) + }, + new HttpTimelinePostCreateRequestData + { + ContentType = MimeTypes.ImagePng, + Data = Convert.ToBase64String(ImageHelper.CreatePngWithSize(100, 100)) + } + } + }, expectedStatusCode: HttpStatusCode.Created); + } + + [Fact] + public async Task PostDataIndexGet() + { + using var client = CreateClientAsUser(); + await client.TestSendAsync(HttpMethod.Get, "v2/timelines/user/hello/posts/1/data"); + } + + [Fact] + public async Task PostDataGet() + { + using var client = CreateClientAsUser(); + await client.TestSendAsync(HttpMethod.Get, "v2/timelines/user/hello/posts/1/data/1"); + } + + [Fact] + public async Task PostDataGetNotExist() + { + using var client = CreateClientAsUser(); + await client.TestSendAsync(HttpMethod.Get, "v2/timelines/user/hello/posts/1/data/3", expectedStatusCode: HttpStatusCode.NotFound); + } + + [Fact] + public async Task PostDataGetNotLogin() + { + using var client = CreateDefaultClient(); + await client.TestSendAsync(HttpMethod.Get, "v2/timelines/user/hello/posts/1/data", expectedStatusCode: HttpStatusCode.Forbidden); + await client.TestSendAsync(HttpMethod.Get, "v2/timelines/user/hello/posts/1/data/1", expectedStatusCode: HttpStatusCode.Forbidden); + } + + [Fact] + public async Task PostDataGetForbid() + { + await CreateUserAsync("user2", "user2pw"); + using var client = CreateClientWithToken(await CreateTokenWithCredentialAsync("user2", "user2pw")); + await client.TestSendAsync(HttpMethod.Get, "v2/timelines/user/hello/posts/1/data", expectedStatusCode: HttpStatusCode.Forbidden); + await client.TestSendAsync(HttpMethod.Get, "v2/timelines/user/hello/posts/1/data/1", expectedStatusCode: HttpStatusCode.Forbidden); + } + } +} -- cgit v1.2.3