Make middleman compatible with aruba 0.10.x
This commit is contained in:
parent
90d386079d
commit
741caab546
9 changed files with 206 additions and 103 deletions
2
Gemfile
2
Gemfile
|
@ -6,7 +6,7 @@ gem 'yard', '~> 0.8', require: false
|
|||
|
||||
# Test tools
|
||||
gem 'pry', '~> 0.10', group: :development
|
||||
gem 'aruba', '~> 0.7.4'
|
||||
gem 'aruba', '~> 0.10.0'
|
||||
gem 'rspec', '~> 3.0'
|
||||
gem 'cucumber', '~> 2.0'
|
||||
|
||||
|
|
|
@ -6,7 +6,7 @@ Feature: Run the preview server
|
|||
|
||||
Background:
|
||||
Given a fixture app "preview-server-app"
|
||||
And the default aruba timeout is 30 seconds
|
||||
And the default aruba exit timeout is 30 seconds
|
||||
|
||||
Scenario: Start the server with defaults
|
||||
When I run `middleman server` interactively
|
||||
|
|
|
@ -54,7 +54,7 @@ Feature: Local Data API
|
|||
|
||||
Scenario: Invalid YAML
|
||||
Given a fixture app "basic-data-app"
|
||||
And the default aruba timeout is 30 seconds
|
||||
And the default aruba exit timeout is 30 seconds
|
||||
And a file named "data/test.yml" with:
|
||||
"""
|
||||
'ASDSFDa:
|
||||
|
@ -68,7 +68,7 @@ Feature: Local Data API
|
|||
|
||||
Scenario: Invalid JSON
|
||||
Given a fixture app "basic-data-app"
|
||||
And the default aruba timeout is 30 seconds
|
||||
And the default aruba exit timeout is 30 seconds
|
||||
And a file named "data/test.json" with:
|
||||
"""
|
||||
'ASDSFDa:
|
||||
|
|
|
@ -18,27 +18,45 @@ end
|
|||
|
||||
Then /^should raise an exception if the operator is not supported$/ do
|
||||
expect {
|
||||
selector = ::Middleman::Sitemap::Queryable::Selector.new :attribute => :author, :operator => 'zomg'
|
||||
::Middleman::Sitemap::Queryable::Selector.new :attribute => :author, :operator => 'zomg'
|
||||
}.to raise_error(::Middleman::Sitemap::Queryable::OperatorNotSupportedError)
|
||||
end
|
||||
|
||||
Then /^should limit the documents to the number specified$/ do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
@server_inst.sitemap.order_by(:id).limit(2).all.map { |r| r.raw_data[:id] }.sort.should == [1,2].sort
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^should offset the documents by the number specified$/ do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
@server_inst.sitemap.order_by(:id).offset(2).all.map { |r| r.raw_data[:id] }.sort.should == [3,4,5].sort
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^should support offset and limit at the same time$/ do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
@server_inst.sitemap.order_by(:id).offset(1).limit(2).all.map { |r| r.raw_data[:id] }.sort.should == [2,3].sort
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^should not freak out about an offset higher than the document count$/ do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
@server_inst.sitemap.order_by(:id).offset(5).all.should == []
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^should return the right documents$/ do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
documents = @server_inst.sitemap.resources.select { |r| !r.raw_data.empty? }
|
||||
document_1 = documents[0]
|
||||
document_2 = documents[1]
|
||||
|
@ -48,88 +66,147 @@ Then /^should return the right documents$/ do
|
|||
|
||||
found_document = @server_inst.sitemap.where(:title => document_2.raw_data[:title]).first
|
||||
document_2.should == found_document
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^should be chainable$/ do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
documents = @server_inst.sitemap.resources.select { |r| !r.raw_data.empty? }
|
||||
document_1 = documents[0]
|
||||
|
||||
document_proxy = @server_inst.sitemap.where(:title => document_1.raw_data[:title])
|
||||
document_proxy.where(:id => document_1.raw_data[:id])
|
||||
document_1.should == document_proxy.first
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^should not be confused by attributes not present in all documents$/ do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
result = @server_inst.sitemap.where(:seldom_attribute => 'is seldom').all
|
||||
result.map { |r| r.raw_data[:id] }.should == [4]
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^with a gt operator should return the right documents$/ do
|
||||
selector = ::Middleman::Sitemap::Queryable::Selector.new :attribute => :id, :operator => 'gt'
|
||||
cd '.' do
|
||||
with_environment do
|
||||
found_documents = @server_inst.sitemap.where(selector => 2).all
|
||||
found_documents.map { |r| r.raw_data[:id] }.sort.should == [5,3,4].sort
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^with a gte operator should return the right documents$/ do
|
||||
selector = ::Middleman::Sitemap::Queryable::Selector.new :attribute => :id, :operator => 'gte'
|
||||
|
||||
cd '.' do
|
||||
with_environment do
|
||||
found_documents = @server_inst.sitemap.where(selector => 2).all
|
||||
found_documents.map { |r| r.raw_data[:id] }.sort.should == [2,5,3,4].sort
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^with an in operator should return the right documents$/ do
|
||||
selector = ::Middleman::Sitemap::Queryable::Selector.new :attribute => :id, :operator => 'in'
|
||||
cd '.' do
|
||||
with_environment do
|
||||
found_documents = @server_inst.sitemap.where(selector => [2,3]).all
|
||||
found_documents.map { |r| r.raw_data[:id] }.sort.should == [2,3].sort
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^with an lt operator should return the right documents$/ do
|
||||
selector = ::Middleman::Sitemap::Queryable::Selector.new :attribute => :id, :operator => 'lt'
|
||||
cd '.' do
|
||||
with_environment do
|
||||
found_documents = @server_inst.sitemap.where(selector => 2).all
|
||||
found_documents.map { |r| r.raw_data[:id] }.should == [1]
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^with an lte operator should return the right documents$/ do
|
||||
selector = ::Middleman::Sitemap::Queryable::Selector.new :attribute => :id, :operator => 'lte'
|
||||
cd '.' do
|
||||
with_environment do
|
||||
found_documents = @server_inst.sitemap.where(selector => 2).all
|
||||
found_documents.map { |r| r.raw_data[:id] }.sort.should == [1,2].sort
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^with an include operator include should return the right documents$/ do
|
||||
selector = ::Middleman::Sitemap::Queryable::Selector.new :attribute => :tags, :operator => 'include'
|
||||
cd '.' do
|
||||
with_environment do
|
||||
found_documents = @server_inst.sitemap.where(selector => 'ruby').all
|
||||
found_documents.map { |r| r.raw_data[:id] }.sort.should == [1,2].sort
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^with mixed operators should return the right documents$/ do
|
||||
in_selector = ::Middleman::Sitemap::Queryable::Selector.new :attribute => :id, :operator => 'in'
|
||||
gt_selector = ::Middleman::Sitemap::Queryable::Selector.new :attribute => :id, :operator => 'gt'
|
||||
cd '.' do
|
||||
with_environment do
|
||||
documents_proxy = @server_inst.sitemap.where(in_selector => [2,3])
|
||||
found_documents = documents_proxy.where(gt_selector => 2).all
|
||||
found_documents.map { |r| r.raw_data[:id] }.should == [3]
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^using multiple constrains in one where should return the right documents$/ do
|
||||
selector = ::Middleman::Sitemap::Queryable::Selector.new :attribute => :id, :operator => 'lte'
|
||||
cd '.' do
|
||||
with_environment do
|
||||
found_documents = @server_inst.sitemap.where(selector => 2, :status => :published).all
|
||||
found_documents.map { |r| r.raw_data[:id] }.sort.should == [1,2].sort
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^should support ordering by attribute ascending$/ do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
found_documents = @server_inst.sitemap.order_by(:title => :asc).all
|
||||
found_documents.map { |r| r.raw_data[:id] }.should == [2,3,1,5,4]
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^should support ordering by attribute descending$/ do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
found_documents = @server_inst.sitemap.order_by(:title => :desc).all
|
||||
found_documents.map { |r| r.raw_data[:id] }.should == [4,5,1,3,2]
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^should order by attribute ascending by default$/ do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
found_documents = @server_inst.sitemap.order_by(:title).all
|
||||
found_documents.map { |r| r.raw_data[:id] }.should == [2,3,1,5,4]
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^should exclude documents that do not own the attribute$/ do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
found_documents = @server_inst.sitemap.order_by(:status).all
|
||||
found_documents.map { |r| r.raw_data[:id] }.to_set.should == [1,2].to_set
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
require 'aruba/cucumber'
|
||||
require 'aruba/jruby'
|
||||
require 'aruba/config/jruby'
|
||||
require 'middleman-core/step_definitions/middleman_steps'
|
||||
require 'middleman-core/step_definitions/builder_steps'
|
||||
require 'middleman-core/step_definitions/server_steps'
|
||||
|
|
|
@ -5,29 +5,27 @@ Before do
|
|||
end
|
||||
|
||||
Given /^app "([^\"]*)" is using config "([^\"]*)"$/ do |path, config_name|
|
||||
target = File.join(PROJECT_ROOT_PATH, 'fixtures', path)
|
||||
config_path = File.join(current_directory, "config-#{config_name}.rb")
|
||||
config_dest = File.join(current_directory, 'config.rb')
|
||||
FileUtils.cp(config_path, config_dest)
|
||||
copy("config-#{config_name}.rb", 'config.rb')
|
||||
end
|
||||
|
||||
Given /^an empty app$/ do
|
||||
step %Q{a directory named "empty_app"}
|
||||
step %Q{I cd to "empty_app"}
|
||||
ENV['MM_ROOT'] = nil
|
||||
|
||||
delete_environment_variable 'MM_ROOT'
|
||||
end
|
||||
|
||||
Given /^a fixture app "([^\"]*)"$/ do |path|
|
||||
ENV['MM_ROOT'] = nil
|
||||
delete_environment_variable 'MM_ROOT'
|
||||
|
||||
# This step can be reentered from several places but we don't want
|
||||
# to keep re-copying and re-cd-ing into ever-deeper directories
|
||||
next if File.basename(current_directory) == path
|
||||
next if File.basename(expand_path('.')) == path
|
||||
|
||||
step %Q{a directory named "#{path}"}
|
||||
|
||||
target_path = File.join(PROJECT_ROOT_PATH, 'fixtures', path)
|
||||
FileUtils.cp_r(target_path, current_directory)
|
||||
FileUtils.cp_r(target_path, expand_path('.'))
|
||||
|
||||
step %Q{I cd to "#{path}"}
|
||||
end
|
||||
|
@ -58,20 +56,20 @@ Given /^a successfully built app at "([^\"]*)" with flags "([^\"]*)"$/ do |path,
|
|||
end
|
||||
|
||||
Given /^a modification time for a file named "([^\"]*)"$/ do |file|
|
||||
target = File.join(current_directory, file)
|
||||
target = expand_path(file)
|
||||
@modification_times[target] = File.mtime(target)
|
||||
end
|
||||
|
||||
Then /^the file "([^\"]*)" should not have been updated$/ do |file|
|
||||
target = File.join(current_directory, file)
|
||||
target = expand_path(file)
|
||||
File.mtime(target).should == @modification_times[target]
|
||||
end
|
||||
|
||||
# Provide this Aruba overload in case we're matching something with quotes in it
|
||||
Then /^the file "([^"]*)" should contain '([^']*)'$/ do |file, partial_content|
|
||||
check_file_content(file, Regexp.new(Regexp.escape(partial_content)), true)
|
||||
expect(file).to have_file_content Regexp.new(Regexp.escape(partial_content))
|
||||
end
|
||||
|
||||
And /the file "(.*)" should be gzipped/ do |file|
|
||||
expect(File.binread(File.join(current_directory, file), 2)).to eq(['1F8B'].pack('H*'))
|
||||
expect(File.binread(expand_path(file), 2)).to eq(['1F8B'].pack('H*'))
|
||||
end
|
||||
|
|
|
@ -1,11 +1,11 @@
|
|||
When /^I stop (?:middleman|all commands) if the output( of the last command)? contains:$/ do |last_command, expected|
|
||||
begin
|
||||
Timeout.timeout(exit_timeout) do
|
||||
Timeout.timeout(aruba.config.exit_timeout) do
|
||||
loop do
|
||||
fail "You need to start middleman interactively first." unless @interactive
|
||||
fail "You need to start middleman interactively first." if last_command_started.nil?
|
||||
|
||||
if unescape(@interactive.output) =~ Regexp.new(unescape(expected))
|
||||
only_processes.each { |p| p.terminate }
|
||||
if sanitize_text(last_command_started.output) =~ Regexp.new(sanitize_text(expected))
|
||||
terminate_all_commands
|
||||
break
|
||||
end
|
||||
|
||||
|
@ -13,10 +13,10 @@ When /^I stop (?:middleman|all commands) if the output( of the last command)? co
|
|||
end
|
||||
end
|
||||
rescue ChildProcess::TimeoutError, TimeoutError
|
||||
@interactive.terminate
|
||||
terminate_all_commands
|
||||
ensure
|
||||
announcer.stdout @interactive.stdout
|
||||
announcer.stderr @interactive.stderr
|
||||
announcer.announce :stdout, last_command_started.stdout
|
||||
announcer.announce :stderr, last_command_started.stderr
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -68,7 +68,7 @@ Given /I start a mdns server with:/ do |string|
|
|||
)
|
||||
)
|
||||
|
||||
set_env 'PATH', File.expand_path(File.join(current_dir, 'bin')) + ':' + ENV['PATH']
|
||||
set_environment_variable 'PATH', File.expand_path(File.join(current_dir, 'bin')) + ':' + ENV['PATH']
|
||||
write_file db_file, string
|
||||
|
||||
@mdns_server = run("dns_server.rb #{db_file} #{port}", 120)
|
||||
|
@ -80,7 +80,7 @@ end
|
|||
|
||||
# Make sure each and every process is really dead
|
||||
After do
|
||||
only_processes.each { |p| p.terminate }
|
||||
terminate_all_commands
|
||||
end
|
||||
|
||||
Before '@ruby-2.1' do
|
||||
|
|
|
@ -9,9 +9,17 @@ Then /^the file "([^\"]*)" is removed$/ do |path|
|
|||
end
|
||||
|
||||
Then /^the file "([^\"]*)" did change$/ do |path|
|
||||
cd '.' do
|
||||
with_environment do
|
||||
@server_inst.files.did_change(path)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^the file "([^\"]*)" did delete$/ do |path|
|
||||
cd '.' do
|
||||
with_environment do
|
||||
@server_inst.files.did_delete(path)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
@ -31,15 +31,13 @@ Given /^current environment is "([^\"]*)"$/ do |env|
|
|||
end
|
||||
|
||||
Given /^the Server is running$/ do
|
||||
root_dir = File.expand_path(current_directory)
|
||||
|
||||
if File.exists?(File.join(root_dir, 'source'))
|
||||
ENV['MM_SOURCE'] = 'source'
|
||||
if exist? 'source'
|
||||
set_environment_variable 'MM_SOURCE', 'source'
|
||||
else
|
||||
ENV['MM_SOURCE'] = ''
|
||||
set_environment_variable 'MM_SOURCE', ''
|
||||
end
|
||||
|
||||
ENV['MM_ROOT'] = root_dir
|
||||
set_environment_variable 'MM_ROOT', expand_path('.')
|
||||
|
||||
initialize_commands = @initialize_commands || []
|
||||
initialize_commands.unshift lambda {
|
||||
|
@ -47,13 +45,15 @@ Given /^the Server is running$/ do
|
|||
set :show_exceptions, false
|
||||
}
|
||||
|
||||
in_current_directory do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
@server_inst = Middleman::Application.server.inst do
|
||||
initialize_commands.each do |p|
|
||||
instance_exec(&p)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Capybara.app = @server_inst.class.to_rack_app
|
||||
end
|
||||
|
@ -68,61 +68,81 @@ Given /^a template named "([^\"]*)" with:$/ do |name, string|
|
|||
end
|
||||
|
||||
When /^I go to "([^\"]*)"$/ do |url|
|
||||
in_current_directory do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
visit(URI.encode(url).to_s)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^going to "([^\"]*)" should not raise an exception$/ do |url|
|
||||
in_current_directory do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
expect{ visit(URI.encode(url).to_s) }.to_not raise_exception
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^the content type should be "([^\"]*)"$/ do |expected|
|
||||
in_current_directory do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
expect(page.response_headers['Content-Type']).to start_with expected
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^I should see "([^\"]*)"$/ do |expected|
|
||||
in_current_directory do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
expect(page.body).to include expected
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^I should see '([^\']*)'$/ do |expected|
|
||||
in_current_directory do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
expect(page.body).to include expected
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^I should see:$/ do |expected|
|
||||
in_current_directory do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
expect(page.body).to include expected
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^I should not see "([^\"]*)"$/ do |expected|
|
||||
in_current_directory do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
expect(page.body).not_to include expected
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^I should not see:$/ do |expected|
|
||||
in_current_directory do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
expect(page.body).not_to include expected
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^the status code should be "([^\"]*)"$/ do |expected|
|
||||
in_current_directory do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
expect(page.status_code).to eq expected.to_i
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Then /^I should see "([^\"]*)" lines$/ do |lines|
|
||||
in_current_directory do
|
||||
cd '.' do
|
||||
with_environment do
|
||||
expect(page.body.chomp.split($/).length).to eq lines.to_i
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Reference in a new issue