@@ -0,0 +1,37 | |||||
|
1 | # Redmine runs tests on own continuous integration server. | |||
|
2 | # http://www.redmine.org/projects/redmine/wiki/Continuous_integration | |||
|
3 | # You can also run tests on your environment. | |||
|
4 | language: ruby | |||
|
5 | rvm: | |||
|
6 | - 1.8.7 | |||
|
7 | - 1.9.3 | |||
|
8 | - 2.0 | |||
|
9 | - jruby | |||
|
10 | matrix: | |||
|
11 | allow_failures: | |||
|
12 | # SCM tests fail randomly due to IO.popen(). | |||
|
13 | # https://github.com/jruby/jruby/issues/779 | |||
|
14 | - rvm: jruby | |||
|
15 | env: | |||
|
16 | - "TEST_SUITE=units DATABASE_ADAPTER=postgresql" | |||
|
17 | - "TEST_SUITE=functionals DATABASE_ADAPTER=postgresql" | |||
|
18 | - "TEST_SUITE=integration DATABASE_ADAPTER=postgresql" | |||
|
19 | - "TEST_SUITE=units DATABASE_ADAPTER=mysql" | |||
|
20 | - "TEST_SUITE=functionals DATABASE_ADAPTER=mysql" | |||
|
21 | - "TEST_SUITE=integration DATABASE_ADAPTER=mysql" | |||
|
22 | - "TEST_SUITE=units DATABASE_ADAPTER=sqlite3" | |||
|
23 | - "TEST_SUITE=functionals DATABASE_ADAPTER=sqlite3" | |||
|
24 | - "TEST_SUITE=integration DATABASE_ADAPTER=sqlite3" | |||
|
25 | before_install: | |||
|
26 | - "sudo apt-get update -qq" | |||
|
27 | - "sudo apt-get --no-install-recommends install bzr cvs git mercurial subversion" | |||
|
28 | script: | |||
|
29 | - "SCMS=bazaar,cvs,subversion,git,mercurial,filesystem" | |||
|
30 | - "export SCMS" | |||
|
31 | - "git --version" | |||
|
32 | - "bundle install" | |||
|
33 | - "RUN_ON_NOT_OFFICIAL='' RUBY_VER=1.9 BRANCH=trunk bundle exec rake config/database.yml" | |||
|
34 | - "bundle install" | |||
|
35 | - "JRUBY_OPTS=-J-Xmx1024m bundle exec rake ci" | |||
|
36 | notifications: | |||
|
37 | email: false |
@@ -1,72 +1,92 | |||||
1 | desc "Run the Continous Integration tests for Redmine" |
|
1 | desc "Run the Continuous Integration tests for Redmine" | |
2 | task :ci do |
|
2 | task :ci do | |
3 | # RAILS_ENV and ENV[] can diverge so force them both to test |
|
3 | # RAILS_ENV and ENV[] can diverge so force them both to test | |
4 | ENV['RAILS_ENV'] = 'test' |
|
4 | ENV['RAILS_ENV'] = 'test' | |
5 | RAILS_ENV = 'test' |
|
5 | RAILS_ENV = 'test' | |
6 | Rake::Task["ci:setup"].invoke |
|
6 | Rake::Task["ci:setup"].invoke | |
7 | Rake::Task["ci:build"].invoke |
|
7 | Rake::Task["ci:build"].invoke | |
8 | Rake::Task["ci:teardown"].invoke |
|
8 | Rake::Task["ci:teardown"].invoke | |
9 | end |
|
9 | end | |
10 |
|
10 | |||
11 | namespace :ci do |
|
11 | namespace :ci do | |
12 | desc "Setup Redmine for a new build" |
|
12 | desc "Setup Redmine for a new build" | |
13 | task :setup do |
|
13 | task :setup do | |
14 | Rake::Task["tmp:clear"].invoke |
|
14 | Rake::Task["tmp:clear"].invoke | |
15 | Rake::Task["log:clear"].invoke |
|
15 | Rake::Task["log:clear"].invoke | |
16 | Rake::Task["db:create:all"].invoke |
|
16 | Rake::Task["db:create:all"].invoke | |
17 | Rake::Task["db:migrate"].invoke |
|
17 | Rake::Task["db:migrate"].invoke | |
18 | Rake::Task["db:schema:dump"].invoke |
|
18 | Rake::Task["db:schema:dump"].invoke | |
|
19 | if scms = ENV['SCMS'] | |||
|
20 | scms.split(',').each do |scm| | |||
|
21 | Rake::Task["test:scm:setup:#{scm}"].invoke | |||
|
22 | end | |||
|
23 | else | |||
19 | Rake::Task["test:scm:setup:all"].invoke |
|
24 | Rake::Task["test:scm:setup:all"].invoke | |
|
25 | end | |||
20 | Rake::Task["test:scm:update"].invoke |
|
26 | Rake::Task["test:scm:update"].invoke | |
21 | end |
|
27 | end | |
22 |
|
28 | |||
23 | desc "Build Redmine" |
|
29 | desc "Build Redmine" | |
24 | task :build do |
|
30 | task :build do | |
|
31 | if test_suite = ENV['TEST_SUITE'] | |||
|
32 | Rake::Task["test:#{test_suite}"].invoke | |||
|
33 | else | |||
25 | Rake::Task["test"].invoke |
|
34 | Rake::Task["test"].invoke | |
|
35 | end | |||
26 | # Rake::Task["test:ui"].invoke if RUBY_VERSION >= '1.9.3' |
|
36 | # Rake::Task["test:ui"].invoke if RUBY_VERSION >= '1.9.3' | |
27 | end |
|
37 | end | |
28 |
|
38 | |||
29 | desc "Finish the build" |
|
39 | desc "Finish the build" | |
30 | task :teardown do |
|
40 | task :teardown do | |
31 | end |
|
41 | end | |
32 | end |
|
42 | end | |
33 |
|
43 | |||
34 | desc "Creates database.yml for the CI server" |
|
44 | desc "Creates database.yml for the CI server" | |
35 | file 'config/database.yml' do |
|
45 | file 'config/database.yml' do | |
36 | require 'yaml' |
|
46 | require 'yaml' | |
37 | database = ENV['DATABASE_ADAPTER'] |
|
47 | database = ENV['DATABASE_ADAPTER'] | |
38 | ruby = ENV['RUBY_VER'].gsub('.', '').gsub('-', '') |
|
48 | ruby = ENV['RUBY_VER'].gsub('.', '').gsub('-', '') | |
39 | branch = ENV['BRANCH'].gsub('.', '').gsub('-', '') |
|
49 | branch = ENV['BRANCH'].gsub('.', '').gsub('-', '') | |
40 | dev_db_name = "ci_#{branch}_#{ruby}_dev" |
|
50 | dev_db_name = "ci_#{branch}_#{ruby}_dev" | |
41 | test_db_name = "ci_#{branch}_#{ruby}_test" |
|
51 | test_db_name = "ci_#{branch}_#{ruby}_test" | |
42 |
|
52 | |||
43 | case database |
|
53 | case database | |
44 | when 'mysql' |
|
54 | when 'mysql' | |
45 | dev_conf = {'adapter' => (RUBY_VERSION >= '1.9' ? 'mysql2' : 'mysql'), |
|
55 | dev_conf = {'adapter' => (RUBY_VERSION >= '1.9' ? 'mysql2' : 'mysql'), | |
46 | 'database' => dev_db_name, 'host' => 'localhost', |
|
56 | 'database' => dev_db_name, 'host' => 'localhost', | |
47 | 'username' => 'jenkins', 'password' => 'jenkins', |
|
|||
48 | 'encoding' => 'utf8'} |
|
57 | 'encoding' => 'utf8'} | |
|
58 | if ENV['RUN_ON_NOT_OFFICIAL'] | |||
|
59 | dev_conf['username'] = 'root' | |||
|
60 | else | |||
|
61 | dev_conf['username'] = 'jenkins' | |||
|
62 | dev_conf['password'] = 'jenkins' | |||
|
63 | end | |||
49 | test_conf = dev_conf.merge('database' => test_db_name) |
|
64 | test_conf = dev_conf.merge('database' => test_db_name) | |
50 | when 'postgresql' |
|
65 | when 'postgresql' | |
51 | dev_conf = {'adapter' => 'postgresql', 'database' => dev_db_name, |
|
66 | dev_conf = {'adapter' => 'postgresql', 'database' => dev_db_name, | |
52 |
'host' => 'localhost' |
|
67 | 'host' => 'localhost'} | |
53 | 'username' => 'jenkins', 'password' => 'jenkins'} |
|
68 | if ENV['RUN_ON_NOT_OFFICIAL'] | |
|
69 | dev_conf['username'] = 'postgres' | |||
|
70 | else | |||
|
71 | dev_conf['username'] = 'jenkins' | |||
|
72 | dev_conf['password'] = 'jenkins' | |||
|
73 | end | |||
54 | test_conf = dev_conf.merge('database' => test_db_name) |
|
74 | test_conf = dev_conf.merge('database' => test_db_name) | |
55 | when /sqlite3/ |
|
75 | when /sqlite3/ | |
56 | dev_conf = {'adapter' => (Object.const_defined?(:JRUBY_VERSION) ? |
|
76 | dev_conf = {'adapter' => (Object.const_defined?(:JRUBY_VERSION) ? | |
57 | 'jdbcsqlite3' : 'sqlite3'), |
|
77 | 'jdbcsqlite3' : 'sqlite3'), | |
58 | 'database' => "db/#{dev_db_name}.sqlite3"} |
|
78 | 'database' => "db/#{dev_db_name}.sqlite3"} | |
59 | test_conf = dev_conf.merge('database' => "db/#{test_db_name}.sqlite3") |
|
79 | test_conf = dev_conf.merge('database' => "db/#{test_db_name}.sqlite3") | |
60 | when 'sqlserver' |
|
80 | when 'sqlserver' | |
61 | dev_conf = {'adapter' => 'sqlserver', 'database' => dev_db_name, |
|
81 | dev_conf = {'adapter' => 'sqlserver', 'database' => dev_db_name, | |
62 | 'host' => 'mssqlserver', 'port' => 1433, |
|
82 | 'host' => 'mssqlserver', 'port' => 1433, | |
63 | 'username' => 'jenkins', 'password' => 'jenkins'} |
|
83 | 'username' => 'jenkins', 'password' => 'jenkins'} | |
64 | test_conf = dev_conf.merge('database' => test_db_name) |
|
84 | test_conf = dev_conf.merge('database' => test_db_name) | |
65 | else |
|
85 | else | |
66 | abort "Unknown database" |
|
86 | abort "Unknown database" | |
67 | end |
|
87 | end | |
68 |
|
88 | |||
69 | File.open('config/database.yml', 'w') do |f| |
|
89 | File.open('config/database.yml', 'w') do |f| | |
70 | f.write YAML.dump({'development' => dev_conf, 'test' => test_conf}) |
|
90 | f.write YAML.dump({'development' => dev_conf, 'test' => test_conf}) | |
71 | end |
|
91 | end | |
72 | end |
|
92 | end |
General Comments 0
You need to be logged in to leave comments.
Login now