aboutsummaryrefslogtreecommitdiff
path: root/Timeline.Tests/UnitTest.cs
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2019-02-04 23:25:33 +0800
committercrupest <crupest@outlook.com>2019-02-04 23:25:33 +0800
commitfdc51c9e4ac225311e4e14923e6b48efbd05a6e1 (patch)
tree387fa924f0fbdd7b40a25029d5e7c3955764272b /Timeline.Tests/UnitTest.cs
downloadtimeline-fdc51c9e4ac225311e4e14923e6b48efbd05a6e1.tar.gz
timeline-fdc51c9e4ac225311e4e14923e6b48efbd05a6e1.tar.bz2
timeline-fdc51c9e4ac225311e4e14923e6b48efbd05a6e1.zip
Init commit.
Diffstat (limited to 'Timeline.Tests/UnitTest.cs')
-rw-r--r--Timeline.Tests/UnitTest.cs58
1 files changed, 58 insertions, 0 deletions
diff --git a/Timeline.Tests/UnitTest.cs b/Timeline.Tests/UnitTest.cs
new file mode 100644
index 00000000..e201061b
--- /dev/null
+++ b/Timeline.Tests/UnitTest.cs
@@ -0,0 +1,58 @@
+using Microsoft.AspNetCore.Mvc.Testing;
+using System;
+using System.Linq;
+using System.Net;
+using System.Net.Http;
+using System.Threading.Tasks;
+using Timeline.Controllers;
+using Timeline.Tests.Helpers;
+using Xunit;
+using Xunit.Abstractions;
+
+namespace Timeline.Tests
+{
+ public class UnitTest : IClassFixture<WebApplicationFactory<Startup>>
+ {
+ private readonly WebApplicationFactory<Startup> _factory;
+
+ public UnitTest(WebApplicationFactory<Startup> factory, ITestOutputHelper outputHelper)
+ {
+ _factory = factory.WithTestConfig(outputHelper);
+ }
+
+ [Fact]
+ public async Task UnauthenticationTest()
+ {
+ using (var client = _factory.CreateDefaultClient())
+ {
+ var response = await client.GetAsync("/api/SampleData/WeatherForecasts");
+
+ Assert.Equal(HttpStatusCode.Unauthorized, response.StatusCode);
+ }
+ }
+
+ [Fact]
+ public async Task AuthenticationTest()
+ {
+ using (var client = _factory.CreateDefaultClient())
+ {
+ var response = await client.PostAsJsonAsync("/api/User/LogIn", new UserController.UserCredentials { Username = "crupest", Password = "yang0101" });
+
+ Assert.Equal(HttpStatusCode.OK, response.StatusCode);
+
+ var token = response.Headers.GetValues("Authorization").Single();
+
+ var request = new HttpRequestMessage
+ {
+ RequestUri = new Uri(client.BaseAddress, "/api/SampleData/WeatherForecasts"),
+ Method = HttpMethod.Get
+ };
+ request.Headers.Add("Authorization", token);
+
+ var response2 = await client.SendAsync(request);
+
+ Assert.Equal(HttpStatusCode.OK, response2.StatusCode);
+ }
+ }
+ }
+}