##// END OF EJS Templates
use environment variable for running independent tests (units etc.) in ci.rake...
Toshi MARUYAMA -
r12162:2db5fc1a66a1
parent child
Show More
@@ -1,78 +1,82
1 1 desc "Run the Continous Integration tests for Redmine"
2 2 task :ci do
3 3 # RAILS_ENV and ENV[] can diverge so force them both to test
4 4 ENV['RAILS_ENV'] = 'test'
5 5 RAILS_ENV = 'test'
6 6 Rake::Task["ci:setup"].invoke
7 7 Rake::Task["ci:build"].invoke
8 8 Rake::Task["ci:teardown"].invoke
9 9 end
10 10
11 11 namespace :ci do
12 12 desc "Setup Redmine for a new build"
13 13 task :setup do
14 14 Rake::Task["tmp:clear"].invoke
15 15 Rake::Task["log:clear"].invoke
16 16 Rake::Task["db:create:all"].invoke
17 17 Rake::Task["db:migrate"].invoke
18 18 Rake::Task["db:schema:dump"].invoke
19 19 if scms = ENV['SCMS']
20 20 scms.split(',').each do |scm|
21 21 Rake::Task["test:scm:setup:#{scm}"].invoke
22 22 end
23 23 else
24 24 Rake::Task["test:scm:setup:all"].invoke
25 25 end
26 26 Rake::Task["test:scm:update"].invoke
27 27 end
28 28
29 29 desc "Build Redmine"
30 30 task :build do
31 Rake::Task["test"].invoke
31 if test_suite = ENV['TEST_SUITE']
32 Rake::Task["test:#{test_suite}"].invoke
33 else
34 Rake::Task["test"].invoke
35 end
32 36 # Rake::Task["test:ui"].invoke if RUBY_VERSION >= '1.9.3'
33 37 end
34 38
35 39 desc "Finish the build"
36 40 task :teardown do
37 41 end
38 42 end
39 43
40 44 desc "Creates database.yml for the CI server"
41 45 file 'config/database.yml' do
42 46 require 'yaml'
43 47 database = ENV['DATABASE_ADAPTER']
44 48 ruby = ENV['RUBY_VER'].gsub('.', '').gsub('-', '')
45 49 branch = ENV['BRANCH'].gsub('.', '').gsub('-', '')
46 50 dev_db_name = "ci_#{branch}_#{ruby}_dev"
47 51 test_db_name = "ci_#{branch}_#{ruby}_test"
48 52
49 53 case database
50 54 when 'mysql'
51 55 dev_conf = {'adapter' => (RUBY_VERSION >= '1.9' ? 'mysql2' : 'mysql'),
52 56 'database' => dev_db_name, 'host' => 'localhost',
53 57 'username' => 'jenkins', 'password' => 'jenkins',
54 58 'encoding' => 'utf8'}
55 59 test_conf = dev_conf.merge('database' => test_db_name)
56 60 when 'postgresql'
57 61 dev_conf = {'adapter' => 'postgresql', 'database' => dev_db_name,
58 62 'host' => 'localhost',
59 63 'username' => 'jenkins', 'password' => 'jenkins'}
60 64 test_conf = dev_conf.merge('database' => test_db_name)
61 65 when /sqlite3/
62 66 dev_conf = {'adapter' => (Object.const_defined?(:JRUBY_VERSION) ?
63 67 'jdbcsqlite3' : 'sqlite3'),
64 68 'database' => "db/#{dev_db_name}.sqlite3"}
65 69 test_conf = dev_conf.merge('database' => "db/#{test_db_name}.sqlite3")
66 70 when 'sqlserver'
67 71 dev_conf = {'adapter' => 'sqlserver', 'database' => dev_db_name,
68 72 'host' => 'mssqlserver', 'port' => 1433,
69 73 'username' => 'jenkins', 'password' => 'jenkins'}
70 74 test_conf = dev_conf.merge('database' => test_db_name)
71 75 else
72 76 abort "Unknown database"
73 77 end
74 78
75 79 File.open('config/database.yml', 'w') do |f|
76 80 f.write YAML.dump({'development' => dev_conf, 'test' => test_conf})
77 81 end
78 82 end
General Comments 0
You need to be logged in to leave comments. Login now