1
0
Fork 0
mirror of https://github.com/thoughtbot/capybara-webkit synced 2023-03-27 23:22:28 -04:00
A Capybara driver for headless WebKit to test JavaScript web apps
Find a file
Alex Kwiatkowski d0b4950f4c Fix build on Travis
Use require_relative for capybara_webkit_builder as RVM
on travis doesn't include lib directory in require paths
2014-01-28 18:53:28 -05:00
bin Suppress the webkit_server Dock icon on Mac OS X. 2011-06-14 10:33:53 -04:00
gemfiles Release capybara-webkit 1.1.1 2013-12-24 19:26:05 -05:00
lib Fix killing webkit_server on JRuby 2014-01-28 13:54:18 -05:00
spec Check node index atomically to prevent race condition 2013-12-06 10:43:17 -05:00
src Include stdio.h in IgnoreDebugOutput 2013-12-24 18:42:28 -05:00
templates Split Command into more abstract Command and concrete SocketCommand 2012-07-08 12:04:30 -07:00
test Rewrite qInstallMsgHandler test in C++ 2013-11-10 16:52:01 -05:00
.gitignore Ignore .ruby-version and .ruby-gemset 2013-12-24 18:29:49 -05:00
.rspec Added rspec options 2011-02-24 23:14:52 -05:00
.travis.yml Remove Rubinius from travis.yml 2013-12-24 18:42:58 -05:00
Appraisals Test Capybara Webkit against Capybara v2.1.0 2013-04-09 11:45:57 -04:00
capybara-webkit.gemspec Lock capybara dependency to < 2.2 2013-12-24 18:33:06 -05:00
CONTRIBUTING.md Add Vagrant configuration. 2013-01-16 23:05:58 +01:00
extconf.rb Move code that compiles Webkit into separate file to support Ruby 1.9.2 2011-04-15 17:53:31 -04:00
Gemfile Use secure RubyGems URL 2013-02-28 11:09:43 -05:00
Gemfile.lock Release capybara-webkit 1.1.1 2013-12-24 19:26:05 -05:00
GOALS Updated to reflect more complexity, adding some subjectivity in the process 2012-07-09 10:03:33 +02:00
LICENSE Update LICENSE copyright year 2012-09-14 11:37:04 -07:00
NEWS.md Release capybara-webkit 1.1.1 2013-12-24 19:26:05 -05:00
Rakefile Fix build on Travis 2014-01-28 18:53:28 -05:00
README.md Fix typo in README 2013-12-20 16:23:51 -05:00
vagrant_setup.sh Add Vagrant configuration. 2013-01-16 23:05:58 +01:00
Vagrantfile Add Vagrant configuration. 2013-01-16 23:05:58 +01:00
webkit_server.pro Rewrite qInstallMsgHandler test in C++ 2013-11-10 16:52:01 -05:00

capybara-webkit

Build Status Code Climate

A capybara driver that uses WebKit via QtWebKit.

Qt Dependency and Installation Issues

capybara-webkit depends on a WebKit implementation from Qt, a cross-platform development toolkit. You'll need to download the Qt libraries to build and install the gem. You can find instructions for downloading and installing QT on the capybara-webkit wiki. capybara-webkit requires Qt version 4.8.

Windows Support

Currently 32-bit Windows will compile capybara-webkit. Support for Windows is provided by the open source community and Windows related issues should be posted to Stack Overflow.

Reporting Issues

Without access to your application code we can't easily debug most crashes or generic failures, so we've included a debug version of the driver that prints a log of what happened during each test. Before filing a crash bug, please see Reporting Crashes. You're much more likely to get a fix if you follow those instructions.

If you're having trouble compiling or installing, please check out the [wiki]. If you don't have any luck there, please post to Stack Overflow. Please don't open a Github issue for a system-specific compiler issue.

CI

If you're like us, you'll be using capybara-webkit on CI.

On Linux platforms, capybara-webkit requires an X server to run, although it doesn't create any visible windows. Xvfb works fine for this. You can setup Xvfb yourself and set a DISPLAY variable, or try out the headless gem.

Usage

Add the capybara-webkit gem to your Gemfile:

gem "capybara-webkit"

Set your Capybara Javascript driver to webkit:

Capybara.javascript_driver = :webkit

In cucumber, tag scenarios with @javascript to run them using a headless WebKit browser.

In RSpec, use the :js => true flag. See the capybara documentation for more information about using capybara with RSpec.

Take note of the transactional fixtures section of the capybara README.

If you're using capybara-webkit with Sinatra, don't forget to set

Capybara.app = MySinatraApp.new

Non-Standard Driver Methods

capybara-webkit supports a few methods that are not part of the standard capybara API. You can access these by calling driver on the capybara session. When using the DSL, that will look like page.driver.method_name.

console_messages: returns an array of messages printed using console.log

// In Javascript:
console.log("hello")
# In Ruby:
page.driver.console_messages
=> [{:source=>"http://example.com", :line_number=>1, :message=>"hello"}]

error_messages: returns an array of Javascript errors that occurred

page.driver.error_messages
=> [{:source=>"http://example.com", :line_number=>1, :message=>"SyntaxError: Parse error"}]

alert_messages, confirm_messages, prompt_messages: returns arrays of Javascript dialog messages for each dialog type

// In Javascript:
alert("HI");
confirm("Ok?");
prompt("Number?", "42");
# In Ruby:
page.driver.alert_messages
=> ["Hi"]
page.driver.confirm_messages
=> ["Ok?"]
page.driver.prompt_messages
=> ["Number?"]

resize_window: change the viewport size to the given width and height

page.driver.resize_window(500, 300)
page.driver.evaluate_script("window.innerWidth")
=> 500

cookies: allows read-only access of cookies for the current session

page.driver.cookies["alpha"]
=> "abc"

accept_js_confirms!: accept any Javascript confirm that is triggered by the page's Javascript

// In Javascript:
if (confirm("Ok?"))
  console.log("Hi");
else
  console.log("Bye");
# In Ruby:
page.driver.accept_js_confirms!
visit "/"
page.driver.console_messages.first[:message]
=> "Hi"

dismiss_js_confirms!: dismiss any Javascript confirm that is triggered by the page's Javascript

// In Javascript:
if (confirm("Ok?"))
  console.log("Hi");
else
  console.log("Bye");
# In Ruby:
page.driver.dismiss_js_confirms!
visit "/"
page.driver.console_messages.first[:message]
=> "Bye"

accept_js_prompts!: accept any Javascript prompt that is triggered by the page's Javascript

// In Javascript:
var a = prompt("Number?", "0")
console.log(a);
# In Ruby:
page.driver.accept_js_prompts!
visit "/"
page.driver.console_messages.first[:message]
=> "0"

dismiss_js_prompts!: dismiss any Javascript prompt that is triggered by the page's Javascript

// In Javascript:
var a = prompt("Number?", "0")
if (a != null)
  console.log(a);
else
  console.log("you said no"));
# In Ruby:
page.driver.dismiss_js_prompts!
visit "/"
page.driver.console_messages.first[:message]
=> "you said no"

js_prompt_input=(value): set the text to use if a Javascript prompt is encountered and accepted

// In Javascript:
var a = prompt("Number?", "0")
console.log(a);
# In Ruby:
page.driver.js_prompt_input = "42"
page.driver.accept_js_prompts!
visit "/"
page.driver.console_messages.first[:message]
=> "42"

header: set the given HTTP header for subsequent requests

page.driver.header 'Referer', 'https://www.thoughtbot.com'

Contributing

See the CONTRIBUTING document.

About

The capybara WebKit driver is maintained by Joe Ferris and Matt Horan. It was written by thoughtbot, inc with the help of numerous contributions from the open source community.

Code for rendering the current webpage to a PNG is borrowed from Phantom.js' implementation.

thoughtbot

The names and logos for thoughtbot are trademarks of thoughtbot, inc.

License

capybara-webkit is Copyright (c) 2010-2013 thoughtbot, inc. It is free software, and may be redistributed under the terms specified in the LICENSE file.