bin | ||
lib | ||
skel/features/support | ||
.gitignore | ||
Gemfile | ||
LICENSE | ||
persistent_selenium.gemspec | ||
Rakefile | ||
README.md |
Persistent Selenium
Now you can keep that precious browser window open when doing continuous integration testing. Save seconds, and sanity, with every test re-run!
Also, the browser stays open at its last state so you can inspect it and more easily fix your tests and/or code.
Start an instance:
persistent_selenium [ --port 9854 ] [ --browser firefox ] [ --chrome-extensions <file.crx> ... ]
Tell Capybara to use it:
# features/support/env.rb
require 'persistent_selenium/driver'
Capybara.default_driver = :persistent_selenium
If you're using Cucumber, you can also install that hook:
persistent_selenium install
Should work just the same as if you used the standard Capybara Selenium driver, except for these two differences:
- The browser starts up first thing and sticks around, so you don't pay the startup/shutdown penalty with each test run.
- The last page you were on before your tests passed/failed stays there, so you can inspect it and adjust your tests.
The browser's cache is disabled, and cookies are reset before the next test runs, so you still get the state cleared out before your next set of tests.
.persistent_selenium
Configure everything in your app with a .persistent_selenium
file:
# .persistent_selenium
PersistentSelenium.configure do |c|
c.browser = :chrome
c.chrome_extensions = %w{AngularJS-Batarang.crx}
end
Chrome Extensions
If, for example, you do a lot with AngularJS and want to use Batarang,
download the extension, put it in your project's folder somewhere, and call persistent_selenium
with the path
to the extension:
persistent_selenium --browser chrome --chrome-extensions AngularJS-Batarang.crx
Best practice
Use it with Foreman and Guard. Start up your test suite via Guard, configure your test suite to use persistent_selenium, and run persistent_selenium alongside it:
guard: guard -g wip
ps: persistent_selenium
It's an integral part of my integration testing setup.
Under the hood
It's DRb, which mostly Just Works (tm), and has a little reshuffling of the default Capybara Selenium driver's code.
When DRb doesn't Just Work (tm)
You're most likely using all
and invoking an action on one of the nodes within, I'd wager. If you need to find a node
to perform an action on, it's best to stick with find
, since it's less likely that node will go out of
ObjectSpace that quickly. If you need to examine the document for particular properties, and all
seems like
the best way to do it, instead try parsing the document body with Nokogiri and using its finders.
That way, all your node searching will be done on the client end.