2012-02-17 01:18:01 +04:00
|
|
|
# Redmine - project management software
|
2014-01-30 02:45:39 +04:00
|
|
|
# Copyright (C) 2006-2014 Jean-Philippe Lang
|
2012-02-17 01:18:01 +04:00
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU General Public License
|
|
|
|
# as published by the Free Software Foundation; either version 2
|
|
|
|
# of the License, or (at your option) any later version.
|
2012-04-29 17:25:07 +04:00
|
|
|
#
|
2012-02-17 01:18:01 +04:00
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
2012-04-29 17:25:07 +04:00
|
|
|
#
|
2012-02-17 01:18:01 +04:00
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
|
|
|
|
namespace :redmine do
|
|
|
|
namespace :attachments do
|
2012-04-15 19:56:58 +04:00
|
|
|
desc 'Removes uploaded files left unattached after one day.'
|
2012-02-17 01:18:01 +04:00
|
|
|
task :prune => :environment do
|
|
|
|
Attachment.prune
|
|
|
|
end
|
2012-12-13 16:07:19 +04:00
|
|
|
|
|
|
|
desc 'Moves attachments stored at the root of the file directory (ie. created before Redmine 2.3) to their subdirectories'
|
|
|
|
task :move_to_subdirectories => :environment do
|
|
|
|
Attachment.move_from_root_to_target_directory
|
|
|
|
end
|
2012-02-17 01:18:01 +04:00
|
|
|
end
|
2012-04-15 19:56:58 +04:00
|
|
|
|
|
|
|
namespace :tokens do
|
|
|
|
desc 'Removes expired tokens.'
|
|
|
|
task :prune => :environment do
|
|
|
|
Token.destroy_expired
|
|
|
|
end
|
|
|
|
end
|
2012-04-15 19:57:35 +04:00
|
|
|
|
|
|
|
namespace :watchers do
|
|
|
|
desc 'Removes watchers from what they can no longer view.'
|
|
|
|
task :prune => :environment do
|
|
|
|
Watcher.prune
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
desc 'Fetch changesets from the repositories'
|
|
|
|
task :fetch_changesets => :environment do
|
|
|
|
Repository.fetch_changesets
|
|
|
|
end
|
2012-04-25 21:17:49 +04:00
|
|
|
|
|
|
|
desc 'Migrates and copies plugins assets.'
|
|
|
|
task :plugins do
|
|
|
|
Rake::Task["redmine:plugins:migrate"].invoke
|
|
|
|
Rake::Task["redmine:plugins:assets"].invoke
|
|
|
|
end
|
|
|
|
|
2014-01-12 13:02:31 +04:00
|
|
|
desc <<-DESC
|
|
|
|
FOR EXPERIMENTAL USE ONLY, Moves Redmine data from production database to the development database.
|
|
|
|
This task should only be used when you need to move data from one DBMS to a different one (eg. MySQL to PostgreSQL).
|
|
|
|
WARNING: All data in the development database is deleted.
|
|
|
|
DESC
|
|
|
|
|
|
|
|
task :migrate_dbms => :environment do
|
2014-02-09 14:49:57 +04:00
|
|
|
ActiveRecord::Base.establish_connection :development
|
|
|
|
target_tables = ActiveRecord::Base.connection.tables
|
|
|
|
ActiveRecord::Base.remove_connection
|
|
|
|
|
2014-01-12 13:02:31 +04:00
|
|
|
ActiveRecord::Base.establish_connection :production
|
2014-02-09 14:49:57 +04:00
|
|
|
tables = ActiveRecord::Base.connection.tables.sort - %w(schema_migrations plugin_schema_info)
|
|
|
|
|
|
|
|
if (tables - target_tables).any?
|
|
|
|
abort "The following table(s) are missing from the target database: #{(tables - target_tables).join(', ')}"
|
|
|
|
end
|
2014-01-12 13:02:31 +04:00
|
|
|
|
2014-02-09 14:49:57 +04:00
|
|
|
tables.each do |table_name|
|
2014-01-12 13:02:31 +04:00
|
|
|
Source = Class.new(ActiveRecord::Base)
|
|
|
|
Target = Class.new(ActiveRecord::Base)
|
|
|
|
Target.establish_connection(:development)
|
|
|
|
|
|
|
|
[Source, Target].each do |klass|
|
|
|
|
klass.table_name = table_name
|
|
|
|
klass.reset_column_information
|
|
|
|
klass.inheritance_column = "foo"
|
|
|
|
klass.record_timestamps = false
|
|
|
|
end
|
|
|
|
Target.primary_key = (Target.column_names.include?("id") ? "id" : nil)
|
|
|
|
|
|
|
|
source_count = Source.count
|
|
|
|
puts "Migrating %6d records from #{table_name}..." % source_count
|
|
|
|
|
|
|
|
Target.delete_all
|
|
|
|
offset = 0
|
|
|
|
while (objects = Source.offset(offset).limit(5000).order("1,2").to_a) && objects.any?
|
|
|
|
offset += objects.size
|
|
|
|
Target.transaction do
|
|
|
|
objects.each do |object|
|
|
|
|
new_object = Target.new(object.attributes)
|
|
|
|
new_object.id = object.id if Target.primary_key
|
|
|
|
new_object.save(:validate => false)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
Target.connection.reset_pk_sequence!(table_name) if Target.primary_key
|
|
|
|
target_count = Target.count
|
|
|
|
abort "Some records were not migrated" unless source_count == target_count
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-04-25 21:17:49 +04:00
|
|
|
namespace :plugins do
|
|
|
|
desc 'Migrates installed plugins.'
|
|
|
|
task :migrate => :environment do
|
2012-05-07 01:03:30 +04:00
|
|
|
name = ENV['NAME']
|
2012-05-01 13:02:34 +04:00
|
|
|
version = nil
|
2012-05-07 01:03:30 +04:00
|
|
|
version_string = ENV['VERSION']
|
2012-05-01 13:02:34 +04:00
|
|
|
if version_string
|
|
|
|
if version_string =~ /^\d+$/
|
|
|
|
version = version_string.to_i
|
|
|
|
if name.nil?
|
|
|
|
abort "The VERSION argument requires a plugin NAME."
|
|
|
|
end
|
|
|
|
else
|
2012-05-07 01:03:30 +04:00
|
|
|
abort "Invalid VERSION #{version_string} given."
|
2012-05-01 13:02:34 +04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
begin
|
|
|
|
Redmine::Plugin.migrate(name, version)
|
|
|
|
rescue Redmine::PluginNotFound
|
|
|
|
abort "Plugin #{name} was not found."
|
2012-04-25 21:17:49 +04:00
|
|
|
end
|
2012-07-29 22:01:13 +04:00
|
|
|
|
|
|
|
Rake::Task["db:schema:dump"].invoke
|
2012-04-25 21:17:49 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
desc 'Copies plugins assets into the public directory.'
|
|
|
|
task :assets => :environment do
|
2012-05-07 01:03:30 +04:00
|
|
|
name = ENV['NAME']
|
2012-05-01 14:25:22 +04:00
|
|
|
|
|
|
|
begin
|
|
|
|
Redmine::Plugin.mirror_assets(name)
|
|
|
|
rescue Redmine::PluginNotFound
|
|
|
|
abort "Plugin #{name} was not found."
|
|
|
|
end
|
2012-04-25 21:17:49 +04:00
|
|
|
end
|
2012-05-28 14:02:24 +04:00
|
|
|
|
|
|
|
desc 'Runs the plugins tests.'
|
|
|
|
task :test do
|
|
|
|
Rake::Task["redmine:plugins:test:units"].invoke
|
|
|
|
Rake::Task["redmine:plugins:test:functionals"].invoke
|
|
|
|
Rake::Task["redmine:plugins:test:integration"].invoke
|
|
|
|
end
|
|
|
|
|
|
|
|
namespace :test do
|
|
|
|
desc 'Runs the plugins unit tests.'
|
|
|
|
Rake::TestTask.new :units => "db:test:prepare" do |t|
|
|
|
|
t.libs << "test"
|
|
|
|
t.verbose = true
|
2012-11-01 13:40:40 +04:00
|
|
|
t.pattern = "plugins/#{ENV['NAME'] || '*'}/test/unit/**/*_test.rb"
|
2012-05-28 14:02:24 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
desc 'Runs the plugins functional tests.'
|
|
|
|
Rake::TestTask.new :functionals => "db:test:prepare" do |t|
|
|
|
|
t.libs << "test"
|
|
|
|
t.verbose = true
|
2012-11-01 13:40:40 +04:00
|
|
|
t.pattern = "plugins/#{ENV['NAME'] || '*'}/test/functional/**/*_test.rb"
|
2012-05-28 14:02:24 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
desc 'Runs the plugins integration tests.'
|
|
|
|
Rake::TestTask.new :integration => "db:test:prepare" do |t|
|
|
|
|
t.libs << "test"
|
|
|
|
t.verbose = true
|
2012-11-01 13:40:40 +04:00
|
|
|
t.pattern = "plugins/#{ENV['NAME'] || '*'}/test/integration/**/*_test.rb"
|
2012-05-28 14:02:24 +04:00
|
|
|
end
|
|
|
|
end
|
2012-04-25 21:17:49 +04:00
|
|
|
end
|
2012-02-17 01:18:01 +04:00
|
|
|
end
|
2012-05-02 20:30:16 +04:00
|
|
|
|
|
|
|
# Load plugins' rake tasks
|
|
|
|
Dir[File.join(Rails.root, "plugins/*/lib/tasks/**/*.rake")].sort.each { |ext| load ext }
|