tests for readonly repositories

This commit is contained in:
Sean Garrett
2023-07-04 22:38:01 +01:00
parent b09b359867
commit dc7a4dc67b
56 changed files with 10877 additions and 1212 deletions
@@ -12,15 +12,15 @@ using Xunit;
namespace CoreUnitTests.KeyedReadOnlyMongoRepositoryTests;
public class GetOneAsyncTests : TestKeyedReadOnlyMongoRepositoryContext<Guid>
public class GetOneAsyncTests : TestKeyedReadOnlyMongoRepositoryContext<int>
{
private readonly Expression<Func<TestDocument, bool>> filter = document => document.SomeContent == "SomeContent";
private readonly Expression<Func<TestDocumentWithKey<int>, bool>> filter = document => document.SomeContent == "SomeContent";
[Fact]
public async Task WithFilter_GetsOne()
{
// Arrange
var document = Fixture.Create<TestDocument>();
var document = Fixture.Create<TestDocumentWithKey<int>>();
SetupReader(document);
@@ -31,7 +31,7 @@ public class GetOneAsyncTests : TestKeyedReadOnlyMongoRepositoryContext<Guid>
result.Should().NotBeNull();
result.Should().BeEquivalentTo(document);
Reader.Verify(
x => x.GetOneAsync<TestDocument, Guid>(filter, null, CancellationToken.None),
x => x.GetOneAsync<TestDocumentWithKey<int>, int>(filter, null, CancellationToken.None),
Times.Once);
}
@@ -39,7 +39,7 @@ public class GetOneAsyncTests : TestKeyedReadOnlyMongoRepositoryContext<Guid>
public async Task WithFilterAndCancellationToken_GetsOne()
{
// Arrange
var document = Fixture.Create<TestDocument>();
var document = Fixture.Create<TestDocumentWithKey<int>>();
var token = new CancellationToken(true);
SetupReader(document);
@@ -51,7 +51,7 @@ public class GetOneAsyncTests : TestKeyedReadOnlyMongoRepositoryContext<Guid>
result.Should().NotBeNull();
result.Should().BeEquivalentTo(document);
Reader.Verify(
x => x.GetOneAsync<TestDocument, Guid>(filter, null, token),
x => x.GetOneAsync<TestDocumentWithKey<int>, int>(filter, null, token),
Times.Once);
}
@@ -59,7 +59,7 @@ public class GetOneAsyncTests : TestKeyedReadOnlyMongoRepositoryContext<Guid>
public async Task WithFilterAndPartitionKey_GetsOne()
{
// Arrange
var document = Fixture.Create<TestDocument>();
var document = Fixture.Create<TestDocumentWithKey<int>>();
var partitionKey = Fixture.Create<string>();
SetupReader(document);
@@ -71,7 +71,7 @@ public class GetOneAsyncTests : TestKeyedReadOnlyMongoRepositoryContext<Guid>
result.Should().NotBeNull();
result.Should().BeEquivalentTo(document);
Reader.Verify(
x => x.GetOneAsync<TestDocument, Guid>(filter, partitionKey, CancellationToken.None),
x => x.GetOneAsync<TestDocumentWithKey<int>, int>(filter, partitionKey, CancellationToken.None),
Times.Once);
}
@@ -79,7 +79,7 @@ public class GetOneAsyncTests : TestKeyedReadOnlyMongoRepositoryContext<Guid>
public async Task WithFilterAndPartitionKeyAndCancellationToken_GetsOne()
{
// Arrange
var document = Fixture.Create<TestDocument>();
var document = Fixture.Create<TestDocumentWithKey<int>>();
var partitionKey = Fixture.Create<string>();
var token = new CancellationToken(true);
@@ -92,17 +92,17 @@ public class GetOneAsyncTests : TestKeyedReadOnlyMongoRepositoryContext<Guid>
result.Should().NotBeNull();
result.Should().BeEquivalentTo(document);
Reader.Verify(
x => x.GetOneAsync<TestDocument, Guid>(filter, partitionKey, token),
x => x.GetOneAsync<TestDocumentWithKey<int>, int>(filter, partitionKey, token),
Times.Once);
}
private void SetupReader(TestDocument document)
private void SetupReader(TestDocumentWithKey<int> document)
{
Reader = new Mock<IMongoDbReader>();
Reader
.Setup(
x => x.GetOneAsync<TestDocument, Guid>(
It.IsAny<Expression<Func<TestDocument, bool>>>(),
x => x.GetOneAsync<TestDocumentWithKey<int>, int>(
It.IsAny<Expression<Func<TestDocumentWithKey<int>, bool>>>(),
It.IsAny<string>(),
It.IsAny<CancellationToken>()))
.ReturnsAsync(document);