Implement DeleteManyByFeedbackReceiverIdAsync for TokensService.cs and FeedbackReceiversController.cs.
This commit is contained in:
parent
56bbb68dda
commit
ef15623b10
9 changed files with 206 additions and 61 deletions
|
@ -31,5 +31,12 @@ namespace Retroactiune.Core.Interfaces
|
|||
/// <param name="filters">Filters object for filtering results.</param>
|
||||
/// <returns>A list of tokens matching the filters.</returns>
|
||||
public Task<IEnumerable<Token>> ListTokens(TokenListFilters filters);
|
||||
|
||||
/// <summary>
|
||||
/// Deletes tokens, by their associated FeedbackReceiverId.
|
||||
/// </summary>
|
||||
/// <param name="feedbackReceiverIds">A list of FeedbackReceiverIDs.</param>
|
||||
/// <returns>The result of the delete operation.</returns>
|
||||
public Task DeleteManyByFeedbackReceiverIdAsync(IEnumerable<string> feedbackReceiverIds);
|
||||
}
|
||||
}
|
|
@ -8,11 +8,11 @@ using Retroactiune.Core.Interfaces;
|
|||
|
||||
namespace Retroactiune.Core.Services
|
||||
{
|
||||
public class TokenService : ITokensService
|
||||
public class TokensService : ITokensService
|
||||
{
|
||||
private readonly IMongoCollection<Token> _collection;
|
||||
|
||||
public TokenService(IMongoClient client, IDatabaseSettings settings)
|
||||
public TokensService(IMongoClient client, IDatabaseSettings settings)
|
||||
{
|
||||
var database = client.GetDatabase(settings.DatabaseName);
|
||||
_collection = database.GetCollection<Token>(settings.TokensCollectionName);
|
||||
|
@ -106,5 +106,18 @@ namespace Retroactiune.Core.Services
|
|||
var results = await _collection.FindAsync(tokensListFilter);
|
||||
return await results.ToListAsync();
|
||||
}
|
||||
|
||||
public async Task DeleteManyByFeedbackReceiverIdAsync(IEnumerable<string> feedbackReceiverIds)
|
||||
{
|
||||
try
|
||||
{
|
||||
var filter = new FilterDefinitionBuilder<Token>();
|
||||
await _collection.DeleteManyAsync(filter.In(i => i.FeedbackReceiverId, feedbackReceiverIds));
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
throw new GenericServiceException($"Operation failed: {e.Message} {e.StackTrace}");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -124,13 +124,10 @@ namespace Retroactiune.IntegrationTests.Retroactiune.WebAPI.Controllers
|
|||
// Arrange
|
||||
await _mongoDb.DropAsync();
|
||||
var guids = new List<string>();
|
||||
byte index = 0;
|
||||
var feedbackReceivers = items as FeedbackReceiver[] ?? items.ToArray();
|
||||
foreach (var i in feedbackReceivers)
|
||||
{
|
||||
i.Id = new BsonObjectId(new ObjectId(new byte[] {1, 2, index, 4, 5, 6, 7, 8, 9, index, 11, 14}))
|
||||
.ToString();
|
||||
index += 1;
|
||||
i.Id = ObjectId.GenerateNewId().ToString();
|
||||
guids.Add(i.Id);
|
||||
}
|
||||
|
||||
|
@ -151,19 +148,49 @@ namespace Retroactiune.IntegrationTests.Retroactiune.WebAPI.Controllers
|
|||
Assert.Equal(0L, docs);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task Test_Delete_OK_With_Tokens()
|
||||
{
|
||||
// Arrange
|
||||
await _mongoDb.DropAsync();
|
||||
var feedbackReceiver = new FeedbackReceiver
|
||||
{
|
||||
Id = ObjectId.GenerateNewId().ToString(),
|
||||
Description = "blam",
|
||||
CreatedAt = DateTime.UtcNow,
|
||||
Name = "test"
|
||||
};
|
||||
await _mongoDb.FeedbackReceiverCollection.InsertOneAsync(feedbackReceiver);
|
||||
|
||||
|
||||
// Test
|
||||
var httpResponse = await _client.DeleteAsync($"/api/v1/FeedbackReceivers/{feedbackReceiver.Id}",
|
||||
CancellationToken.None);
|
||||
await _client.PostAsync("/api/v1/Tokens/",
|
||||
new StringContent($"{{\"numberOfTokens\": 100, \"feedbackReceiverId\": \"{feedbackReceiver.Id}\"}}",
|
||||
Encoding.UTF8,
|
||||
"application/json"));
|
||||
|
||||
|
||||
// Assert
|
||||
Assert.Equal(HttpStatusCode.NoContent, httpResponse.StatusCode);
|
||||
var feedbackReceivers =
|
||||
await _mongoDb.FeedbackReceiverCollection.CountDocumentsAsync(FilterDefinition<FeedbackReceiver>.Empty);
|
||||
var tokens = await _mongoDb.TokensCollection.CountDocumentsAsync(FilterDefinition<Token>.Empty);
|
||||
Assert.Equal(0L, feedbackReceivers);
|
||||
Assert.Equal(0L, tokens);
|
||||
}
|
||||
|
||||
[Theory, AutoData]
|
||||
public async Task Test_DeleteMany_OK(IEnumerable<FeedbackReceiver> items)
|
||||
{
|
||||
// Arrange
|
||||
await _mongoDb.DropAsync();
|
||||
var guids = new List<string>();
|
||||
byte index = 0;
|
||||
var feedbackReceivers = items as FeedbackReceiver[] ?? items.ToArray();
|
||||
foreach (var i in feedbackReceivers)
|
||||
{
|
||||
i.Id = new BsonObjectId(new ObjectId(new byte[] {1, 2, index, 4, 5, 6, 7, 8, 9, index, 11, 14}))
|
||||
.ToString();
|
||||
index += 1;
|
||||
i.Id = ObjectId.GenerateNewId().ToString();
|
||||
guids.Add(i.Id);
|
||||
}
|
||||
|
||||
|
@ -194,7 +221,7 @@ namespace Retroactiune.IntegrationTests.Retroactiune.WebAPI.Controllers
|
|||
await _mongoDb.DropAsync();
|
||||
var feedbackReceiver = new FeedbackReceiver
|
||||
{
|
||||
Id = new BsonObjectId(new ObjectId(new byte[] {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14})).ToString(),
|
||||
Id = ObjectId.GenerateNewId().ToString(),
|
||||
Name = "N4m3",
|
||||
Description = "something",
|
||||
CreatedAt = DateTime.UnixEpoch
|
||||
|
@ -248,21 +275,21 @@ namespace Retroactiune.IntegrationTests.Retroactiune.WebAPI.Controllers
|
|||
{
|
||||
new FeedbackReceiver
|
||||
{
|
||||
Id = new BsonObjectId(new ObjectId(new byte[] {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14})).ToString(),
|
||||
Id = ObjectId.GenerateNewId().ToString(),
|
||||
Name = "N4m3",
|
||||
Description = "something",
|
||||
CreatedAt = DateTime.UnixEpoch
|
||||
},
|
||||
new FeedbackReceiver
|
||||
{
|
||||
Id = new BsonObjectId(new ObjectId(new byte[] {2, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14})).ToString(),
|
||||
Id = ObjectId.GenerateNewId().ToString(),
|
||||
Name = "N4m3_Two",
|
||||
Description = "something",
|
||||
CreatedAt = DateTime.UnixEpoch
|
||||
},
|
||||
new FeedbackReceiver
|
||||
{
|
||||
Id = new BsonObjectId(new ObjectId(new byte[] {3, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14})).ToString(),
|
||||
Id = ObjectId.GenerateNewId().ToString(),
|
||||
Name = "N4m3_Three",
|
||||
Description = "something",
|
||||
CreatedAt = DateTime.UnixEpoch
|
||||
|
@ -294,21 +321,21 @@ namespace Retroactiune.IntegrationTests.Retroactiune.WebAPI.Controllers
|
|||
{
|
||||
new FeedbackReceiver
|
||||
{
|
||||
Id = new BsonObjectId(new ObjectId(new byte[] {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14})).ToString(),
|
||||
Id = ObjectId.GenerateNewId().ToString(),
|
||||
Name = "N4m3",
|
||||
Description = "something",
|
||||
CreatedAt = DateTime.UnixEpoch
|
||||
},
|
||||
new FeedbackReceiver
|
||||
{
|
||||
Id = new BsonObjectId(new ObjectId(new byte[] {2, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14})).ToString(),
|
||||
Id = ObjectId.GenerateNewId().ToString(),
|
||||
Name = "N4m3_Two",
|
||||
Description = "something",
|
||||
CreatedAt = DateTime.UnixEpoch
|
||||
},
|
||||
new FeedbackReceiver
|
||||
{
|
||||
Id = new BsonObjectId(new ObjectId(new byte[] {3, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14})).ToString(),
|
||||
Id = ObjectId.GenerateNewId().ToString(),
|
||||
Name = "N4m3_Three",
|
||||
Description = "something",
|
||||
CreatedAt = DateTime.UnixEpoch
|
||||
|
@ -344,21 +371,21 @@ namespace Retroactiune.IntegrationTests.Retroactiune.WebAPI.Controllers
|
|||
{
|
||||
new FeedbackReceiver
|
||||
{
|
||||
Id = new BsonObjectId(new ObjectId(new byte[] {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14})).ToString(),
|
||||
Id = ObjectId.GenerateNewId().ToString(),
|
||||
Name = "N4m3",
|
||||
Description = "something",
|
||||
CreatedAt = DateTime.UnixEpoch
|
||||
},
|
||||
new FeedbackReceiver
|
||||
{
|
||||
Id = new BsonObjectId(new ObjectId(new byte[] {2, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14})).ToString(),
|
||||
Id = ObjectId.GenerateNewId().ToString(),
|
||||
Name = "N4m3_Two",
|
||||
Description = "something",
|
||||
CreatedAt = DateTime.UnixEpoch
|
||||
},
|
||||
new FeedbackReceiver
|
||||
{
|
||||
Id = new BsonObjectId(new ObjectId(new byte[] {3, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14})).ToString(),
|
||||
Id = ObjectId.GenerateNewId().ToString(),
|
||||
Name = "N4m3_Three",
|
||||
Description = "something",
|
||||
CreatedAt = DateTime.UnixEpoch
|
||||
|
|
|
@ -116,13 +116,10 @@ namespace Retroactiune.IntegrationTests.Retroactiune.WebAPI.Controllers
|
|||
await _mongoDb.DropAsync();
|
||||
var guids = new List<string>();
|
||||
var tokensArr = tokens as Token[] ?? tokens.ToArray();
|
||||
byte index = 0;
|
||||
foreach (var i in tokensArr)
|
||||
{
|
||||
i.Id = new BsonObjectId(new ObjectId(new byte[] {1, 2, index, 4, 5, 6, 7, 8, 9, index, 11, 14}))
|
||||
.ToString();
|
||||
i.FeedbackReceiverId = i.Id;
|
||||
index += 1;
|
||||
i.Id = ObjectId.GenerateNewId().ToString();
|
||||
i.FeedbackReceiverId = ObjectId.GenerateNewId().ToString();
|
||||
guids.Add(i.Id);
|
||||
}
|
||||
|
||||
|
@ -161,13 +158,10 @@ namespace Retroactiune.IntegrationTests.Retroactiune.WebAPI.Controllers
|
|||
await _mongoDb.DropAsync();
|
||||
var guids = new List<string>();
|
||||
var tokensArr = tokens as Token[] ?? tokens.ToArray();
|
||||
byte index = 0;
|
||||
foreach (var i in tokensArr)
|
||||
{
|
||||
i.Id = new BsonObjectId(new ObjectId(new byte[] {1, 2, index, 4, 5, 6, 7, 8, 9, index, 11, 14}))
|
||||
.ToString();
|
||||
i.FeedbackReceiverId = i.Id;
|
||||
index += 1;
|
||||
i.Id = ObjectId.GenerateNewId().ToString();
|
||||
i.FeedbackReceiverId = ObjectId.GenerateNewId().ToString();
|
||||
guids.Add(i.Id);
|
||||
}
|
||||
|
||||
|
|
|
@ -36,7 +36,7 @@ namespace Retroactiune.Tests.Retroactiune.Core.Services
|
|||
.Returns(mongoCollectionMock.Object);
|
||||
|
||||
// Test & Assert
|
||||
var service = new TokenService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
var service = new TokensService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
await Assert.ThrowsAsync<ArgumentException>(async () => { await service.GenerateTokensAsync(-1, ""); });
|
||||
}
|
||||
|
||||
|
@ -64,7 +64,7 @@ namespace Retroactiune.Tests.Retroactiune.Core.Services
|
|||
|
||||
// Test
|
||||
var expiryTime = DateTime.UtcNow;
|
||||
var service = new TokenService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
var service = new TokensService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
await service.GenerateTokensAsync(3, "Hello", expiryTime);
|
||||
|
||||
// Assert
|
||||
|
@ -105,7 +105,7 @@ namespace Retroactiune.Tests.Retroactiune.Core.Services
|
|||
.Returns(mongoCollectionMock.Object);
|
||||
|
||||
// Test
|
||||
var service = new TokenService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
var service = new TokensService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
await service.DeleteTokens(new[] {"test_id"});
|
||||
|
||||
// Assert
|
||||
|
@ -140,10 +140,11 @@ namespace Retroactiune.Tests.Retroactiune.Core.Services
|
|||
.Returns(mongoCollectionMock.Object);
|
||||
|
||||
mongoCollectionMock.Setup(i => i.FindAsync(It.IsAny<FilterDefinition<Token>>(),
|
||||
It.IsAny<FindOptions<Token, Token>>(), It.IsAny<CancellationToken>())).ReturnsAsync(mongoCursorMock.Object);
|
||||
It.IsAny<FindOptions<Token, Token>>(), It.IsAny<CancellationToken>()))
|
||||
.ReturnsAsync(mongoCursorMock.Object);
|
||||
|
||||
// Test
|
||||
var service = new TokenService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
var service = new TokensService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
var result = await service.ListTokens(new TokenListFilters());
|
||||
|
||||
// Assert
|
||||
|
@ -179,10 +180,11 @@ namespace Retroactiune.Tests.Retroactiune.Core.Services
|
|||
.Returns(mongoCollectionMock.Object);
|
||||
|
||||
mongoCollectionMock.Setup(i => i.FindAsync(It.IsAny<FilterDefinition<Token>>(),
|
||||
It.IsAny<FindOptions<Token, Token>>(), It.IsAny<CancellationToken>())).ReturnsAsync(mongoCursorMock.Object);
|
||||
It.IsAny<FindOptions<Token, Token>>(), It.IsAny<CancellationToken>()))
|
||||
.ReturnsAsync(mongoCursorMock.Object);
|
||||
|
||||
// Test
|
||||
var service = new TokenService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
var service = new TokensService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
var result = await service.ListTokens(new TokenListFilters
|
||||
{
|
||||
Ids = new[] {"a", "b"},
|
||||
|
@ -201,5 +203,79 @@ namespace Retroactiune.Tests.Retroactiune.Core.Services
|
|||
It.IsAny<FindOptions<Token, Token>>(),
|
||||
It.IsAny<CancellationToken>()), Times.Once);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task Test_DeleteManyByFeedbackReceiverIdAsync_Ok()
|
||||
{
|
||||
// Setup
|
||||
var mongoDatabaseMock = new Mock<IMongoDatabase>();
|
||||
var mongoClientMock = new Mock<IMongoClient>();
|
||||
var mongoSettingsMock = new Mock<IDatabaseSettings>();
|
||||
var mongoCollectionMock = new Mock<IMongoCollection<Token>>();
|
||||
|
||||
mongoSettingsMock.SetupGet(i => i.DatabaseName).Returns("MyDB");
|
||||
mongoSettingsMock.SetupGet(i => i.TokensCollectionName).Returns("tokens");
|
||||
|
||||
mongoClientMock
|
||||
.Setup(stub => stub.GetDatabase(It.IsAny<string>(),
|
||||
It.IsAny<MongoDatabaseSettings>()))
|
||||
.Returns(mongoDatabaseMock.Object);
|
||||
|
||||
mongoDatabaseMock
|
||||
.Setup(i => i.GetCollection<Token>(It.IsAny<string>(),
|
||||
It.IsAny<MongoCollectionSettings>()))
|
||||
.Returns(mongoCollectionMock.Object);
|
||||
|
||||
// Test
|
||||
var service = new TokensService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
await service.DeleteManyByFeedbackReceiverIdAsync(new[] {"test_id"});
|
||||
|
||||
// Assert
|
||||
mongoCollectionMock.Verify(
|
||||
i
|
||||
=> i.DeleteManyAsync(
|
||||
It.IsAny<FilterDefinition<Token>>(),
|
||||
It.IsAny<CancellationToken>()), Times.Once);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public async Task Test_DeleteManyByFeedbackReceiverIdAsync_Exception()
|
||||
{
|
||||
// Setup
|
||||
var mongoDatabaseMock = new Mock<IMongoDatabase>();
|
||||
var mongoClientMock = new Mock<IMongoClient>();
|
||||
var mongoSettingsMock = new Mock<IDatabaseSettings>();
|
||||
var mongoCollectionMock = new Mock<IMongoCollection<Token>>();
|
||||
|
||||
mongoSettingsMock.SetupGet(i => i.DatabaseName).Returns("MyDB");
|
||||
mongoSettingsMock.SetupGet(i => i.TokensCollectionName).Returns("tokens");
|
||||
|
||||
mongoClientMock
|
||||
.Setup(stub => stub.GetDatabase(It.IsAny<string>(),
|
||||
It.IsAny<MongoDatabaseSettings>()))
|
||||
.Returns(mongoDatabaseMock.Object);
|
||||
|
||||
mongoDatabaseMock
|
||||
.Setup(i => i.GetCollection<Token>(It.IsAny<string>(),
|
||||
It.IsAny<MongoCollectionSettings>()))
|
||||
.Returns(mongoCollectionMock.Object);
|
||||
|
||||
mongoCollectionMock.Setup(i =>
|
||||
i.DeleteManyAsync(It.IsAny<FilterDefinition<Token>>(), It.IsAny<CancellationToken>()))
|
||||
.ThrowsAsync(new GenericServiceException("op failed"));
|
||||
// Test
|
||||
var service = new TokensService(mongoClientMock.Object, mongoSettingsMock.Object);
|
||||
await Assert.ThrowsAsync<GenericServiceException>(async () =>
|
||||
{
|
||||
await service.DeleteManyByFeedbackReceiverIdAsync(new[] {"test_id"});
|
||||
});
|
||||
|
||||
// Assert
|
||||
mongoCollectionMock.Verify(
|
||||
i
|
||||
=> i.DeleteManyAsync(
|
||||
It.IsAny<FilterDefinition<Token>>(),
|
||||
It.IsAny<CancellationToken>()), Times.Once);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -22,10 +22,12 @@ namespace Retroactiune.Tests.Retroactiune.WebAPI.Controllers
|
|||
// Arrange
|
||||
var mapper = TestUtils.GetMapper();
|
||||
var mockService = new Mock<IFeedbackReceiverService>();
|
||||
var tokensService = new Mock<ITokensService>();
|
||||
var logger = new Mock<ILogger<FeedbackReceiversController>>();
|
||||
|
||||
// Test
|
||||
var controller = new FeedbackReceiversController(mockService.Object, mapper, null, logger.Object);
|
||||
var controller = new FeedbackReceiversController(mockService.Object, tokensService.Object, mapper, null,
|
||||
logger.Object);
|
||||
var result = await controller.Post(new List<FeedbackReceiverInDto>());
|
||||
|
||||
// Assert, null because we don't have the ApiBehaviourOptions set, which would generate the IActionResult for the invalid input.
|
||||
|
@ -39,10 +41,12 @@ namespace Retroactiune.Tests.Retroactiune.WebAPI.Controllers
|
|||
// Arrange
|
||||
var mapper = TestUtils.GetMapper();
|
||||
var mockService = new Mock<IFeedbackReceiverService>();
|
||||
var tokensService = new Mock<ITokensService>();
|
||||
var logger = new Mock<ILogger<FeedbackReceiversController>>();
|
||||
|
||||
// Test
|
||||
var controller = new FeedbackReceiversController(mockService.Object, mapper, null, logger.Object);
|
||||
var controller = new FeedbackReceiversController(mockService.Object, tokensService.Object, mapper, null,
|
||||
logger.Object);
|
||||
var result = await controller.Post(items);
|
||||
|
||||
// Assert
|
||||
|
@ -56,16 +60,21 @@ namespace Retroactiune.Tests.Retroactiune.WebAPI.Controllers
|
|||
// Arrange
|
||||
var mapper = TestUtils.GetMapper();
|
||||
var mockService = new Mock<IFeedbackReceiverService>();
|
||||
var tokensService = new Mock<ITokensService>();
|
||||
var logger = new Mock<ILogger<FeedbackReceiversController>>();
|
||||
|
||||
// Test
|
||||
var controller = new FeedbackReceiversController(mockService.Object, mapper, null, logger.Object);
|
||||
var controller = new FeedbackReceiversController(mockService.Object, tokensService.Object, mapper, null,
|
||||
logger.Object);
|
||||
var result = await controller.Delete("bad_guid_but_unit_test_works_cause_validation_doesnt");
|
||||
|
||||
// Assert
|
||||
Assert.IsType<NoContentResult>(result);
|
||||
mockService.Verify(s => s.DeleteManyAsync(new[] {"bad_guid_but_unit_test_works_cause_validation_doesnt"}),
|
||||
Times.Once);
|
||||
tokensService.Verify(
|
||||
s => s.DeleteManyByFeedbackReceiverIdAsync(new[]
|
||||
{"bad_guid_but_unit_test_works_cause_validation_doesnt"}), Times.Once);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
|
@ -74,10 +83,12 @@ namespace Retroactiune.Tests.Retroactiune.WebAPI.Controllers
|
|||
// Arrange
|
||||
var mapper = TestUtils.GetMapper();
|
||||
var mockService = new Mock<IFeedbackReceiverService>();
|
||||
var tokensService = new Mock<ITokensService>();
|
||||
var logger = new Mock<ILogger<FeedbackReceiversController>>();
|
||||
|
||||
// Test
|
||||
var controller = new FeedbackReceiversController(mockService.Object, mapper, null, logger.Object);
|
||||
var controller = new FeedbackReceiversController(mockService.Object, tokensService.Object, mapper, null,
|
||||
logger.Object);
|
||||
var items = new[] {"bad_guid_but_unit_test_works_cause_validation_doesnt", "2", "3"};
|
||||
var result = await controller.DeleteMany(items);
|
||||
|
||||
|
@ -85,6 +96,7 @@ namespace Retroactiune.Tests.Retroactiune.WebAPI.Controllers
|
|||
Assert.IsType<NoContentResult>(result);
|
||||
mockService.Verify(s => s.DeleteManyAsync(items),
|
||||
Times.Once);
|
||||
tokensService.Verify(s => s.DeleteManyByFeedbackReceiverIdAsync(items), Times.Once);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
|
@ -93,19 +105,21 @@ namespace Retroactiune.Tests.Retroactiune.WebAPI.Controllers
|
|||
// Arrange
|
||||
var mapper = TestUtils.GetMapper();
|
||||
var mockService = new Mock<IFeedbackReceiverService>();
|
||||
var tokensService = new Mock<ITokensService>();
|
||||
var logger = new Mock<ILogger<FeedbackReceiversController>>();
|
||||
mockService.Setup(i => i.DeleteManyAsync(It.IsAny<IEnumerable<string>>()))
|
||||
.ThrowsAsync(new GenericServiceException("op failed"));
|
||||
|
||||
// Test
|
||||
var controller = new FeedbackReceiversController(mockService.Object, mapper, null, logger.Object);
|
||||
var controller = new FeedbackReceiversController(mockService.Object, tokensService.Object, mapper, null,
|
||||
logger.Object);
|
||||
var items = new[] {"bad_guid_but_unit_test_works_cause_validation_doesnt", "2", "3"};
|
||||
var result = await controller.DeleteMany(items);
|
||||
|
||||
// Assert
|
||||
Assert.IsType<BadRequestObjectResult>(result);
|
||||
mockService.Verify(s => s.DeleteManyAsync(items),
|
||||
Times.Once);
|
||||
mockService.Verify(s => s.DeleteManyAsync(items), Times.Once);
|
||||
tokensService.Verify(s => s.DeleteManyByFeedbackReceiverIdAsync(items), Times.Once);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
|
@ -114,12 +128,14 @@ namespace Retroactiune.Tests.Retroactiune.WebAPI.Controllers
|
|||
// Arrange
|
||||
var mapper = TestUtils.GetMapper();
|
||||
var mockService = new Mock<IFeedbackReceiverService>();
|
||||
var tokensService = new Mock<ITokensService>();
|
||||
var logger = new Mock<ILogger<FeedbackReceiversController>>();
|
||||
mockService.Setup(i => i.FindAsync(It.IsAny<IEnumerable<string>>(), null, null))
|
||||
.ReturnsAsync(new[] {new FeedbackReceiver()});
|
||||
|
||||
// Test
|
||||
var controller = new FeedbackReceiversController(mockService.Object, mapper, null, logger.Object);
|
||||
var controller = new FeedbackReceiversController(mockService.Object, tokensService.Object, mapper, null,
|
||||
logger.Object);
|
||||
var result = await controller.Get("bad_guid_but_unit_test_works_cause_validation_doesnt");
|
||||
|
||||
// Assert
|
||||
|
@ -135,10 +151,12 @@ namespace Retroactiune.Tests.Retroactiune.WebAPI.Controllers
|
|||
// Arrange
|
||||
var mapper = TestUtils.GetMapper();
|
||||
var mockService = new Mock<IFeedbackReceiverService>();
|
||||
var tokensService = new Mock<ITokensService>();
|
||||
var logger = new Mock<ILogger<FeedbackReceiversController>>();
|
||||
|
||||
// Test
|
||||
var controller = new FeedbackReceiversController(mockService.Object, mapper, null, logger.Object);
|
||||
var controller = new FeedbackReceiversController(mockService.Object, tokensService.Object, mapper, null,
|
||||
logger.Object);
|
||||
var result = await controller.Get("bad_guid_but_unit_test_works_cause_validation_doesnt");
|
||||
|
||||
// Assert
|
||||
|
@ -154,11 +172,13 @@ namespace Retroactiune.Tests.Retroactiune.WebAPI.Controllers
|
|||
// Arrange
|
||||
var mapper = TestUtils.GetMapper();
|
||||
var mockService = new Mock<IFeedbackReceiverService>();
|
||||
var tokensService = new Mock<ITokensService>();
|
||||
var logger = new Mock<ILogger<FeedbackReceiversController>>();
|
||||
var filterArr = filter as string[] ?? filter.ToArray();
|
||||
|
||||
// Test
|
||||
var controller = new FeedbackReceiversController(mockService.Object, mapper, null, logger.Object);
|
||||
var controller = new FeedbackReceiversController(mockService.Object, tokensService.Object, mapper, null,
|
||||
logger.Object);
|
||||
var result = await controller.List(filterArr, offset, limit);
|
||||
|
||||
Assert.IsType<OkObjectResult>(result);
|
||||
|
|
|
@ -20,14 +20,19 @@ namespace Retroactiune.Controllers
|
|||
public class FeedbackReceiversController : ControllerBase
|
||||
{
|
||||
private readonly IOptions<ApiBehaviorOptions> _apiBehaviorOptions;
|
||||
private readonly IFeedbackReceiverService _service;
|
||||
|
||||
// Note: Probably refactor this to use an Aggregate object, need to learn more about aggregates..
|
||||
private readonly IFeedbackReceiverService _feedbackReceiverService;
|
||||
private readonly ITokensService _tokensService;
|
||||
private readonly IMapper _mapper;
|
||||
private readonly ILogger _logger;
|
||||
|
||||
public FeedbackReceiversController(IFeedbackReceiverService service, IMapper mapper,
|
||||
public FeedbackReceiversController(IFeedbackReceiverService feedbackReceiverService,
|
||||
ITokensService tokensService, IMapper mapper,
|
||||
IOptions<ApiBehaviorOptions> apiBehaviorOptions, ILogger<FeedbackReceiversController> logger)
|
||||
{
|
||||
_service = service;
|
||||
_feedbackReceiverService = feedbackReceiverService;
|
||||
_tokensService = tokensService;
|
||||
_mapper = mapper;
|
||||
_apiBehaviorOptions = apiBehaviorOptions;
|
||||
_logger = logger;
|
||||
|
@ -61,7 +66,7 @@ namespace Retroactiune.Controllers
|
|||
return result;
|
||||
});
|
||||
|
||||
await _service.CreateManyAsync(mappedItems);
|
||||
await _feedbackReceiverService.CreateManyAsync(mappedItems);
|
||||
|
||||
return Ok(new BasicResponse()
|
||||
{
|
||||
|
@ -83,7 +88,8 @@ namespace Retroactiune.Controllers
|
|||
[StringLength(24, ErrorMessage = "invalid guid, must be 24 characters", MinimumLength = 24)]
|
||||
string guid)
|
||||
{
|
||||
await _service.DeleteManyAsync(new[] {guid});
|
||||
await Task.WhenAll(_feedbackReceiverService.DeleteManyAsync(new[] {guid}),
|
||||
_tokensService.DeleteManyByFeedbackReceiverIdAsync(new[] {guid}));
|
||||
return NoContent();
|
||||
}
|
||||
|
||||
|
@ -103,7 +109,7 @@ namespace Retroactiune.Controllers
|
|||
[StringLength(24, ErrorMessage = "invalid guid, must be 24 characters", MinimumLength = 24)]
|
||||
string guid)
|
||||
{
|
||||
var result = await _service.FindAsync(new[] {guid});
|
||||
var result = await _feedbackReceiverService.FindAsync(new[] {guid});
|
||||
var feedbackReceivers = result as FeedbackReceiver[] ?? result.ToArray();
|
||||
if (!feedbackReceivers.Any())
|
||||
{
|
||||
|
@ -134,7 +140,7 @@ namespace Retroactiune.Controllers
|
|||
[RangeAttribute(1, 1000, ErrorMessage = "limit is out of range, allowed ranges [1-1000]"), FromQuery]
|
||||
int limit)
|
||||
{
|
||||
return Ok(await _service.FindAsync(filter, offset, limit));
|
||||
return Ok(await _feedbackReceiverService.FindAsync(filter, offset, limit));
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
|
@ -151,7 +157,9 @@ namespace Retroactiune.Controllers
|
|||
{
|
||||
try
|
||||
{
|
||||
await _service.DeleteManyAsync(ids);
|
||||
var feedbackReceiverIds = ids as string[] ?? ids.ToArray();
|
||||
await Task.WhenAll(_feedbackReceiverService.DeleteManyAsync(feedbackReceiverIds),
|
||||
_tokensService.DeleteManyByFeedbackReceiverIdAsync(feedbackReceiverIds));
|
||||
return NoContent();
|
||||
}
|
||||
catch (GenericServiceException e)
|
||||
|
|
|
@ -39,7 +39,7 @@ namespace Retroactiune
|
|||
|
||||
// Services
|
||||
services.AddSingleton<IFeedbackReceiverService, FeedbackReceiverService>();
|
||||
services.AddSingleton<ITokensService, TokenService>();
|
||||
services.AddSingleton<ITokensService, TokensService>();
|
||||
services.AddSingleton<IMongoClient, MongoClient>(i =>
|
||||
{
|
||||
var settings = i.GetService<IOptions<DatabaseSettings>>();
|
||||
|
|
|
@ -35,7 +35,7 @@ namespace Retroactiune
|
|||
|
||||
// Services
|
||||
services.AddSingleton<IFeedbackReceiverService, FeedbackReceiverService>();
|
||||
services.AddSingleton<ITokensService, TokenService>();
|
||||
services.AddSingleton<ITokensService, TokensService>();
|
||||
services.AddSingleton<IMongoClient, MongoClient>(i =>
|
||||
{
|
||||
var settings = i.GetService<IOptions<DatabaseSettings>>();
|
||||
|
|
Loading…
Reference in a new issue