Updated core unit tests to latest recommendations
This commit is contained in:
@@ -12,11 +12,13 @@ using AMWD.Net.Api.Cloudflare;
|
||||
using Moq;
|
||||
using Moq.Protected;
|
||||
|
||||
namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
namespace Cloudflare.Tests.CloudflareClientTests
|
||||
{
|
||||
[TestClass]
|
||||
public class PutAsyncTest
|
||||
{
|
||||
public TestContext TestContext { get; set; }
|
||||
|
||||
private const string BaseUrl = "https://localhost/api/v4/";
|
||||
|
||||
private HttpMessageHandlerMock _httpHandlerMock;
|
||||
@@ -52,46 +54,46 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[ExpectedException(typeof(ObjectDisposedException))]
|
||||
public async Task ShouldThrowDisposed()
|
||||
{
|
||||
// Arrange
|
||||
var client = GetClient() as CloudflareClient;
|
||||
client.Dispose();
|
||||
|
||||
// Act
|
||||
await client.PutAsync<object, object>("test", _request);
|
||||
|
||||
// Assert - ObjectDisposedException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ObjectDisposedException>(async () =>
|
||||
{
|
||||
await client.PutAsync<object, object>("test", _request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[DataRow(null)]
|
||||
[DataRow("")]
|
||||
[DataRow(" ")]
|
||||
[ExpectedException(typeof(ArgumentNullException))]
|
||||
public async Task ShouldThrowArgumentNullOnRequestPath(string path)
|
||||
{
|
||||
// Arrange
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.PutAsync<object, object>(path, _request);
|
||||
|
||||
// Assert - ArgumentNullException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentNullException>(async () =>
|
||||
{
|
||||
await client.PutAsync<object, object>(path, _request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[ExpectedException(typeof(ArgumentException))]
|
||||
public async Task ShouldThrowArgumentOnRequestPath()
|
||||
{
|
||||
// Arrange
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.PutAsync<object, object>("foo?bar=baz", _request);
|
||||
|
||||
// Assert - ArgumentException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentException>(async () =>
|
||||
{
|
||||
await client.PutAsync<object, object>("foo?bar=baz", _request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -107,7 +109,7 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.PutAsync<TestClass, TestClass>("test", _request);
|
||||
var response = await client.PutAsync<TestClass, TestClass>("test", _request, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
@@ -116,21 +118,21 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
Assert.IsNotNull(response.Messages);
|
||||
Assert.IsNull(response.ResultInfo);
|
||||
|
||||
Assert.AreEqual(0, response.Errors.Count);
|
||||
Assert.AreEqual(0, response.Messages.Count);
|
||||
Assert.IsEmpty(response.Errors);
|
||||
Assert.IsEmpty(response.Messages);
|
||||
|
||||
Assert.IsNotNull(response.Result);
|
||||
Assert.AreEqual("some-string", response.Result.Str);
|
||||
Assert.AreEqual(123, response.Result.Int);
|
||||
|
||||
Assert.AreEqual(1, _httpHandlerMock.Callbacks.Count);
|
||||
Assert.HasCount(1, _httpHandlerMock.Callbacks);
|
||||
|
||||
var callback = _httpHandlerMock.Callbacks.First();
|
||||
Assert.AreEqual(HttpMethod.Put, callback.Method);
|
||||
Assert.AreEqual("https://localhost/api/v4/test", callback.Url);
|
||||
Assert.AreEqual(@"{""string"":""Happy Testing!"",""integer"":54321}", callback.Content);
|
||||
|
||||
Assert.AreEqual(3, callback.Headers.Count);
|
||||
Assert.HasCount(3, callback.Headers);
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("Accept"));
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("Authorization"));
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("User-Agent"));
|
||||
@@ -159,7 +161,7 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.PutAsync<TestClass, StringContent>("test", stringContent);
|
||||
var response = await client.PutAsync<TestClass, StringContent>("test", stringContent, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
@@ -168,21 +170,21 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
Assert.IsNotNull(response.Messages);
|
||||
Assert.IsNull(response.ResultInfo);
|
||||
|
||||
Assert.AreEqual(0, response.Errors.Count);
|
||||
Assert.AreEqual(0, response.Messages.Count);
|
||||
Assert.IsEmpty(response.Errors);
|
||||
Assert.IsEmpty(response.Messages);
|
||||
|
||||
Assert.IsNotNull(response.Result);
|
||||
Assert.AreEqual("some-string", response.Result.Str);
|
||||
Assert.AreEqual(123, response.Result.Int);
|
||||
|
||||
Assert.AreEqual(1, _httpHandlerMock.Callbacks.Count);
|
||||
Assert.HasCount(1, _httpHandlerMock.Callbacks);
|
||||
|
||||
var callback = _httpHandlerMock.Callbacks.First();
|
||||
Assert.AreEqual(HttpMethod.Put, callback.Method);
|
||||
Assert.AreEqual("https://localhost/api/v4/test", callback.Url);
|
||||
Assert.AreEqual(@"{""test"":""HERE ?""}", callback.Content);
|
||||
|
||||
Assert.AreEqual(3, callback.Headers.Count);
|
||||
Assert.HasCount(3, callback.Headers);
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("Accept"));
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("Authorization"));
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("User-Agent"));
|
||||
@@ -210,7 +212,7 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.PutAsync<TestClass, object>("putput", null);
|
||||
var response = await client.PutAsync<TestClass, object>("putput", null, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
@@ -219,21 +221,21 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
Assert.IsNotNull(response.Messages);
|
||||
Assert.IsNull(response.ResultInfo);
|
||||
|
||||
Assert.AreEqual(0, response.Errors.Count);
|
||||
Assert.AreEqual(0, response.Messages.Count);
|
||||
Assert.IsEmpty(response.Errors);
|
||||
Assert.IsEmpty(response.Messages);
|
||||
|
||||
Assert.IsNotNull(response.Result);
|
||||
Assert.AreEqual("some-string", response.Result.Str);
|
||||
Assert.AreEqual(123, response.Result.Int);
|
||||
|
||||
Assert.AreEqual(1, _httpHandlerMock.Callbacks.Count);
|
||||
Assert.HasCount(1, _httpHandlerMock.Callbacks);
|
||||
|
||||
var callback = _httpHandlerMock.Callbacks.First();
|
||||
Assert.AreEqual(HttpMethod.Put, callback.Method);
|
||||
Assert.AreEqual("https://localhost/api/v4/putput", callback.Url);
|
||||
Assert.IsNull(callback.Content);
|
||||
|
||||
Assert.AreEqual(3, callback.Headers.Count);
|
||||
Assert.HasCount(3, callback.Headers);
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("Accept"));
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("Authorization"));
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("User-Agent"));
|
||||
@@ -262,7 +264,7 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
try
|
||||
{
|
||||
// Act
|
||||
await client.PutAsync<object, object>("foo", _request);
|
||||
await client.PutAsync<object, object>("foo", _request, TestContext.CancellationTokenSource.Token);
|
||||
Assert.Fail();
|
||||
}
|
||||
catch (AuthenticationException ex)
|
||||
@@ -287,7 +289,7 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.PutAsync<string, TestClass>("some-awesome-path", _request);
|
||||
var response = await client.PutAsync<string, TestClass>("some-awesome-path", _request, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
@@ -298,14 +300,14 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
|
||||
Assert.AreEqual("This is an awesome text ;-)", response.Result);
|
||||
|
||||
Assert.AreEqual(1, _httpHandlerMock.Callbacks.Count);
|
||||
Assert.HasCount(1, _httpHandlerMock.Callbacks);
|
||||
|
||||
var callback = _httpHandlerMock.Callbacks.First();
|
||||
Assert.AreEqual(HttpMethod.Put, callback.Method);
|
||||
Assert.AreEqual("https://localhost/api/v4/some-awesome-path?bar=08%2F15", callback.Url);
|
||||
Assert.AreEqual(@"{""string"":""Happy Testing!"",""integer"":54321}", callback.Content);
|
||||
|
||||
Assert.AreEqual(3, callback.Headers.Count);
|
||||
Assert.HasCount(3, callback.Headers);
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("Accept"));
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("Authorization"));
|
||||
Assert.IsTrue(callback.Headers.ContainsKey("User-Agent"));
|
||||
@@ -331,7 +333,6 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[ExpectedException(typeof(JsonReaderException))]
|
||||
public async Task ShouldThrowExceptionOnInvalidResponse()
|
||||
{
|
||||
// Arrange
|
||||
@@ -343,8 +344,11 @@ namespace Cloudflare.Core.Tests.CloudflareClientTests
|
||||
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.PutAsync<TestClass, TestClass>("some-path", _request);
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<JsonReaderException>(async () =>
|
||||
{
|
||||
await client.PutAsync<TestClass, TestClass>("some-path", _request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
private void VerifyDefaults()
|
||||
|
||||
Reference in New Issue
Block a user