Fixing issue with abstract class
This commit is contained in:
@@ -5,6 +5,7 @@ using AMWD.Net.Api.Cloudflare;
|
||||
using AMWD.Net.Api.Cloudflare.Dns;
|
||||
using AMWD.Net.Api.Cloudflare.Dns.Internals;
|
||||
using Moq;
|
||||
using Newtonsoft.Json.Linq;
|
||||
|
||||
namespace Cloudflare.Dns.Tests.DnsRecordsExtensions
|
||||
{
|
||||
@@ -20,7 +21,7 @@ namespace Cloudflare.Dns.Tests.DnsRecordsExtensions
|
||||
private Mock<ICloudflareClient> _clientMock;
|
||||
|
||||
private List<(string RequestPath, InternalBatchRequest Request, IQueryParameterFilter QueryFilter)> _callbacks;
|
||||
private CloudflareResponse<BatchDnsRecordsResponse> _response;
|
||||
private CloudflareResponse<JObject> _response;
|
||||
private BatchDnsRecordsRequest _request;
|
||||
|
||||
[TestInitialize]
|
||||
@@ -28,7 +29,7 @@ namespace Cloudflare.Dns.Tests.DnsRecordsExtensions
|
||||
{
|
||||
_callbacks = [];
|
||||
|
||||
_response = new CloudflareResponse<BatchDnsRecordsResponse>
|
||||
_response = new CloudflareResponse<JObject>
|
||||
{
|
||||
Success = true,
|
||||
Messages = [
|
||||
@@ -37,15 +38,21 @@ namespace Cloudflare.Dns.Tests.DnsRecordsExtensions
|
||||
Errors = [
|
||||
new ResponseInfo(1000, "Error 1")
|
||||
],
|
||||
Result = new BatchDnsRecordsResponse()
|
||||
Result = new JObject
|
||||
{
|
||||
["deletes"] = JArray.FromObject(new[] { JObject.FromObject(new ARecord(DomainName) { Id = RecordId, Content = IpContent }) }),
|
||||
["patches"] = JArray.FromObject(new[] { JObject.FromObject(new ARecord(DomainName) { Id = RecordId, Content = IpContent }) }),
|
||||
["posts"] = JArray.FromObject(new[] { JObject.FromObject(new ARecord(DomainName) { Id = RecordId, Content = IpContent }) }),
|
||||
["puts"] = JArray.FromObject(new[] { JObject.FromObject(new ARecord(DomainName) { Id = RecordId, Content = IpContent }) })
|
||||
}
|
||||
};
|
||||
|
||||
_request = new BatchDnsRecordsRequest(ZoneId)
|
||||
{
|
||||
Deletes = [RecordId],
|
||||
Updates = [new BatchDnsRecordsRequest.Patch(RecordId, DomainName) { Type = DnsRecordType.A, Content = IpContent }],
|
||||
Overwrites = [new BatchDnsRecordsRequest.Put(RecordId, DomainName) { Type = DnsRecordType.A, Content = IpContent }],
|
||||
Creates = [new BatchDnsRecordsRequest.Post(DomainName) { Type = DnsRecordType.A, Content = IpContent }],
|
||||
Updates = [new BatchDnsRecordsRequest.Patch(RecordId, DomainName) { Type = DnsRecordType.A, Content = IpContent }],
|
||||
Overwrites = [new BatchDnsRecordsRequest.Put(RecordId, DomainName) { Type = DnsRecordType.A, Content = IpContent }]
|
||||
};
|
||||
}
|
||||
|
||||
@@ -61,7 +68,16 @@ namespace Cloudflare.Dns.Tests.DnsRecordsExtensions
|
||||
// Assert
|
||||
Assert.IsNotNull(response);
|
||||
Assert.IsTrue(response.Success);
|
||||
Assert.AreEqual(_response.Result, response.Result);
|
||||
Assert.IsNotNull(response.Result);
|
||||
|
||||
Assert.AreEqual(RecordId, response.Result.Deletes.Single().Id);
|
||||
Assert.AreEqual(IpContent, response.Result.Deletes.Single().Content);
|
||||
Assert.AreEqual(RecordId, response.Result.Creates.Single().Id);
|
||||
Assert.AreEqual(IpContent, response.Result.Creates.Single().Content);
|
||||
Assert.AreEqual(RecordId, response.Result.Updates.Single().Id);
|
||||
Assert.AreEqual(IpContent, response.Result.Updates.Single().Content);
|
||||
Assert.AreEqual(RecordId, response.Result.Overwrites.Single().Id);
|
||||
Assert.AreEqual(IpContent, response.Result.Overwrites.Single().Content);
|
||||
|
||||
Assert.AreEqual(1, _callbacks.Count);
|
||||
|
||||
@@ -93,7 +109,7 @@ namespace Cloudflare.Dns.Tests.DnsRecordsExtensions
|
||||
Assert.AreEqual(DnsRecordType.A, post.Type);
|
||||
Assert.AreEqual(IpContent, post.Content);
|
||||
|
||||
_clientMock.Verify(m => m.PostAsync<BatchDnsRecordsResponse, InternalBatchRequest>($"/zones/{ZoneId}/dns_records/batch", It.IsAny<InternalBatchRequest>(), null, It.IsAny<CancellationToken>()), Times.Once);
|
||||
_clientMock.Verify(m => m.PostAsync<JObject, InternalBatchRequest>($"/zones/{ZoneId}/dns_records/batch", It.IsAny<InternalBatchRequest>(), null, It.IsAny<CancellationToken>()), Times.Once);
|
||||
_clientMock.VerifyNoOtherCalls();
|
||||
}
|
||||
|
||||
@@ -101,7 +117,7 @@ namespace Cloudflare.Dns.Tests.DnsRecordsExtensions
|
||||
{
|
||||
_clientMock = new Mock<ICloudflareClient>();
|
||||
_clientMock
|
||||
.Setup(m => m.PostAsync<BatchDnsRecordsResponse, InternalBatchRequest>(It.IsAny<string>(), It.IsAny<InternalBatchRequest>(), It.IsAny<IQueryParameterFilter>(), It.IsAny<CancellationToken>()))
|
||||
.Setup(m => m.PostAsync<JObject, InternalBatchRequest>(It.IsAny<string>(), It.IsAny<InternalBatchRequest>(), It.IsAny<IQueryParameterFilter>(), It.IsAny<CancellationToken>()))
|
||||
.Callback<string, InternalBatchRequest, IQueryParameterFilter, CancellationToken>((requestPath, request, queryFilter, _) => _callbacks.Add((requestPath, request, queryFilter)))
|
||||
.ReturnsAsync(() => _response);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user