using System; using System.Linq.Expressions; using System.Threading; using AutoFixture; using CoreUnitTests.Infrastructure; using CoreUnitTests.Infrastructure.Model; using FluentAssertions; using MongoDB.Driver; using MongoDbGenericRepository.DataAccess.Read; using Moq; using Xunit; namespace CoreUnitTests.ReadOnlyMongoRepositoryTests; public class CountTests : TestReadOnlyMongoRepositoryContext { private readonly Expression> expression = document => document.SomeContent == "SomeContent"; [Fact] public void WithExpression_Counts() { // Arrange var count = Fixture.Create(); SetupReader(count); // Act var result = Sut.Count(expression); // Assert result.Should().Be(count); Reader.Verify( x => x.Count(expression, null, CancellationToken.None), Times.Once); } [Fact] public void WithExpressionAndCancellationToken_Counts() { // Arrange var count = Fixture.Create(); var token = new CancellationToken(true); SetupReader(count); // Act var result = Sut.Count(expression, token); // Assert result.Should().Be(count); Reader.Verify( x => x.Count(expression, null, token), Times.Once); } [Fact] public void WithExpressionAndPartitionKey_Counts() { // Arrange var count = Fixture.Create(); var partitionKey = Fixture.Create(); SetupReader(count); // Act var result = Sut.Count(expression, partitionKey); // Assert result.Should().Be(count); Reader.Verify( x => x.Count(expression, partitionKey, CancellationToken.None), Times.Once); } [Fact] public void WithExpressionAndPartitionKeyAndCancellationToken_Counts() { // Arrange var count = Fixture.Create(); var partitionKey = Fixture.Create(); var token = new CancellationToken(true); SetupReader(count); // Act var result = Sut.Count(expression, partitionKey, token); // Assert result.Should().Be(count); Reader.Verify( x => x.Count(expression, partitionKey, token), Times.Once); } private void SetupReader(long count) { Reader = new Mock(); Reader .Setup( x => x.Count( It.IsAny>>(), It.IsAny(), It.IsAny())) .Returns(count); } #region Keyed private readonly Expression, bool>> keyedExpression = document => document.SomeContent == "SomeContent"; private readonly FilterDefinition> keyedFilter = Builders>.Filter.Eq( document => document.SomeContent, "SomeContent"); [Fact] public void Keyed_WithExpression_Counts() { // Arrange var count = Fixture.Create(); SetupKeyedReader(count); // Act var result = Sut.Count, int>(keyedExpression); // Assert result.Should().Be(count); Reader.Verify( x => x.Count, int>(keyedExpression, null, CancellationToken.None), Times.Once); } [Fact] public void Keyed_WithExpressionAndCancellationToken_Counts() { // Arrange var count = Fixture.Create(); var token = new CancellationToken(true); SetupKeyedReader(count); // Act var result = Sut.Count, int>(keyedExpression, token); // Assert result.Should().Be(count); Reader.Verify( x => x.Count, int>(keyedExpression, null, token), Times.Once); } [Fact] public void Keyed_WithExpressionAndPartitionKey_Counts() { // Arrange var count = Fixture.Create(); var partitionKey = Fixture.Create(); SetupKeyedReader(count); // Act var result = Sut.Count, int>(keyedExpression, partitionKey); // Assert result.Should().Be(count); Reader.Verify( x => x.Count, int>(keyedExpression, partitionKey, CancellationToken.None), Times.Once); } [Fact] public void Keyed_WithExpressionAndPartitionKeyAndCancellationToken_Counts() { // Arrange var count = Fixture.Create(); var partitionKey = Fixture.Create(); var token = new CancellationToken(true); SetupKeyedReader(count); // Act var result = Sut.Count, int>(keyedExpression, partitionKey, token); // Assert result.Should().Be(count); Reader.Verify( x => x.Count, int>(keyedExpression, partitionKey, token), Times.Once); } private void SetupKeyedReader(long count) { Reader = new Mock(); Reader .Setup( x => x.Count, int>( It.IsAny, bool>>>(), It.IsAny(), It.IsAny())) .Returns(count); } [Fact] public void Keyed_WithFilter_Counts() { // Arrange var count = Fixture.Create(); SetupKeyedReaderWithFilter(count); // Act var result = Sut.Count, int>(keyedFilter); // Assert Reader.Verify( x => x.Count, int>(keyedFilter, null, null, CancellationToken.None), Times.Once); result.Should().Be(count); } [Fact] public void Keyed_WithFilterAndCountOptions_Counts() { // Arrange var count = Fixture.Create(); var countOptions = new CountOptions(); SetupKeyedReaderWithFilter(count); // Act var result = Sut.Count, int>(keyedFilter, countOptions); // Assert Reader.Verify( x => x.Count, int>(keyedFilter, countOptions, null, CancellationToken.None), Times.Once); result.Should().Be(count); } [Fact] public void Keyed_WithFilterAndCancellationToken_Counts() { // Arrange var count = Fixture.Create(); var token = new CancellationToken(true); SetupKeyedReaderWithFilter(count); // Act var result = Sut.Count, int>(keyedFilter, token); // Assert result.Should().Be(count); Reader.Verify( x => x.Count, int>(keyedFilter, null, null, token), Times.Once); } [Fact] public void Keyed_WithFilterAndCountOptionsAndCancellationToken_Counts() { // Arrange var count = Fixture.Create(); var token = new CancellationToken(true); var countOptions = new CountOptions(); SetupKeyedReaderWithFilter(count); // Act var result = Sut.Count, int>(keyedFilter, countOptions, token); // Assert result.Should().Be(count); Reader.Verify( x => x.Count, int>(keyedFilter, countOptions, null, token), Times.Once); } [Fact] public void Keyed_WithFilterAndPartitionKey_Counts() { // Arrange var count = Fixture.Create(); var partitionKey = Fixture.Create(); SetupKeyedReaderWithFilter(count); // Act var result = Sut.Count, int>(keyedFilter, partitionKey); // Assert result.Should().Be(count); Reader.Verify( x => x.Count, int>(keyedFilter, null, partitionKey, CancellationToken.None), Times.Once); } [Fact] public void Keyed_WithFilterAndCountOptionsAndPartitionKey_Counts() { // Arrange var count = Fixture.Create(); var partitionKey = Fixture.Create(); var countOptions = new CountOptions(); SetupKeyedReaderWithFilter(count); // Act var result = Sut.Count, int>(keyedFilter, countOptions, partitionKey); // Assert result.Should().Be(count); Reader.Verify( x => x.Count, int>(keyedFilter, countOptions, partitionKey, CancellationToken.None), Times.Once); } [Fact] public void Keyed_WithFilterAndPartitionKeyAndCancellationToken_Counts() { // Arrange var count = Fixture.Create(); var partitionKey = Fixture.Create(); var token = new CancellationToken(true); SetupKeyedReaderWithFilter(count); // Act var result = Sut.Count, int>(keyedFilter, partitionKey, token); // Assert result.Should().Be(count); Reader.Verify( x => x.Count, int>(keyedFilter, null, partitionKey, token), Times.Once); } [Fact] public void Keyed_WithFilterAndCountOptionsAndPartitionKeyAndCancellationToken_Counts() { // Arrange var count = Fixture.Create(); var partitionKey = Fixture.Create(); var token = new CancellationToken(true); var countOptions = new CountOptions(); SetupKeyedReaderWithFilter(count); // Act var result = Sut.Count, int>(keyedFilter, countOptions, partitionKey, token); // Assert result.Should().Be(count); Reader.Verify( x => x.Count, int>(keyedFilter, countOptions, partitionKey, token), Times.Once); } private void SetupKeyedReaderWithFilter(long count) { Reader = new Mock(); Reader .Setup( x => x.Count, int>( It.IsAny>>(), It.IsAny(), It.IsAny(), It.IsAny())) .Returns(count); } #endregion }