- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何设置确定性测试以验证列表中的项目是否已排序?
首先,我执行以下操作:
public void SyncListContainsSortedItems(
[Frozen] SyncItem[] expected,
SyncItemList sut)
{
Assert.Equal(expected.OrderBy(x => x.Key).First(), sut.First());
}
public void SyncListContainsSortedItems(
[Frozen] SyncItem[] seed,
SyncItemList sut)
{
var expected = seed.OrderByDescending(x => x.Key);
Assert.Equal(expected.OrderBy(x => x.Key).First(), sut.First());
}
public class SyncItemList : List<SyncItem>
{
public SyncItemList(SyncItem[] input)
{
foreach (var item in input) { this.Add(item); }
}
}
public void SyncListContainsSortedItems(IFixture fixture, List<SyncItem> seed)
{
var seconditem = seed.OrderBy(x => x.Key).Skip(1).First();
seed.Remove(seconditem);
seed.Insert(0, seconditem);
var seedArray = seed.ToArray();
var ascending = seedArray.OrderBy(x => x.Key).ToArray();
var descending = seedArray.OrderByDescending(x => x.Key).ToArray();
Assert.NotEqual(ascending, seedArray);
Assert.NotEqual(descending, seedArray);
fixture.Inject<SyncItem[]>(seedArray);
var sut = fixture.Create<SyncItemList>();
var expected = ascending;
var actual = sut.ToArray();
Assert.Equal(expected, actual);
}
SortedSet<SyncItem>
继承,而不是从
List<SyncItem>
继承。
最佳答案
有多种方法可以解决此问题。
命令式版本
这是比OP中提供的命令更简单的命令式版本:
[Fact]
public void ImperativeTest()
{
var fixture = new Fixture();
var expected = fixture.CreateMany<SyncItem>(3).OrderBy(si => si.Key);
var unorderedItems = expected.Skip(1).Concat(expected.Take(1)).ToArray();
fixture.Inject(unorderedItems);
var sut = fixture.Create<SyncItemList>();
Assert.Equal(expected, sut);
}
fixture
的变异,因此很难重构为更具声明性的方法。
public class UnorderedSyncItems : ICustomization
{
public void Customize(IFixture fixture)
{
fixture.Customizations.Add(new UnorderedSyncItemsGenerator());
}
private class UnorderedSyncItemsGenerator : ISpecimenBuilder
{
public object Create(object request, ISpecimenContext context)
{
var t = request as Type;
if (t == null ||
t != typeof(SyncItem[]))
return new NoSpecimen(request);
var items = ((IEnumerable)context
.Resolve(new FiniteSequenceRequest(typeof(SyncItem), 3)))
.Cast<SyncItem>();
return items.Skip(1).Concat(items.Take(1)).ToArray();
}
}
}
new FiniteSequenceRequest(typeof(SyncItem), 3))
只是创建有限序列的
SyncItem
实例的弱类型(非通用)方法。这是
CreateMany<SyncItem>(3)
在后台执行的操作。
[Fact]
public void ImperativeTestWithCustomization()
{
var fixture = new Fixture().Customize(new UnorderedSyncItems());
var expected = fixture.Freeze<SyncItem[]>().OrderBy(si => si.Key);
var sut = fixture.Create<SyncItemList>();
Assert.Equal(expected, sut);
}
UnorderedSyncItems
自定义仅更改
SyncItem[]
实例的创建方式;请参见表2-1。每次收到请求时,它仍会创建一个新数组。
Freeze
确保每次都重复使用相同的数组-也在
fixture
创建
sut
实例时也是如此。
[UnorderedConventions]
属性,可以将上述测试重构为基于约定的声明式测试:
public class UnorderedConventionsAttribute : AutoDataAttribute
{
public UnorderedConventionsAttribute()
: base(new Fixture().Customize(new UnorderedSyncItems()))
{
}
}
UnorderedSyncItems
自定义的声明性胶水。现在测试变为:
[Theory, UnorderedConventions]
public void ConventionBasedTest(
[Frozen]SyncItem[] unorderedItems,
SyncItemList sut)
{
var expected = unorderedItems.OrderBy(si => si.Key);
Assert.Equal(expected, sut);
}
[UnorderedSyncItems]
和
[Frozen]
属性的使用。
[UnorderedSyncItems]
属性中,因此它隐含了正在发生的事情。我更喜欢对整个测试套件使用与一组约定相同的“自定义”,因此我不喜欢在此级别引入测试用例的变体。但是,如果您的约定指出
SyncItem[]
实例应始终是无序的,则此约定是好的。
[AutoData]
属性并不是最佳方法。
[Frozen]
属性一样简单地应用一个参数级属性-也许将它们组合在一起,例如
[Unordered][Frozen]
,那将是很好的。但是,这种方法不起作用。
UnorderedSyncItems
,因为否则,可能不能保证卡住的数组无序。
[Unordered][Frozen]
参数级属性的问题在于,在编译时,.NET框架无法保证AutoFixture xUnit.net胶库读取并应用属性时属性的顺序。
public class UnorderedFrozenAttribute : CustomizeAttribute
{
public override ICustomization GetCustomization(ParameterInfo parameter)
{
return new CompositeCustomization(
new UnorderedSyncItems(),
new FreezingCustomization(parameter.ParameterType));
}
}
FreezingCustomization
提供了
[Frozen]
属性的基础实现。)
[Theory, AutoData]
public void DeclarativeTest(
[UnorderedFrozen]SyncItem[] unorderedItems,
SyncItemList sut)
{
var expected = unorderedItems.OrderBy(si => si.Key);
Assert.Equal(expected, sut);
}
[AutoData]
属性而不进行任何自定义,因为现在加扰是由
[UnorderedFrozen]
属性在参数级别应用的。
[AutoData]
派生属性中的一组(其他)测试套件范围的约定,并且仍将
[UnorderedFrozen]
用作选择加入机制。
关于autofixture - 列表中项目的单元测试顺序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17867566/
我刚刚更改了我的 [RegularExpression] 验证,我三分之一的单元测试失败了! 事实证明 AutoFixture 正在根据该正则表达式生成值,这很酷,但它不理解所有正则表达式,所以我想为
我使用 Autofixture 作为 SUT 工厂,但在卡住空实例时遇到困难。 我想做这样的事情: _fixture.Freeze(c => null); 但很快就意识到这是错误的。我已经用这个解决了
我想以不确定的方式自动生成方法的返回值,即每次调用/测试运行时,我都希望方法返回随机值。目前它总是返回方法调用的默认值: public interface IReturn {
给定这些类: public class DrumAndBassBand { public Drums Drum { get; set; } public Bass Bass { get
我正在将我的测试移植到 AutoFixture 2.0 ,而且我遇到了一些我既无法解释也无法解决的奇怪行为。这个简单的测试对我来说失败了: var autoFixtures = new Fixture
我正在研究一个相当嵌套的模型,它有一些循环引用。它还使用 Entity Framework ,因此所有列表都是 ICollection .为了适应这一点,我正在像这样配置 AutoFixture: _
我正在尝试使用 NSubstitute (1.8.2)、AutoFixture (3.33) 和 AutoFixture.AutoNSubstitute (3.33),如下所示: 我有一个 poco,
当我添加一个新的 TracingBehavior到自动夹具 Fixture实例使用 fixture.Behaviors.Add(new TracingBehavior()); 我在我的 R# 单元测试
我目前正在使用 EF Core Code First Approach,并且我有以下域类: public class Employee { // several properties such a
我刚刚开始使用 AutoFixture,我正在了解基础知识(从我所看到的还有更多),但我遇到了一个问题,我不能 100% 确定对于此类事情的最佳实践是什么。 我正在测试一个 Controller ,该
我在我的单元和集成测试中使用 AutoFixture 并遇到了问题。我正在生成数据传输对象,其中一些类在属性上具有 DataAnnotation 属性(其中一些是自定义的)。 AutoFixture
如何设置确定性测试以验证列表中的项目是否已排序? 首先,我执行以下操作: public void SyncListContainsSortedItems( [Frozen] SyncItem[
默认情况下,AutoFixture在“本地未指定时间”中创建DateTime结构。 我一直在尝试找到一种方法来配置它以创建具有UTC类型的DateTime结构,但是到目前为止没有成功。 有没有办法做到
是否可以在卡住后解冻对象类型? 如果我有一个使用 DateTime 的对象 Appointment,有没有办法做这样的事情? var time = fixture.Freeze(); IEnumera
有什么办法可以给 AutoFixture 一个对象的实例,让它通过所有的 setter 并设置随机数据? wiki 示例仅显示如何从 AutoFixture 获取实例,例如 var autoGener
在我使用 AutoFixture 之前的日子里,我可能做了以下安排来设置名为 CustomerService 的服务的单元测试: public void TestName() { //Arrang
我正在尝试编写这个简单的测试: var fixture = new Fixture().Customize(new AutoMoqCustomization()); var postProcessin
我正在尝试使用 SUT Factory “模式”来创建我的 SUT。 给定 SUT 结构: namespace MySut { public class Dep1 { }
我正在使用的域模型有很多循环引用。事实上,可以从图中的任何点到达大多数对象。许多这些循环引用也在集合中。所以一个 Booking将收藏 Students其中有 Courses 的集合其中有 Booki
我遇到了这个错误。 Ploeh.AutoFixture.Kernel.IllegalRequestException : A request for an IntPtr was detected. T
我是一名优秀的程序员,十分优秀!