Switch to current working directory during testing

This commit is contained in:
Max Meyer 2014-11-02 16:51:44 +01:00 committed by Dennis Günnewig
parent 7c37d4ba51
commit f4ce1ff99d
2 changed files with 69 additions and 13 deletions

View file

@ -0,0 +1,33 @@
Feature: Honour working directory
Honour the working directory during testing
In order to support helpers which work with the current directories
Scenario: Set working directory for helpers in tests
Given a fixture app "empty-app"
And a file named "source/index.erb" with:
"""
<%= Dir.getwd %>
"""
And the Server is running
When I go to "/index.html"
Then I should see:
"""
aruba
"""
Scenario: Set working directory for config.rb in tests
Given a fixture app "empty-app"
And a file named "config.rb" with:
"""
set :my_working_directory, Dir.getwd
"""
And a file named "source/index.erb" with:
"""
<%= my_working_directory %>
"""
And the Server is running
When I go to "/index.html"
Then I should see:
"""
aruba
"""

View file

@ -34,6 +34,7 @@ end
Given /^the Server is running$/ do
root_dir = File.expand_path(current_dir)
if File.exists?(File.join(root_dir, 'source'))
ENV['MM_SOURCE'] = 'source'
else
@ -48,9 +49,11 @@ Given /^the Server is running$/ do
set :show_exceptions, false
}
@server_inst = Middleman::Application.server.inst do
initialize_commands.each do |p|
instance_exec(&p)
in_current_dir do
@server_inst = Middleman::Application.server.inst do
initialize_commands.each do |p|
instance_exec(&p)
end
end
end
@ -68,41 +71,61 @@ Given /^a template named "([^\"]*)" with:$/ do |name, string|
end
When /^I go to "([^\"]*)"$/ do |url|
@browser.get(URI.escape(url))
in_current_dir do
@browser.get(URI.escape(url))
end
end
Then /^going to "([^\"]*)" should not raise an exception$/ do |url|
expect{ @browser.get(URI.escape(url)) }.to_not raise_exception
in_current_dir do
expect{ @browser.get(URI.escape(url)) }.to_not raise_exception
end
end
Then /^the content type should be "([^\"]*)"$/ do |expected|
expect(@browser.last_response.content_type).to start_with(expected)
in_current_dir do
expect(@browser.last_response.content_type).to start_with(expected)
end
end
Then /^I should see "([^\"]*)"$/ do |expected|
expect(@browser.last_response.body).to include(expected)
in_current_dir do
expect(@browser.last_response.body).to include(expected)
end
end
Then /^I should see '([^\']*)'$/ do |expected|
expect(@browser.last_response.body).to include(expected)
in_current_dir do
expect(@browser.last_response.body).to include(expected)
end
end
Then /^I should see:$/ do |expected|
expect(@browser.last_response.body).to include(expected)
in_current_dir do
expect(@browser.last_response.body).to include(expected)
end
end
Then /^I should not see "([^\"]*)"$/ do |expected|
expect(@browser.last_response.body).to_not include(expected)
in_current_dir do
expect(@browser.last_response.body).to_not include(expected)
end
end
Then /^I should not see:$/ do |expected|
expect(@browser.last_response.body).to_not include(expected.chomp)
in_current_dir do
expect(@browser.last_response.body).to_not include(expected.chomp)
end
end
Then /^the status code should be "([^\"]*)"$/ do |expected|
expect(@browser.last_response.status).to eq expected.to_i
in_current_dir do
expect(@browser.last_response.status).to eq expected.to_i
end
end
Then /^I should see "([^\"]*)" lines$/ do |lines|
expect(@browser.last_response.body.chomp.split($/).length).to eq(lines.to_i)
in_current_dir do
expect(@browser.last_response.body.chomp.split($/).length).to eq(lines.to_i)
end
end