Ngrok-rspec gem provides ability to run capybara specs through ngrok.
Note: You must have ngrok v2+ installed available in your PATH
.
Add this line to your application's Gemfile:
group :test do
gem 'ngrok-rspec'
end
And then execute:
$ bundle
Or install it yourself as:
$ gem install ngrok-rspec
Configure rspec
RSpec.configure do |config|
# any port can be used
Capybara.server_port = 3001
Ngrok::Rspec.tunnel = { port: Capybara.server_port }
config.include Ngrok::Rspec
end
Write specs using filter ngrok: true
context "Using ngrok", ngrok: true do
it "should use ngrok tunnel" do
# your test code
end
end
For HTTPS connections write specs using filter ngrok_https: true
context "Using ngrok", ngrok_https: true do
it "should use ngrok tunnel" do
# your test code
end
end
Custom tunnel options available:
# custom tunnel options
Ngrok::Rspec.tunnel = {
port: Capybara.server_port,
subdomain: 'MY_SUBDOMAIN',
authtoken: 'MY_TOKEN',
log: 'ngrok.log',
config: '~/.ngrok'
}
Capybara.always_include_port
is set to false
for specs using ngrok-rspec
- Fork it ( https://github.com/bogdanovich/ngrok-rspec/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request