- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
let 的正常行为本质上是绑定(bind)到一个示例 block (即它 block )。这在大多数情况下都很好,但如果您碰巧在一个 let 中创建大型对象并用于多个实例,则可能会出现严重问题例子。在这种情况下,实例变量几乎成为测试套件完整性的必要条件。
时间会这样复合:
在调用的示例数量超过 3 个的情况下,这个时间很快就会成为问题。
大多数人会说使用实例变量是异端邪说,但就 let 的当前状态而言,这似乎是一种过于武断的胡言乱语,没有太多相反的研究。在我读过的任何支持 let 的文章中,唯一的论点是对延迟加载和作用域问题的一些吸引力,这两者在编写良好的测试中都是无关紧要的。
延迟加载在测试中似乎没有意义,因为它仅在您不确定是否需要数据时才有用。如果是这样,您为什么要费心首先为该测试构建数据?
如果您没有在测试中改变您的对象(提示:您永远不应该将其 stub ),那么实例变量可能永远不会成为问题。如果是,则耦合不是变量的错,而是测试本身的错。
TL;DR:是否有一种已知的方法可以将 let 类型语句绑定(bind)到备用 block 区域?理想情况下,我想将它绑定(bind)到 describe 和 context block 以缓解此问题。
例子:
describe 'Person' do
local_bind let(:person) { Person.new(actual_data) }
context 'It has no data' do
local_bind let(:person) { Person.new(blank_data) }
# tests
end
end
其中 local_bind 会将 let 绑定(bind)到当前 block 上下文,而不是它运行的示例。当然这是推测性的语法,但在这里给出了一般的想法。
这将允许我们声明一个对象以在 block 区域内的所有示例中使用,这将大大减少仅示例内存的不良影响。
虽然这些问题不会在基本对象上明显显现(50 次调用 * 0.001 实例化仍然相当快),但它会在更昂贵的对象上变得明显可见(50 次调用 * 0.1 = 5 秒。)
我以前见过那些花了这么长时间的,当他们以某种方式进入规范助手并在糟糕的性能抽象上到处使用时,你可以想象一个包含 3,500 个测试的测试套件如何快速屈服于它的'膝盖。到目前为止观察到的差异是 JSON 问题从 8:15 到 1:57 的时间减少了 75%,当我这样做时让修复我估计减少到 20 秒以下。努力获取这方面的证据。
最佳答案
https://github.com/rspec/rspec-core/issues/1246
我已经与 RSPEC 核心团队讨论了这个确切的问题,他们无意澄清这个不幸的命名约定。相反,他们似乎坚持认为程序员没有更好的知识,必须握住他们的手,然后再接手。一件作品,那很多...
关于ruby-on-rails - RSPEC 让替代范围界定,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21119203/
我想知道 Rspec 中的命令式和声明式步骤是什么。 这是 Rspec 书中的示例代码: Scenario: transfer money (declarative) Given I have $10
我正在尝试使用 Travis 设置 CI。但是我遇到了在 Travis 上失败但在本地没有的测试,甚至提供了相同的种子。 我认为种子运行相同,但现在我不确定,并想弄清楚它是否存在,所以我现在在哪里看。
RSpec 的文档提到了 --bisect option ,当运行时提供最小的复制,例如 rspec ./spec/calculator_10_spec.rb[1:1] ./spec/calculat
我有一些昂贵的测试设置,仅对我的规范中的少数示例是必需的,如果需要,它只需要运行一次。因为它很慢,所以我试图避免将它放在 before(:each) block 中,但 before(:all) 似乎
在我的 Gemfile 中 gem 'rspec-rails', '~> 3.3' 我发现,errors_on 匹配器移动到了另一个 gem:https://github.com/rspec/rspe
如果我运行此命令“rspec ./spec/requests/api/v1/password_reset_request_spec.rb”,此文件中的所有测试都会通过。 但是,当我运行“rspec”时
我花了 4 天时间尝试正确安装 Ruby on Rails,但我遇到了一个大问题。我第一次使用Linux(对我来说更舒服),但遇到问题后,我使用了Windows。令我惊讶的是,我在 Windows 上
我在这样的验证中测试了很多坏字符串: ['0', '3:a', 'xx:11', '-1', '-3:00', 'h', 'h2', 'h2h', 'm', 'm10', 'm10m', '2hm',
我的测试套件中有一部分运行着一堆非常慢的导入器。这些测试不需要经常运行(除非实际上正在处理导入器)所以我使用 Rspec 标签将它们分开:http://relishapp.com/rspec/rspe
Rspec 尝试在运行任何规范文件或整个测试套件结束时运行 Test::Unit 测试。它仍然没关系,因为我没有任何测试单元测试文件,但它尝试传递给 rspec 的命令行选项,因为它们将传递给 Tes
我有一段代码要测试: class User :destroy end 请举例测试关联代码的RSpec代码。 最佳答案 对我来说,这个变体效果很好: describe User do it { s
我正在尝试在 rails Controller 规范中重用一些通用代码。我对管理员用户和普通用户有不同的上下文。但是,对于特定操作,大部分行为是相同的,因此我尝试将这种常见行为提取到辅助函数中: de
我有两个类OneClass和 AnotherClass : class OneClass def initialize(*args) @another_member = AnotherCl
我有一个看起来像这样的模型: class Gist def self.create(options) post_response = Faraday.post do |request|
我是 RSPEC 的新手。我编写了一个名为 result_spec.rb 的 RSPEC 代码,如下所示: describe '#grouped_scores' do subject { result
我对字符串类进行了如下扩展: class String def last_character self[-1] end end 我将 string.rb 文件放在 lib 中,如下所示
我是 RSpec 的新手,我在其中编写了一个测试场景: my_object.should_not be_valid 它工作正常。但是,我想测试模型的特定属性是否无效。这样的 RSpec 行为是现成的吗
我正在尝试测试邮政编码属性的长度以确保其长度为 5 个字符。现在我正在测试以确保它不是空白,然后是 4 个字符太短,6 个字符太长。 有没有办法测试它是否正好是 5 个字符?到目前为止,我在网上或 r
我将rspec与电子邮件规范gem一起使用。我正在尝试做: last_delivery = ActionMailer::Base.deliveries.last last_delivery.body.
我创建了一个新的 rails 应用程序,并按照此处的 rspec-rails 安装说明进行操作 - https://github.com/rspec/rspec-rails然后我在我的 app/lib
我是一名优秀的程序员,十分优秀!