Updated DNS unit tests to latest recommendations
This commit is contained in:
@@ -10,6 +10,8 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions
|
||||
[TestClass]
|
||||
public class ShowDnsAccountSettingsTest
|
||||
{
|
||||
public TestContext TestContext { get; set; }
|
||||
|
||||
private const string AccountId = "023e105f4ecef8ad9ca31a8372d0c353";
|
||||
private const string ZoneId = "023e105f4ecef8ad9ca31a8372d0c354";
|
||||
|
||||
@@ -69,19 +71,19 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.ShowDnsAccountSettings(AccountId);
|
||||
var response = await client.ShowDnsAccountSettings(AccountId, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
Assert.IsTrue(response.Success);
|
||||
Assert.AreEqual(_response.Result, response.Result);
|
||||
|
||||
Assert.AreEqual(1, _callbacks.Count);
|
||||
Assert.HasCount(1, _callbacks);
|
||||
|
||||
var callback = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings", callback.RequestPath);
|
||||
var (requestPath, queryFilter) = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings", requestPath);
|
||||
|
||||
Assert.IsNull(callback.QueryFilter);
|
||||
Assert.IsNull(queryFilter);
|
||||
|
||||
_clientMock.Verify(m => m.GetAsync<DnsAccountSettings>($"/accounts/{AccountId}/dns_settings", null, It.IsAny<CancellationToken>()), Times.Once);
|
||||
_clientMock.VerifyNoOtherCalls();
|
||||
|
||||
@@ -11,6 +11,8 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions
|
||||
[TestClass]
|
||||
public class UpdateDnsAccountSettingsTest
|
||||
{
|
||||
public TestContext TestContext { get; set; }
|
||||
|
||||
private const string AccountId = "023e105f4ecef8ad9ca31a8372d0c353";
|
||||
private const string ZoneId = "023e105f4ecef8ad9ca31a8372d0c354";
|
||||
|
||||
@@ -100,37 +102,37 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.UpdateDnsAccountSettings(_request);
|
||||
var response = await client.UpdateDnsAccountSettings(_request, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
Assert.IsTrue(response.Success);
|
||||
Assert.AreEqual(_response.Result, response.Result);
|
||||
|
||||
Assert.AreEqual(1, _callbacks.Count);
|
||||
Assert.HasCount(1, _callbacks);
|
||||
|
||||
var callback = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings", callback.RequestPath);
|
||||
var (requestPath, request) = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings", requestPath);
|
||||
|
||||
Assert.IsNotNull(callback.Request);
|
||||
Assert.IsTrue(callback.Request.ZoneDefaults.FlattenAllCnames);
|
||||
Assert.IsFalse(callback.Request.ZoneDefaults.FoundationDns);
|
||||
Assert.IsNotNull(callback.Request.ZoneDefaults.InternalDns);
|
||||
Assert.AreEqual(ZoneId, callback.Request.ZoneDefaults.InternalDns.ReferenceZoneId);
|
||||
Assert.IsFalse(callback.Request.ZoneDefaults.MultiProvider);
|
||||
Assert.IsNotNull(callback.Request.ZoneDefaults.Nameservers);
|
||||
Assert.AreEqual(DnsAccountNameserversType.Random, callback.Request.ZoneDefaults.Nameservers.Type);
|
||||
Assert.AreEqual(86400, callback.Request.ZoneDefaults.NameserverTtl);
|
||||
Assert.IsFalse(callback.Request.ZoneDefaults.SecondaryOverrides);
|
||||
Assert.IsNotNull(callback.Request.ZoneDefaults.SOA);
|
||||
Assert.AreEqual(604800, callback.Request.ZoneDefaults.SOA.Expire);
|
||||
Assert.AreEqual(1800, callback.Request.ZoneDefaults.SOA.MinimumTtl);
|
||||
Assert.AreEqual("ns1.example.org", callback.Request.ZoneDefaults.SOA.PrimaryNameserver);
|
||||
Assert.AreEqual(28800, callback.Request.ZoneDefaults.SOA.Refresh);
|
||||
Assert.AreEqual(3600, callback.Request.ZoneDefaults.SOA.Retry);
|
||||
Assert.AreEqual(43200, callback.Request.ZoneDefaults.SOA.TimeToLive);
|
||||
Assert.AreEqual("admin.example.org", callback.Request.ZoneDefaults.SOA.ZoneAdministrator);
|
||||
Assert.AreEqual(DnsZoneMode.Standard, callback.Request.ZoneDefaults.ZoneMode);
|
||||
Assert.IsNotNull(request);
|
||||
Assert.IsTrue(request.ZoneDefaults.FlattenAllCnames);
|
||||
Assert.IsFalse(request.ZoneDefaults.FoundationDns);
|
||||
Assert.IsNotNull(request.ZoneDefaults.InternalDns);
|
||||
Assert.AreEqual(ZoneId, request.ZoneDefaults.InternalDns.ReferenceZoneId);
|
||||
Assert.IsFalse(request.ZoneDefaults.MultiProvider);
|
||||
Assert.IsNotNull(request.ZoneDefaults.Nameservers);
|
||||
Assert.AreEqual(DnsAccountNameserversType.Random, request.ZoneDefaults.Nameservers.Type);
|
||||
Assert.AreEqual(86400, request.ZoneDefaults.NameserverTtl);
|
||||
Assert.IsFalse(request.ZoneDefaults.SecondaryOverrides);
|
||||
Assert.IsNotNull(request.ZoneDefaults.SOA);
|
||||
Assert.AreEqual(604800, request.ZoneDefaults.SOA.Expire);
|
||||
Assert.AreEqual(1800, request.ZoneDefaults.SOA.MinimumTtl);
|
||||
Assert.AreEqual("ns1.example.org", request.ZoneDefaults.SOA.PrimaryNameserver);
|
||||
Assert.AreEqual(28800, request.ZoneDefaults.SOA.Refresh);
|
||||
Assert.AreEqual(3600, request.ZoneDefaults.SOA.Retry);
|
||||
Assert.AreEqual(43200, request.ZoneDefaults.SOA.TimeToLive);
|
||||
Assert.AreEqual("admin.example.org", request.ZoneDefaults.SOA.ZoneAdministrator);
|
||||
Assert.AreEqual(DnsZoneMode.Standard, request.ZoneDefaults.ZoneMode);
|
||||
|
||||
_clientMock.Verify(m => m.PatchAsync<DnsAccountSettings, InternalUpdateDnsAccountSettingsRequest>($"/accounts/{AccountId}/dns_settings", It.IsAny<InternalUpdateDnsAccountSettingsRequest>(), It.IsAny<CancellationToken>()), Times.Once);
|
||||
_clientMock.VerifyNoOtherCalls();
|
||||
@@ -140,24 +142,24 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions
|
||||
public async Task ShouldUpdateDnsSettingsNone()
|
||||
{
|
||||
// Arrange
|
||||
var request = new UpdateDnsAccountSettingsRequest(AccountId);
|
||||
var req = new UpdateDnsAccountSettingsRequest(AccountId);
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.UpdateDnsAccountSettings(request);
|
||||
var response = await client.UpdateDnsAccountSettings(req, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
Assert.IsTrue(response.Success);
|
||||
Assert.AreEqual(_response.Result, response.Result);
|
||||
|
||||
Assert.AreEqual(1, _callbacks.Count);
|
||||
Assert.HasCount(1, _callbacks);
|
||||
|
||||
var callback = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings", callback.RequestPath);
|
||||
var (requestPath, request) = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings", requestPath);
|
||||
|
||||
Assert.IsNotNull(callback.Request);
|
||||
Assert.IsNull(callback.Request.ZoneDefaults);
|
||||
Assert.IsNotNull(request);
|
||||
Assert.IsNull(request.ZoneDefaults);
|
||||
|
||||
_clientMock.Verify(m => m.PatchAsync<DnsAccountSettings, InternalUpdateDnsAccountSettingsRequest>($"/accounts/{AccountId}/dns_settings", It.IsAny<InternalUpdateDnsAccountSettingsRequest>(), It.IsAny<CancellationToken>()), Times.Once);
|
||||
_clientMock.VerifyNoOtherCalls();
|
||||
@@ -167,196 +169,196 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions
|
||||
public async Task ShouldUpdateDnsSettingsNoneDefaults()
|
||||
{
|
||||
// Arrange
|
||||
var request = new UpdateDnsAccountSettingsRequest(AccountId)
|
||||
var req = new UpdateDnsAccountSettingsRequest(AccountId)
|
||||
{
|
||||
ZoneDefaults = new DnsAccountZoneDefaults()
|
||||
};
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.UpdateDnsAccountSettings(request);
|
||||
var response = await client.UpdateDnsAccountSettings(req, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
Assert.IsTrue(response.Success);
|
||||
Assert.AreEqual(_response.Result, response.Result);
|
||||
|
||||
Assert.AreEqual(1, _callbacks.Count);
|
||||
Assert.HasCount(1, _callbacks);
|
||||
|
||||
var callback = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings", callback.RequestPath);
|
||||
var (requestPath, request) = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings", requestPath);
|
||||
|
||||
Assert.IsNotNull(callback.Request);
|
||||
Assert.IsNotNull(callback.Request.ZoneDefaults);
|
||||
Assert.IsNull(callback.Request.ZoneDefaults.FlattenAllCnames);
|
||||
Assert.IsNull(callback.Request.ZoneDefaults.FoundationDns);
|
||||
Assert.IsNull(callback.Request.ZoneDefaults.MultiProvider);
|
||||
Assert.IsNull(callback.Request.ZoneDefaults.Nameservers);
|
||||
Assert.IsNull(callback.Request.ZoneDefaults.NameserverTtl);
|
||||
Assert.IsNull(callback.Request.ZoneDefaults.SecondaryOverrides);
|
||||
Assert.IsNull(callback.Request.ZoneDefaults.SOA);
|
||||
Assert.IsNull(callback.Request.ZoneDefaults.ZoneMode);
|
||||
Assert.IsNotNull(request);
|
||||
Assert.IsNotNull(request.ZoneDefaults);
|
||||
Assert.IsNull(request.ZoneDefaults.FlattenAllCnames);
|
||||
Assert.IsNull(request.ZoneDefaults.FoundationDns);
|
||||
Assert.IsNull(request.ZoneDefaults.MultiProvider);
|
||||
Assert.IsNull(request.ZoneDefaults.Nameservers);
|
||||
Assert.IsNull(request.ZoneDefaults.NameserverTtl);
|
||||
Assert.IsNull(request.ZoneDefaults.SecondaryOverrides);
|
||||
Assert.IsNull(request.ZoneDefaults.SOA);
|
||||
Assert.IsNull(request.ZoneDefaults.ZoneMode);
|
||||
|
||||
_clientMock.Verify(m => m.PatchAsync<DnsAccountSettings, InternalUpdateDnsAccountSettingsRequest>($"/accounts/{AccountId}/dns_settings", It.IsAny<InternalUpdateDnsAccountSettingsRequest>(), It.IsAny<CancellationToken>()), Times.Once);
|
||||
_clientMock.VerifyNoOtherCalls();
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[ExpectedException(typeof(ArgumentOutOfRangeException))]
|
||||
public async Task ShouldThrowArgumentOutOfRangeExceptionForInvalidMode()
|
||||
{
|
||||
// Arrange
|
||||
_request.ZoneDefaults.ZoneMode = 0;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.UpdateDnsAccountSettings(_request);
|
||||
|
||||
// Assert - ArgumentOutOfRangeException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentOutOfRangeException>(async () =>
|
||||
{
|
||||
await client.UpdateDnsAccountSettings(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[ExpectedException(typeof(ArgumentOutOfRangeException))]
|
||||
public async Task ShouldThrowArgumentOutOfRangeExceptionForInvalidNameserverType()
|
||||
{
|
||||
// Arrange
|
||||
_request.ZoneDefaults.Nameservers.Type = 0;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.UpdateDnsAccountSettings(_request);
|
||||
|
||||
// Assert - ArgumentOutOfRangeException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentOutOfRangeException>(async () =>
|
||||
{
|
||||
await client.UpdateDnsAccountSettings(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[DataRow(29)]
|
||||
[DataRow(86401)]
|
||||
[ExpectedException(typeof(ArgumentOutOfRangeException))]
|
||||
public async Task ShouldThrowArgumentOutOfRangeExceptionForInvalidNameserverTtl(int ttl)
|
||||
{
|
||||
// Arrange
|
||||
_request.ZoneDefaults.NameserverTtl = ttl;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.UpdateDnsAccountSettings(_request);
|
||||
|
||||
// Assert - ArgumentOutOfRangeException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentOutOfRangeException>(async () =>
|
||||
{
|
||||
await client.UpdateDnsAccountSettings(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[DataRow(86399)]
|
||||
[DataRow(2419201)]
|
||||
[ExpectedException(typeof(ArgumentOutOfRangeException))]
|
||||
public async Task ShouldThrowArgumentOutOfRangeExceptionForInvalidSoaExpire(int ttl)
|
||||
{
|
||||
// Arrange
|
||||
_request.ZoneDefaults.SOA.Expire = ttl;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.UpdateDnsAccountSettings(_request);
|
||||
|
||||
// Assert - ArgumentOutOfRangeException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentOutOfRangeException>(async () =>
|
||||
{
|
||||
await client.UpdateDnsAccountSettings(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[DataRow(59)]
|
||||
[DataRow(86401)]
|
||||
[ExpectedException(typeof(ArgumentOutOfRangeException))]
|
||||
public async Task ShouldThrowArgumentOutOfRangeExceptionForInvalidSoaMinimumTtl(int ttl)
|
||||
{
|
||||
// Arrange
|
||||
_request.ZoneDefaults.SOA.MinimumTtl = ttl;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.UpdateDnsAccountSettings(_request);
|
||||
|
||||
// Assert - ArgumentOutOfRangeException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentOutOfRangeException>(async () =>
|
||||
{
|
||||
await client.UpdateDnsAccountSettings(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[DataRow(null)]
|
||||
[DataRow("")]
|
||||
[DataRow(" ")]
|
||||
[ExpectedException(typeof(ArgumentNullException))]
|
||||
public async Task ShouldThrowArgumentNullExceptionForMissingSoaNameserver(string nameserver)
|
||||
{
|
||||
// Arrange
|
||||
_request.ZoneDefaults.SOA.PrimaryNameserver = nameserver;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.UpdateDnsAccountSettings(_request);
|
||||
|
||||
// Assert - ArgumentNullException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentNullException>(async () =>
|
||||
{
|
||||
await client.UpdateDnsAccountSettings(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[DataRow(599)]
|
||||
[DataRow(86401)]
|
||||
[ExpectedException(typeof(ArgumentOutOfRangeException))]
|
||||
public async Task ShouldThrowArgumentOutOfRangeExceptionForInvalidSoaRefresh(int ttl)
|
||||
{
|
||||
// Arrange
|
||||
_request.ZoneDefaults.SOA.Refresh = ttl;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.UpdateDnsAccountSettings(_request);
|
||||
|
||||
// Assert - ArgumentOutOfRangeException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentOutOfRangeException>(async () =>
|
||||
{
|
||||
await client.UpdateDnsAccountSettings(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[DataRow(599)]
|
||||
[DataRow(86401)]
|
||||
[ExpectedException(typeof(ArgumentOutOfRangeException))]
|
||||
public async Task ShouldThrowArgumentOutOfRangeExceptionForInvalidSoaRetry(int ttl)
|
||||
{
|
||||
// Arrange
|
||||
_request.ZoneDefaults.SOA.Retry = ttl;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.UpdateDnsAccountSettings(_request);
|
||||
|
||||
// Assert - ArgumentOutOfRangeException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentOutOfRangeException>(async () =>
|
||||
{
|
||||
await client.UpdateDnsAccountSettings(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[DataRow(299)]
|
||||
[DataRow(86401)]
|
||||
[ExpectedException(typeof(ArgumentOutOfRangeException))]
|
||||
public async Task ShouldThrowArgumentOutOfRangeExceptionForInvalidSoaTtl(int ttl)
|
||||
{
|
||||
// Arrange
|
||||
_request.ZoneDefaults.SOA.TimeToLive = ttl;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.UpdateDnsAccountSettings(_request);
|
||||
|
||||
// Assert - ArgumentOutOfRangeException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentOutOfRangeException>(async () =>
|
||||
{
|
||||
await client.UpdateDnsAccountSettings(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[DataRow(null)]
|
||||
[DataRow("")]
|
||||
[DataRow(" ")]
|
||||
[ExpectedException(typeof(ArgumentNullException))]
|
||||
public async Task ShouldThrowArgumentNullExceptionForMissingSoaAdministrator(string admin)
|
||||
{
|
||||
// Arrange
|
||||
_request.ZoneDefaults.SOA.ZoneAdministrator = admin;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
await client.UpdateDnsAccountSettings(_request);
|
||||
|
||||
// Assert - ArgumentNullException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentNullException>(async () =>
|
||||
{
|
||||
await client.UpdateDnsAccountSettings(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
private ICloudflareClient GetClient()
|
||||
|
||||
@@ -11,6 +11,8 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
[TestClass]
|
||||
public class CreateInternalDnsViewTest
|
||||
{
|
||||
public TestContext TestContext { get; set; }
|
||||
|
||||
private const string AccountId = "023e105f4ecef8ad9ca31a8372d0c353";
|
||||
private const string ViewId = "023e105f4ecef8ad9ca31a8372d0c354";
|
||||
private const string ViewName = "InternalView";
|
||||
@@ -50,21 +52,21 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.CreateInternalDnsView(_request);
|
||||
var response = await client.CreateInternalDnsView(_request, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
Assert.IsTrue(response.Success);
|
||||
Assert.AreEqual(_response.Result, response.Result);
|
||||
|
||||
Assert.AreEqual(1, _callbacks.Count);
|
||||
Assert.HasCount(1, _callbacks);
|
||||
|
||||
var callback = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views", callback.RequestPath);
|
||||
Assert.IsNotNull(callback.Request);
|
||||
var (requestPath, request) = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views", requestPath);
|
||||
Assert.IsNotNull(request);
|
||||
|
||||
Assert.AreEqual(ViewName, callback.Request.Name);
|
||||
CollectionAssert.AreEqual(_request.ZoneIds.ToList(), callback.Request.Zones.ToList());
|
||||
Assert.AreEqual(ViewName, request.Name);
|
||||
CollectionAssert.AreEqual(_request.ZoneIds.ToList(), request.Zones.ToList());
|
||||
|
||||
_clientMock.Verify(m => m.PostAsync<InternalDnsView, InternalModifyInternalDnsViewRequest>($"/accounts/{AccountId}/dns_settings/views", It.IsAny<InternalModifyInternalDnsViewRequest>(), null, It.IsAny<CancellationToken>()), Times.Once);
|
||||
_clientMock.VerifyNoOtherCalls();
|
||||
@@ -74,31 +76,31 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
[DataRow(null)]
|
||||
[DataRow("")]
|
||||
[DataRow(" ")]
|
||||
[ExpectedException(typeof(ArgumentNullException))]
|
||||
public async Task ShouldThrowArgumentNullExceptionWhenNameIsNull(string name)
|
||||
{
|
||||
// Arrange
|
||||
_request.Name = name;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.CreateInternalDnsView(_request);
|
||||
|
||||
// Assert - ArgumentNullException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentNullException>(async () =>
|
||||
{
|
||||
var response = await client.CreateInternalDnsView(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[ExpectedException(typeof(ArgumentOutOfRangeException))]
|
||||
public async Task ShouldThrowArgumentOutOfRangeExceptionWhenNameTooLong()
|
||||
{
|
||||
// Arrange
|
||||
_request.Name = new string('a', 256);
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.CreateInternalDnsView(_request);
|
||||
|
||||
// Assert - ArgumentOutOfRangeException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentOutOfRangeException>(async () =>
|
||||
{
|
||||
var response = await client.CreateInternalDnsView(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
private ICloudflareClient GetClient()
|
||||
|
||||
@@ -10,6 +10,8 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
[TestClass]
|
||||
public class DeleteInternalDnsViewTest
|
||||
{
|
||||
public TestContext TestContext { get; set; }
|
||||
|
||||
private const string AccountId = "023e105f4ecef8ad9ca31a8372d0c353";
|
||||
private const string ViewId = "023e105f4ecef8ad9ca31a8372d0c354";
|
||||
|
||||
@@ -45,18 +47,18 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.DeleteInternalDnsView(AccountId, ViewId);
|
||||
var response = await client.DeleteInternalDnsView(AccountId, ViewId, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
Assert.IsTrue(response.Success);
|
||||
Assert.AreEqual(_response.Result, response.Result);
|
||||
|
||||
Assert.AreEqual(1, _callbacks.Count);
|
||||
Assert.HasCount(1, _callbacks);
|
||||
|
||||
var callback = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views/{ViewId}", callback.RequestPath);
|
||||
Assert.IsNull(callback.QueryFilter);
|
||||
var (requestPath, queryFilter) = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views/{ViewId}", requestPath);
|
||||
Assert.IsNull(queryFilter);
|
||||
|
||||
_clientMock.Verify(m => m.DeleteAsync<Identifier>($"/accounts/{AccountId}/dns_settings/views/{ViewId}", null, It.IsAny<CancellationToken>()), Times.Once);
|
||||
_clientMock.VerifyNoOtherCalls();
|
||||
|
||||
@@ -10,6 +10,8 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
[TestClass]
|
||||
public class InternalDnsViewDetailsTest
|
||||
{
|
||||
public TestContext TestContext { get; set; }
|
||||
|
||||
private const string AccountId = "023e105f4ecef8ad9ca31a8372d0c353";
|
||||
private const string ViewId = "023e105f4ecef8ad9ca31a8372d0c354";
|
||||
private const string ViewName = "InternalView";
|
||||
@@ -43,18 +45,18 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.InternalDnsViewDetails(AccountId, ViewId);
|
||||
var response = await client.InternalDnsViewDetails(AccountId, ViewId, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
Assert.IsTrue(response.Success);
|
||||
Assert.AreEqual(_response.Result, response.Result);
|
||||
|
||||
Assert.AreEqual(1, _callbacks.Count);
|
||||
Assert.HasCount(1, _callbacks);
|
||||
|
||||
var callback = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views/{ViewId}", callback.RequestPath);
|
||||
Assert.IsNull(callback.QueryFilter);
|
||||
var (requestPath, queryFilter) = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views/{ViewId}", requestPath);
|
||||
Assert.IsNull(queryFilter);
|
||||
|
||||
_clientMock.Verify(m => m.GetAsync<InternalDnsView>(
|
||||
$"/accounts/{AccountId}/dns_settings/views/{ViewId}",
|
||||
|
||||
@@ -10,6 +10,8 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
[TestClass]
|
||||
public class ListInternalDnsViewsTest
|
||||
{
|
||||
public TestContext TestContext { get; set; }
|
||||
|
||||
private const string AccountId = "023e105f4ecef8ad9ca31a8372d0c353";
|
||||
|
||||
private Mock<ICloudflareClient> _clientMock;
|
||||
@@ -45,19 +47,19 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.ListInternalDnsViews(AccountId);
|
||||
var response = await client.ListInternalDnsViews(AccountId, cancellationToken: TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
Assert.IsTrue(response.Success);
|
||||
Assert.IsNotNull(response.Result);
|
||||
Assert.AreEqual(2, response.Result.Count);
|
||||
Assert.HasCount(2, response.Result);
|
||||
|
||||
Assert.AreEqual(1, _callbacks.Count);
|
||||
Assert.HasCount(1, _callbacks);
|
||||
|
||||
var callback = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views", callback.RequestPath);
|
||||
Assert.IsNull(callback.QueryFilter);
|
||||
var (requestPath, queryFilter) = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views", requestPath);
|
||||
Assert.IsNull(queryFilter);
|
||||
|
||||
_clientMock.Verify(m => m.GetAsync<IReadOnlyCollection<InternalDnsView>>(
|
||||
$"/accounts/{AccountId}/dns_settings/views",
|
||||
@@ -77,18 +79,18 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
};
|
||||
|
||||
// Act
|
||||
var response = await client.ListInternalDnsViews(AccountId, filter);
|
||||
var response = await client.ListInternalDnsViews(AccountId, filter, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
Assert.IsTrue(response.Success);
|
||||
Assert.IsNotNull(response.Result);
|
||||
|
||||
Assert.AreEqual(1, _callbacks.Count);
|
||||
Assert.HasCount(1, _callbacks);
|
||||
|
||||
var callback = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views", callback.RequestPath);
|
||||
Assert.AreEqual(filter, callback.QueryFilter);
|
||||
var (requestPath, queryFilter) = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views", requestPath);
|
||||
Assert.AreEqual(filter, queryFilter);
|
||||
|
||||
_clientMock.Verify(m => m.GetAsync<IReadOnlyCollection<InternalDnsView>>(
|
||||
$"/accounts/{AccountId}/dns_settings/views",
|
||||
@@ -110,7 +112,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -137,7 +139,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(11, dict.Count);
|
||||
Assert.HasCount(11, dict);
|
||||
|
||||
Assert.AreEqual("desc", dict["direction"]);
|
||||
Assert.AreEqual("all", dict["match"]);
|
||||
@@ -166,7 +168,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -183,7 +185,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -200,7 +202,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -217,7 +219,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -233,7 +235,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -249,7 +251,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -265,7 +267,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -281,7 +283,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -298,7 +300,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -315,7 +317,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
@@ -332,7 +334,7 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(dict);
|
||||
Assert.AreEqual(0, dict.Count);
|
||||
Assert.IsEmpty(dict);
|
||||
}
|
||||
|
||||
#endregion QueryFilter
|
||||
|
||||
@@ -11,6 +11,8 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
[TestClass]
|
||||
public class UpdateInternalDnsViewTest
|
||||
{
|
||||
public TestContext TestContext { get; set; }
|
||||
|
||||
private const string AccountId = "023e105f4ecef8ad9ca31a8372d0c353";
|
||||
private const string ViewId = "023e105f4ecef8ad9ca31a8372d0c354";
|
||||
private const string ViewName = "InternalView";
|
||||
@@ -50,21 +52,21 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.UpdateInternalDnsView(_request);
|
||||
var response = await client.UpdateInternalDnsView(_request, TestContext.CancellationTokenSource.Token);
|
||||
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
Assert.IsTrue(response.Success);
|
||||
Assert.AreEqual(_response.Result, response.Result);
|
||||
|
||||
Assert.AreEqual(1, _callbacks.Count);
|
||||
Assert.HasCount(1, _callbacks);
|
||||
|
||||
var callback = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views/{ViewId}", callback.RequestPath);
|
||||
Assert.IsNotNull(callback.Request);
|
||||
var (requestPath, request) = _callbacks.First();
|
||||
Assert.AreEqual($"/accounts/{AccountId}/dns_settings/views/{ViewId}", requestPath);
|
||||
Assert.IsNotNull(request);
|
||||
|
||||
Assert.AreEqual(ViewName, callback.Request.Name);
|
||||
CollectionAssert.AreEqual(_request.ZoneIds.ToList(), callback.Request.Zones.ToList());
|
||||
Assert.AreEqual(ViewName, request.Name);
|
||||
CollectionAssert.AreEqual(_request.ZoneIds.ToList(), request.Zones.ToList());
|
||||
|
||||
_clientMock.Verify(m => m.PatchAsync<InternalDnsView, InternalModifyInternalDnsViewRequest>(
|
||||
$"/accounts/{AccountId}/dns_settings/views/{ViewId}",
|
||||
@@ -77,31 +79,31 @@ namespace Cloudflare.Dns.Tests.DnsAccountSettingsExtensions.Views
|
||||
[DataRow(null)]
|
||||
[DataRow("")]
|
||||
[DataRow(" ")]
|
||||
[ExpectedException(typeof(ArgumentNullException))]
|
||||
public async Task ShouldThrowArgumentNullExceptionWhenNameIsNull(string name)
|
||||
{
|
||||
// Arrange
|
||||
_request.Name = name;
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.UpdateInternalDnsView(_request);
|
||||
|
||||
// Assert - ArgumentNullException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentNullException>(async () =>
|
||||
{
|
||||
var response = await client.UpdateInternalDnsView(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
[ExpectedException(typeof(ArgumentOutOfRangeException))]
|
||||
public async Task ShouldThrowArgumentOutOfRangeExceptionWhenNameTooLong()
|
||||
{
|
||||
// Arrange
|
||||
_request.Name = new string('a', 256);
|
||||
var client = GetClient();
|
||||
|
||||
// Act
|
||||
var response = await client.UpdateInternalDnsView(_request);
|
||||
|
||||
// Assert - ArgumentOutOfRangeException
|
||||
// Act & Assert
|
||||
await Assert.ThrowsExactlyAsync<ArgumentOutOfRangeException>(async () =>
|
||||
{
|
||||
var response = await client.UpdateInternalDnsView(_request, TestContext.CancellationTokenSource.Token);
|
||||
});
|
||||
}
|
||||
|
||||
private ICloudflareClient GetClient()
|
||||
|
||||
Reference in New Issue
Block a user