首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >capybara-webkit - rails会话未保留/设置

capybara-webkit - rails会话未保留/设置
EN

Stack Overflow用户
提问于 2011-12-16 07:27:35
回答 1查看 1.3K关注 0票数 4

我已经为我的集成测试安装了capybara-webkit,我遇到了一个非常简单的问题。我的会话没有被存储。用例非常简单

代码语言:javascript
复制
       1. Login
       2. Go to a specific page
       3. Check if it has the approp content

现在,在第2步,我的应用程序将测试用例返回到登录页面,这意味着会话设置不正确。

任何帮助都非常感谢。

如果我使用@culerity而不是@javascript,那么这个测试用例就通过了,所以问题似乎是capybara-webkit的设置。

我对capybara-webkit支持的env.rb如下所示

代码语言:javascript
复制
    Spork.prefork do
     require 'cucumber/rails'
     require 'capybara'
     require 'capybara/dsl'
     require 'capybara/cucumber'
     require 'capybara-webkit'

     Capybara.run_server = false
     Capybara.javascript_driver = :webkit
     Capybara.default_selector = :css


     # Capybara defaults to XPath selectors rather than Webrat's default of CSS3. In
     # order to ease the transition to Capybara we set the default here. If you'd
     # prefer to use XPath just remove this line and adjust any selectors in your
     # steps to use the XPath syntax.
     # Capybara.default_host = "127.0.0.1:3000"

     Capybara.app_host = "http://localhost:3000"
   end

更新1:看起来会话正在设置。我使用下面的代码在我的步骤中转储会话

代码语言:javascript
复制
     puts(Capybara.current_session.driver.browser.get_cookies)

我得到了回复

"_jqt_session=BAh7CEkiD3Nlc3Npb25faWQGOgZFRiIlYmMwYzNjYjY0MGU3NTg0OWFlNTcwODhmM2I2MzE1YmRJIhBfY3NyZl90b2tlbgY7AEZJIjEwRzN6NG1NTzZqamNCNC9FdWZWeXBCMHdoeThueXBnaTJDcTVzbmJqQlBZPQY7AEZJIgpmbGFzaAY7AEZJQzolQWN0aW9uRGlzcGF0Y2g6OkZsYXNoOjpGbGFzaEhhc2h7BjoKYWxlcnRJIh9JbnZhbGlkIGVtYWlsIG9yIHBhc3N3b3JkLgY7AFQGOgpAdXNlZG86CFNldAY6CkBoYXNoewY7B1Q%3D--3fbe1c2a77a433228e7b7f2d8c8f0aec3ad5fb5f;HttpOnly;domain=localhost;path=/“

更新2:在错误的树上吠叫。似乎我在测试用例中创建的用户没有被rails应用程序看到,因为我的数据库清理策略被设置为事务性策略。在https://groups.google.com/forum/#!msg/ruby-capybara/JI6JrirL9gM/R6YiXj4gi_UJ上看到更多信息

EN

回答 1

Stack Overflow用户

发布于 2013-12-02 09:21:35

更清楚的是,Capybara webkit或selenium驱动程序运行在不同的线程中,然后是应用程序,所以如果您使用事务性固定设备或带有策略的database_cleaner :事务处理,并且您的数据没有被提交到db,而另一个线程不会看到它。可能的解决办法是:

  1. 使用database_cleaner和策略:截断。(实心,但速度慢)
  2. 添加代码,强制使用单个事务对所有线程进行活动记录。(更快,但可能有一些问题,例如:没有调用after_commit钩子,因为没有提交)

#Capybara使用相同的连接类ActiveRecord::Base mattr_accessor :shared_connection @@shared_connection = nil def self.connection @@shared_connection x\ retrieve_connection end #强制所有线程共享相同的连接。因为它在线程中启动web服务器,所以它在# Capybara上工作。ActiveRecord::Base.connection = ActiveRecord::Base.shared_connection

我用的是第二选择,但这是有争议的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8531093

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档