所以,这是我一直遇到的一个非常有趣的问题。
我目前正在构建一个backbone.js - Rails 应用程序。通常只是为了学习目的而构建它。我(就像任何优秀的 Rails 开发人员一样)在 TDD/BDD 方面做得最好,但我遇到了水豚的问题。
我有一个仅测试 root_path 工作的集成规范(主干历史开始,显示初始信息等......)。
require 'spec_helper'
describe "RentalProperties", js: true do
describe "GET /" do
it "should show a list of properties" do
visit root_path
eventually{page.should have_content("Something")}
end
end
end
我正在使用 jasmine、sinon 和 capybara/rspec/webkit 运行测试。我大致遵循thoughtbot的“Rspec on Rails”书(顺便说一句很棒的书)和本教程:http ://tinnedfruit.com/2011/03/03/testing-backbone-apps-with-jasmine- sinon.html。
运行上述规范时,我遇到了这个错误:
undefined|0|ReferenceError: Strict mode forbids implicit creation of global property 'csrf_token'
我花了很长时间来解决这个问题,因为这个错误真的没有谷歌可以解决的问题。
最终我偶然发现在 JS 中使用“使用严格模式”。本质上,这将使用一些新的 EMCA5 脚本约定。它将捕获更多的编码漏洞,并阻止您访问全局变量。所有美好的事物。
所以我检查了一下,在我的 sinon.js 文件中,我看到:
"use strict";
在文件的第 36 行。瞧,我注释掉了这条线,我的测试工作得很好。
这是我的问题:为什么要使用严格的 csrf?我假设这与我的 rails 布局中的 csrf_meta_tags 有关。如果可能的话,我想把这条线放回 sinon js,因为我认为它是“正确的做法”
有没有人有这方面的更多信息?我提前感谢任何细节!