@@ -1,75 +1,72 | |||
|
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 | database = ENV['DATABASE_ADAPTER'] | |
|
17 | unless Object.const_defined?(:JRUBY_VERSION) && database =~ /sqlite3/ | |
|
18 | 16 |
|
|
19 | end | |
|
20 | 17 | Rake::Task["db:migrate"].invoke |
|
21 | 18 | Rake::Task["db:schema:dump"].invoke |
|
22 | 19 | Rake::Task["test:scm:setup:all"].invoke |
|
23 | 20 | Rake::Task["test:scm:update"].invoke |
|
24 | 21 | end |
|
25 | 22 | |
|
26 | 23 | desc "Build Redmine" |
|
27 | 24 | task :build do |
|
28 | 25 | Rake::Task["test"].invoke |
|
29 | 26 | # Rake::Task["test:ui"].invoke if RUBY_VERSION >= '1.9.3' |
|
30 | 27 | end |
|
31 | 28 | |
|
32 | 29 | desc "Finish the build" |
|
33 | 30 | task :teardown do |
|
34 | 31 | end |
|
35 | 32 | end |
|
36 | 33 | |
|
37 | 34 | desc "Creates database.yml for the CI server" |
|
38 | 35 | file 'config/database.yml' do |
|
39 | 36 | require 'yaml' |
|
40 | 37 | database = ENV['DATABASE_ADAPTER'] |
|
41 | 38 | ruby = ENV['RUBY_VER'].gsub('.', '').gsub('-', '') |
|
42 | 39 | branch = ENV['BRANCH'].gsub('.', '').gsub('-', '') |
|
43 | 40 | dev_db_name = "ci_#{branch}_#{ruby}_dev" |
|
44 | 41 | test_db_name = "ci_#{branch}_#{ruby}_test" |
|
45 | 42 | |
|
46 | 43 | case database |
|
47 | 44 | when 'mysql' |
|
48 | 45 | dev_conf = {'adapter' => (RUBY_VERSION >= '1.9' ? 'mysql2' : 'mysql'), |
|
49 | 46 | 'database' => dev_db_name, 'host' => 'localhost', |
|
50 | 47 | 'username' => 'jenkins', 'password' => 'jenkins', |
|
51 | 48 | 'encoding' => 'utf8'} |
|
52 | 49 | test_conf = dev_conf.merge('database' => test_db_name) |
|
53 | 50 | when 'postgresql' |
|
54 | 51 | dev_conf = {'adapter' => 'postgresql', 'database' => dev_db_name, |
|
55 | 52 | 'host' => 'localhost', |
|
56 | 53 | 'username' => 'jenkins', 'password' => 'jenkins'} |
|
57 | 54 | test_conf = dev_conf.merge('database' => test_db_name) |
|
58 | 55 | when /sqlite3/ |
|
59 | 56 | dev_conf = {'adapter' => (Object.const_defined?(:JRUBY_VERSION) ? |
|
60 | 57 | 'jdbcsqlite3' : 'sqlite3'), |
|
61 | 58 | 'database' => "db/#{dev_db_name}.sqlite3"} |
|
62 | 59 | test_conf = dev_conf.merge('database' => "db/#{test_db_name}.sqlite3") |
|
63 | 60 | when 'sqlserver' |
|
64 | 61 | dev_conf = {'adapter' => 'sqlserver', 'database' => dev_db_name, |
|
65 | 62 | 'host' => 'mssqlserver', 'port' => 1433, |
|
66 | 63 | 'username' => 'jenkins', 'password' => 'jenkins'} |
|
67 | 64 | test_conf = dev_conf.merge('database' => test_db_name) |
|
68 | 65 | else |
|
69 | 66 | abort "Unknown database" |
|
70 | 67 | end |
|
71 | 68 | |
|
72 | 69 | File.open('config/database.yml', 'w') do |f| |
|
73 | 70 | f.write YAML.dump({'development' => dev_conf, 'test' => test_conf}) |
|
74 | 71 | end |
|
75 | 72 | end |
|
1 | NO CONTENT: file was removed |
General Comments 0
You need to be logged in to leave comments.
Login now