annotate .svn/pristine/bc/bc8bccaed2502b05fe9e07abbe378d2850bf83c3.svn-base @ 1628:9c5f8e24dadc live tip

Quieten this cron script
author Chris Cannam
date Tue, 25 Aug 2020 11:38:49 +0100
parents 038ba2d95de8
children
rev   line source
Chris@1296 1 desc "Run the Continous Integration tests for Redmine"
Chris@1296 2 task :ci do
Chris@1296 3 # RAILS_ENV and ENV[] can diverge so force them both to test
Chris@1296 4 ENV['RAILS_ENV'] = 'test'
Chris@1296 5 RAILS_ENV = 'test'
Chris@1296 6 Rake::Task["ci:setup"].invoke
Chris@1296 7 Rake::Task["ci:build"].invoke
Chris@1296 8 Rake::Task["ci:teardown"].invoke
Chris@1296 9 end
Chris@1296 10
Chris@1296 11 # Tasks can be hooked into by redefining them in a plugin
Chris@1296 12 namespace :ci do
Chris@1296 13 desc "Setup Redmine for a new build."
Chris@1296 14 task :setup do
Chris@1296 15 Rake::Task["ci:dump_environment"].invoke
Chris@1296 16 Rake::Task["db:create"].invoke
Chris@1296 17 Rake::Task["db:migrate"].invoke
Chris@1296 18 Rake::Task["db:schema:dump"].invoke
Chris@1296 19 Rake::Task["test:scm:update"].invoke
Chris@1296 20 end
Chris@1296 21
Chris@1296 22 desc "Build Redmine"
Chris@1296 23 task :build do
Chris@1296 24 Rake::Task["test"].invoke
Chris@1296 25 end
Chris@1296 26
Chris@1296 27 # Use this to cleanup after building or run post-build analysis.
Chris@1296 28 desc "Finish the build"
Chris@1296 29 task :teardown do
Chris@1296 30 end
Chris@1296 31
Chris@1296 32 desc "Creates and configures the databases for the CI server"
Chris@1296 33 task :database do
Chris@1296 34 path = 'config/database.yml'
Chris@1296 35 unless File.exists?(path)
Chris@1296 36 database = ENV['DATABASE_ADAPTER']
Chris@1296 37 ruby = ENV['RUBY_VER'].gsub('.', '').gsub('-', '')
Chris@1296 38 branch = ENV['BRANCH'].gsub('.', '').gsub('-', '')
Chris@1296 39 dev_db_name = "ci_#{branch}_#{ruby}_dev"
Chris@1296 40 test_db_name = "ci_#{branch}_#{ruby}_test"
Chris@1296 41
Chris@1296 42 case database
Chris@1296 43 when 'mysql'
Chris@1296 44 raise "Error creating databases" unless
Chris@1296 45 system(%|mysql -u jenkins --password=jenkins -e 'create database #{dev_db_name} character set utf8;'|) &&
Chris@1296 46 system(%|mysql -u jenkins --password=jenkins -e 'create database #{test_db_name} character set utf8;'|)
Chris@1296 47 dev_conf = { 'adapter' => (RUBY_VERSION >= '1.9' ? 'mysql2' : 'mysql'), 'database' => dev_db_name, 'host' => 'localhost', 'username' => 'jenkins', 'password' => 'jenkins', 'encoding' => 'utf8' }
Chris@1296 48 test_conf = { 'adapter' => (RUBY_VERSION >= '1.9' ? 'mysql2' : 'mysql'), 'database' => test_db_name, 'host' => 'localhost', 'username' => 'jenkins', 'password' => 'jenkins', 'encoding' => 'utf8' }
Chris@1296 49 when 'postgresql'
Chris@1296 50 raise "Error creating databases" unless
Chris@1296 51 system(%|psql -U jenkins -d postgres -c "create database #{dev_db_name} owner jenkins encoding 'UTF8';"|) &&
Chris@1296 52 system(%|psql -U jenkins -d postgres -c "create database #{test_db_name} owner jenkins encoding 'UTF8';"|)
Chris@1296 53 dev_conf = { 'adapter' => 'postgresql', 'database' => dev_db_name, 'host' => 'localhost', 'username' => 'jenkins', 'password' => 'jenkins' }
Chris@1296 54 test_conf = { 'adapter' => 'postgresql', 'database' => test_db_name, 'host' => 'localhost', 'username' => 'jenkins', 'password' => 'jenkins' }
Chris@1296 55 when 'sqlite3'
Chris@1296 56 dev_conf = { 'adapter' => 'sqlite3', 'database' => "db/#{dev_db_name}.sqlite3" }
Chris@1296 57 test_conf = { 'adapter' => 'sqlite3', 'database' => "db/#{test_db_name}.sqlite3" }
Chris@1296 58 else
Chris@1296 59 raise "Unknown database"
Chris@1296 60 end
Chris@1296 61
Chris@1296 62 File.open(path, 'w') do |f|
Chris@1296 63 f.write YAML.dump({'development' => dev_conf, 'test' => test_conf})
Chris@1296 64 end
Chris@1296 65 end
Chris@1296 66 end
Chris@1296 67
Chris@1296 68 desc "Dump the environment information to a BUILD_ENVIRONMENT ENV variable for debugging"
Chris@1296 69 task :dump_environment do
Chris@1296 70
Chris@1296 71 ENV['BUILD_ENVIRONMENT'] = ['ruby -v', 'gem -v', 'gem list'].collect do |command|
Chris@1296 72 result = `#{command}`
Chris@1296 73 "$ #{command}\n#{result}"
Chris@1296 74 end.join("\n")
Chris@1296 75
Chris@1296 76 end
Chris@1296 77 end
Chris@1296 78