2008-08-24 10:25:05 -04:00
|
|
|
#!/usr/bin/env ruby
|
|
|
|
require 'fileutils'
|
|
|
|
include FileUtils
|
|
|
|
|
2009-11-10 18:18:21 -05:00
|
|
|
def root_dir
|
|
|
|
@root_dir ||= File.expand_path('../..', __FILE__)
|
|
|
|
end
|
|
|
|
|
|
|
|
def rake(*tasks)
|
2010-02-01 20:35:15 -05:00
|
|
|
tasks.each do |task|
|
|
|
|
cmd = "bundle exec rake #{task}"
|
|
|
|
puts "Running command: #{cmd}"
|
|
|
|
return false unless system(cmd)
|
|
|
|
end
|
2009-11-10 20:13:43 -05:00
|
|
|
true
|
2009-11-10 18:18:21 -05:00
|
|
|
end
|
2008-08-24 10:25:05 -04:00
|
|
|
|
2009-11-10 18:18:21 -05:00
|
|
|
puts "[CruiseControl] Rails build"
|
2008-08-24 10:25:05 -04:00
|
|
|
build_results = {}
|
|
|
|
|
2010-02-01 18:04:03 -05:00
|
|
|
# Install required version of bundler.
|
2010-02-16 20:15:56 -05:00
|
|
|
bundler_install_cmd = "gem install bundler -v 0.9.6 --no-ri --no-rdoc"
|
2010-02-04 17:57:13 -05:00
|
|
|
puts "Running command: #{bundler_install_cmd}"
|
|
|
|
build_results[:install_bundler] = system bundler_install_cmd
|
2008-08-24 10:25:05 -04:00
|
|
|
|
2009-10-27 04:55:17 -04:00
|
|
|
cd root_dir do
|
|
|
|
puts
|
|
|
|
puts "[CruiseControl] Bundling RubyGems"
|
|
|
|
puts
|
2010-02-11 20:43:46 -05:00
|
|
|
build_results[:bundle] = system 'rm -rf ~/.bundle; env CI=1 bundle install'
|
2009-10-27 04:55:17 -04:00
|
|
|
end
|
|
|
|
|
2008-08-24 10:25:05 -04:00
|
|
|
cd "#{root_dir}/activesupport" do
|
|
|
|
puts
|
|
|
|
puts "[CruiseControl] Building ActiveSupport"
|
|
|
|
puts
|
2009-11-10 20:19:39 -05:00
|
|
|
build_results[:activesupport] = rake 'test'
|
2009-11-10 17:59:59 -05:00
|
|
|
build_results[:activesupport_isolated] = rake 'test:isolated'
|
2008-08-24 10:25:05 -04:00
|
|
|
end
|
|
|
|
|
2009-11-10 19:08:02 -05:00
|
|
|
cd "#{root_dir}/railties" do
|
2008-08-24 10:25:05 -04:00
|
|
|
puts
|
2009-11-10 19:08:02 -05:00
|
|
|
puts "[CruiseControl] Building RailTies"
|
2008-08-24 10:25:05 -04:00
|
|
|
puts
|
2009-11-10 20:19:39 -05:00
|
|
|
build_results[:railties] = rake 'test'
|
2008-08-24 10:25:05 -04:00
|
|
|
end
|
|
|
|
|
2009-11-10 19:08:02 -05:00
|
|
|
cd "#{root_dir}/actionpack" do
|
2008-08-26 06:14:07 -04:00
|
|
|
puts
|
2009-11-10 19:08:02 -05:00
|
|
|
puts "[CruiseControl] Building ActionPack"
|
2008-08-26 06:14:07 -04:00
|
|
|
puts
|
2009-11-10 20:19:39 -05:00
|
|
|
build_results[:actionpack] = rake 'test'
|
2009-11-10 19:08:02 -05:00
|
|
|
build_results[:actionpack_isolated] = rake 'test:isolated'
|
2008-08-26 06:14:07 -04:00
|
|
|
end
|
2008-08-24 10:25:05 -04:00
|
|
|
|
2009-11-10 19:08:02 -05:00
|
|
|
cd "#{root_dir}/actionmailer" do
|
2008-08-24 10:25:05 -04:00
|
|
|
puts
|
2009-11-10 19:08:02 -05:00
|
|
|
puts "[CruiseControl] Building ActionMailer"
|
2008-08-24 10:25:05 -04:00
|
|
|
puts
|
2009-11-10 20:19:39 -05:00
|
|
|
build_results[:actionmailer] = rake 'test'
|
2010-02-05 19:17:06 -05:00
|
|
|
build_results[:actionmailer_isolated] = rake 'test:isolated'
|
2008-08-24 10:25:05 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
cd "#{root_dir}/activemodel" do
|
|
|
|
puts
|
|
|
|
puts "[CruiseControl] Building ActiveModel"
|
|
|
|
puts
|
2009-11-10 20:19:39 -05:00
|
|
|
build_results[:activemodel] = rake 'test'
|
2010-02-05 19:17:06 -05:00
|
|
|
build_results[:activemodel_isolated] = rake 'test:isolated'
|
2008-08-24 10:25:05 -04:00
|
|
|
end
|
|
|
|
|
2009-01-06 22:42:53 -05:00
|
|
|
rm_f "#{root_dir}/activeresource/debug.log"
|
2008-08-24 10:25:05 -04:00
|
|
|
cd "#{root_dir}/activeresource" do
|
|
|
|
puts
|
|
|
|
puts "[CruiseControl] Building ActiveResource"
|
|
|
|
puts
|
2009-11-10 20:19:39 -05:00
|
|
|
build_results[:activeresource] = rake 'test'
|
2010-02-05 19:17:06 -05:00
|
|
|
build_results[:activeresource_isolated] = rake 'test:isolated'
|
2008-08-24 10:25:05 -04:00
|
|
|
end
|
|
|
|
|
2009-11-10 19:08:02 -05:00
|
|
|
rm_f "#{root_dir}/activerecord/debug.log"
|
|
|
|
cd "#{root_dir}/activerecord" do
|
2008-08-24 10:25:05 -04:00
|
|
|
puts
|
2009-11-10 19:08:02 -05:00
|
|
|
puts "[CruiseControl] Building ActiveRecord with MySQL"
|
2008-08-24 10:25:05 -04:00
|
|
|
puts
|
2010-02-05 19:17:06 -05:00
|
|
|
build_results[:activerecord_mysql] = rake 'mysql:rebuild_databases', 'mysql:test'
|
|
|
|
build_results[:activerecord_mysql_isolated] = rake 'mysql:rebuild_databases', 'mysql:isolated_test'
|
2008-08-24 10:25:05 -04:00
|
|
|
end
|
|
|
|
|
2009-11-10 19:08:02 -05:00
|
|
|
cd "#{root_dir}/activerecord" do
|
2008-08-24 10:25:05 -04:00
|
|
|
puts
|
2009-11-10 19:08:02 -05:00
|
|
|
puts "[CruiseControl] Building ActiveRecord with PostgreSQL"
|
2008-08-24 10:25:05 -04:00
|
|
|
puts
|
2010-02-05 19:17:06 -05:00
|
|
|
build_results[:activerecord_postgresql8] = rake 'postgresql:rebuild_databases', 'postgresql:test'
|
|
|
|
build_results[:activerecord_postgresql8_isolated] = rake 'postgresql:rebuild_databases', 'postgresql:isolated_test'
|
2008-08-24 10:25:05 -04:00
|
|
|
end
|
|
|
|
|
2009-11-10 19:08:02 -05:00
|
|
|
cd "#{root_dir}/activerecord" do
|
2008-08-24 10:25:05 -04:00
|
|
|
puts
|
2009-11-10 19:08:02 -05:00
|
|
|
puts "[CruiseControl] Building ActiveRecord with SQLite 3"
|
2008-08-24 10:25:05 -04:00
|
|
|
puts
|
2010-02-05 19:17:06 -05:00
|
|
|
build_results[:activerecord_sqlite3] = rake 'sqlite3:test'
|
|
|
|
build_results[:activerecord_sqlite3_isolated] = rake 'sqlite3:isolated_test'
|
2008-08-24 10:25:05 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
puts
|
|
|
|
puts "[CruiseControl] Build environment:"
|
|
|
|
puts "[CruiseControl] #{`cat /etc/issue`}"
|
|
|
|
puts "[CruiseControl] #{`uname -a`}"
|
|
|
|
puts "[CruiseControl] #{`ruby -v`}"
|
|
|
|
puts "[CruiseControl] #{`mysql --version`}"
|
|
|
|
puts "[CruiseControl] #{`pg_config --version`}"
|
|
|
|
puts "[CruiseControl] SQLite3: #{`sqlite3 -version`}"
|
2009-02-04 12:29:00 -05:00
|
|
|
`gem env`.each_line {|line| print "[CruiseControl] #{line}"}
|
2010-02-05 19:18:26 -05:00
|
|
|
puts "[CruiseControl] Bundled gems:"
|
|
|
|
`bundle show`.each_line {|line| print "[CruiseControl] #{line}"}
|
2008-08-24 10:25:05 -04:00
|
|
|
puts "[CruiseControl] Local gems:"
|
2009-02-04 12:29:00 -05:00
|
|
|
`gem list`.each_line {|line| print "[CruiseControl] #{line}"}
|
2008-08-24 10:25:05 -04:00
|
|
|
|
|
|
|
failures = build_results.select { |key, value| value == false }
|
|
|
|
|
|
|
|
if failures.empty?
|
|
|
|
puts
|
|
|
|
puts "[CruiseControl] Rails build finished sucessfully"
|
|
|
|
exit(0)
|
|
|
|
else
|
|
|
|
puts
|
|
|
|
puts "[CruiseControl] Rails build FAILED"
|
|
|
|
puts "[CruiseControl] Failed components: #{failures.map { |component| component.first }.join(', ')}"
|
|
|
|
exit(-1)
|
|
|
|
end
|
|
|
|
|