summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Keiser <john@johnkeiser.com>2015-11-16 19:24:16 -0800
committerJohn Keiser <john@johnkeiser.com>2015-11-16 20:36:50 -0800
commita6170d3c360480217b4142ea5344719f9a2d346c (patch)
treecb8721caa7805129acaaf2662c466b7942933534
parent478117978cb965bbb01531c029129bd588af5106 (diff)
downloadchef-jk/travis_external_tests.tar.gz
Raise an error when a command failsjk/travis_external_tests
-rw-r--r--.travis.yml12
-rw-r--r--tasks/external_tests.rb22
2 files changed, 20 insertions, 14 deletions
diff --git a/.travis.yml b/.travis.yml
index 55b8aa7481..421f3fd764 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -53,10 +53,11 @@ matrix:
cache:
env: "GEMFILE_MOD=\"gem 'chef-sugar'\""
script: bundle exec rake chef_sugar_spec
- - rvm: 2.2
- cache:
- env: "GEMFILE_MOD=\"gem 'chef-rewind'\""
- script: bundle exec rake chef_rewind_spec
+ # Requires vagrant
+ # - rvm: 2.2
+ # cache:
+ # env: "GEMFILE_MOD=\"gem 'chef-rewind'\""
+ # script: bundle exec rake chef_rewind_spec
- rvm: 2.2
cache:
env: "GEMFILE_MOD=\"gem 'foodcritic', github: 'acrmp/foodcritic', branch: 'v5.0.0'\""
@@ -69,9 +70,6 @@ matrix:
cache:
env: "GEMFILE_MOD=\"gem 'poise', github: 'poise/poise'\""
script: bundle exec rake poise_spec
- # Not working yet: halite
- # - rvm: 2.2
- # script: bundle exec rake poise_spec
### START TEST KITCHEN ONLY ###
- rvm: 2.2
gemfile: kitchen-tests/Gemfile
diff --git a/tasks/external_tests.rb b/tasks/external_tests.rb
index 9304244424..91fa249824 100644
--- a/tasks/external_tests.rb
+++ b/tasks/external_tests.rb
@@ -1,33 +1,41 @@
require 'tempfile'
+require 'bundler'
+
+CURRENT_GEM_NAME = 'chef'
+CURRENT_GEM_PATH = File.expand_path('../..', __FILE__)
def bundle_exec_with_chef(test_gem, commands)
gem_path = Bundler.environment.specs[test_gem].first.full_gem_path
- gemfile_path = File.join(gem_path, 'Gemfile.chef-external-test')
+ gemfile_path = File.join(gem_path, "Gemfile.#{CURRENT_GEM_NAME}-external-test")
gemfile = File.open(gemfile_path, "w")
begin
IO.read(File.join(gem_path, 'Gemfile')).each_line do |line|
if line =~ /^\s*gemspec/
next
- elsif line =~ /^\s*gem 'chef'|\s*gem "chef"/
+ elsif line =~ /^\s*gem '#{CURRENT_GEM_NAME}'|\s*gem "#{CURRENT_GEM_NAME}"/
next
elsif line =~ /^\s*dev_gem\s*['"](.+)['"]\s*$/
line = "gem '#{$1}', github: 'poise/#{$1}'"
- elsif line =~ /\s*gem\s*['"]#{test_gem}['"]/ # foodcritic
+ elsif line =~ /\s*gem\s*['"]#{test_gem}['"]/ # foodcritic end
next
end
gemfile.puts(line)
end
- gemfile.puts("gem 'chef', path: #{File.expand_path('../..', __FILE__).inspect}")
+ gemfile.puts("gem #{CURRENT_GEM_NAME.inspect}, path: #{CURRENT_GEM_PATH.inspect}")
gemfile.puts("gemspec path: #{gem_path.inspect}")
gemfile.close
Dir.chdir(gem_path) do
- system({ 'BUNDLE_GEMFILE' => gemfile.path, 'RUBYOPT' => nil }, "bundle install")
+ unless system({ 'RUBYOPT' => nil, 'GEMFILE_MOD' => nil }, "bundle install --gemfile #{gemfile_path}")
+ raise "Error running bundle install --gemfile #{gemfile_path} in #{gem_path}: #{$?.exitstatus}\nGemfile:\n#{IO.read(gemfile_path)}"
+ end
Array(commands).each do |command|
- system({ 'BUNDLE_GEMFILE' => gemfile.path, 'RUBYOPT' => nil }, "bundle exec #{command}")
+ unless system({ 'BUNDLE_GEMFILE' => gemfile_path, 'RUBYOPT' => nil, 'GEMFILE_MOD' => nil }, "bundle exec #{command}")
+ raise "Error running bundle exec #{command} in #{gem_path} with BUNDLE_GEMFILE=#{gemfile_path}: #{$?.exitstatus}\nGemfile:\n#{IO.read(gemfile_path)}"
+ end
end
end
ensure
- File.delete(gemfile_path)
+ File.delete(gemfile_path) if File.exist?(gemfile_path)
end
end