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