diff options
author | crupest <crupest@outlook.com> | 2020-11-14 01:58:38 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2020-11-14 01:58:38 +0800 |
commit | 301780410580647b994e13bc2367153569d04634 (patch) | |
tree | 401cf27c708dcfdf49d31b6596cfa9f69e191d0f /BackEnd/Timeline.Tests/IntegratedTests/HttpClientExtensions.cs | |
parent | 48d53341db4953b3d583dd825b48d854c0a166e9 (diff) | |
download | timeline-301780410580647b994e13bc2367153569d04634.tar.gz timeline-301780410580647b994e13bc2367153569d04634.tar.bz2 timeline-301780410580647b994e13bc2367153569d04634.zip |
...
Diffstat (limited to 'BackEnd/Timeline.Tests/IntegratedTests/HttpClientExtensions.cs')
-rw-r--r-- | BackEnd/Timeline.Tests/IntegratedTests/HttpClientExtensions.cs | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/BackEnd/Timeline.Tests/IntegratedTests/HttpClientExtensions.cs b/BackEnd/Timeline.Tests/IntegratedTests/HttpClientExtensions.cs new file mode 100644 index 00000000..9258e644 --- /dev/null +++ b/BackEnd/Timeline.Tests/IntegratedTests/HttpClientExtensions.cs @@ -0,0 +1,48 @@ +using System;
+using System.Net.Http;
+using System.Net.Http.Headers;
+using System.Net.Http.Json;
+using System.Net.Mime;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace Timeline.Tests.IntegratedTests
+{
+ public static class HttpClientExtensions
+ {
+ public static async Task<HttpResponseMessage> PatchAsJsonAsync<T>(this HttpClient client, string url, T body)
+ {
+ using var reqContent = JsonContent.Create(body, options: CommonJsonSerializeOptions.Options);
+ return await client.PatchAsync(url, reqContent);
+ }
+
+ public static Task<HttpResponseMessage> PutAsync(this HttpClient client, string url)
+ {
+ return client.PutAsync(url, null!);
+ }
+
+ public static Task<HttpResponseMessage> PutByteArrayAsync(this HttpClient client, string url, byte[] body, string mimeType)
+ {
+ return client.PutByteArrayAsync(new Uri(url, UriKind.RelativeOrAbsolute), body, mimeType);
+ }
+
+ public static async Task<HttpResponseMessage> PutByteArrayAsync(this HttpClient client, Uri url, byte[] body, string mimeType)
+ {
+ using var content = new ByteArrayContent(body);
+ content.Headers.ContentLength = body.Length;
+ content.Headers.ContentType = new MediaTypeHeaderValue(mimeType);
+ return await client.PutAsync(url, content);
+ }
+
+ public static Task<HttpResponseMessage> PutStringAsync(this HttpClient client, string url, string body, string? mimeType = null)
+ {
+ return client.PutStringAsync(new Uri(url, UriKind.RelativeOrAbsolute), body, mimeType);
+ }
+
+ public static async Task<HttpResponseMessage> PutStringAsync(this HttpClient client, Uri url, string body, string? mimeType = null)
+ {
+ using var content = new StringContent(body, Encoding.UTF8, mimeType ?? MediaTypeNames.Text.Plain);
+ return await client.PutAsync(url, content);
+ }
+ }
+}
|