假设我有一些我想在不同的上下文或“功能”下测试的场景.
例如,我有一些场景涉及用户访问某些页面并期望某些ajax结果.
但是,在不同的条件或“功能”下,我需要执行不同的“后台”任务,这些任务会改变应用程序的状态.
在这种情况下,我需要一遍又一遍地运行相同的场景,以确保一切都适用于应用程序状态的不同更改.
有没有办法在某处定义场景,然后重用它们?
解决方法
您可以使用
shared examples创建在多个功能中使用的可重用方案.
从relishapp页面获取的基本示例如下.如您所见,在多个功能中使用相同的方案来测试不同的类 – 即运行了6个示例.
- require 'rspec/autorun'
- require "set"
- shared_examples "a collection" do
- let(:collection) { described_class.new([7,2,4]) }
- context "initialized with 3 items" do
- it "says it has three items" do
- collection.size.should eq(3)
- end
- end
- describe "#include?" do
- context "with an an item that is in the collection" do
- it "returns true" do
- collection.include?(7).should be_true
- end
- end
- context "with an an item that is not in the collection" do
- it "returns false" do
- collection.include?(9).should be_false
- end
- end
- end
- end
- describe Array do
- it_behaves_like "a collection"
- end
- describe Set do
- it_behaves_like "a collection"
- end
relishapp页面上有几个示例,包括使用参数运行共享示例(下面复制).我猜(因为我不知道你的确切测试)你应该能够在执行一组例子之前使用参数来设置不同的条件.
- require 'rspec/autorun'
- shared_examples "a measurable object" do |measurement,measurement_methods|
- measurement_methods.each do |measurement_method|
- it "should return #{measurement} from ##{measurement_method}" do
- subject.send(measurement_method).should == measurement
- end
- end
- end
- describe Array,"with 3 items" do
- subject { [1,3] }
- it_should_behave_like "a measurable object",3,[:size,:length]
- end
- describe String,"of 6 characters" do
- subject { "FooBar" }
- it_should_behave_like "a measurable object",6,:length]
- end