Вы можете определить набор соглашений в ваших AssemblyInitialize
, используя выражения It.Is(..)
, и использовать их во время настройки теста.
Было бы также легко определить некоторые вспомогательные методы вокруг него.Например, вы можете отразить синтаксис It.IsAny<T>()
с помощью метода ItExt.IsConventional<T>()
.Вот возможная реализация:
public static class ItExt
{
private static readonly Dictionary<Type, object> RegisteredConventions = new Dictionary<Type, object>();
public static void RegisterConvention<T>(Func<T> convention)
{
RegisteredConventions.Add(typeof(T), convention);
}
public static T IsConventional<T>()
{
Func<T> conventionFunc = (Func<T>)RegisteredConventions[typeof(T)];
return conventionFunc();
}
}
И использование:
[TestClass]
public class FooTests
{
[AssemblyInitialize]
public static void AssemblyInitialize(TestContext context)
{
ItExt.RegisterConvention(() => It.Is<int?>(n => n.HasValue));
}
[TestMethod]
public void FooTest()
{
// Arrange
Mock<IFoo> fooMock = new Mock<IFoo>();
fooMock.Setup(f => f.Bar(ItExt.IsConventional<int?>()))
.Verifiable();
// Act
fooMock.Object.Bar(1);
// Assert
fooMock.VerifyAll(); // throws
}
}
Обратите внимание, что определения соглашений должны храниться как Func<T>
, так что выражение доступно для оценки внутри Mock<T>.Setup
Звоните.