diff options
| author | erdgeist <erdgeist@erdgeist.org> | 2026-06-24 04:13:16 +0200 |
|---|---|---|
| committer | erdgeist <erdgeist@erdgeist.org> | 2026-06-24 04:13:16 +0200 |
| commit | e0a7e0fec760ba12c8067a37e10c96f1f05876e2 (patch) | |
| tree | d0cf745592a46aee4d4913911fd34c7c24515220 /lib | |
| parent | 6424e10be5a89f175a74c71c55660412a169b8b8 (diff) | |
Stage 1 complete: Rails 2.3.5 to Rails 3.2.22.5 upgrade
- Converted plugins to gems (Gemfile)
- Updated config structure (application.rb, boot.rb, environment.rb)
- Converted routes to Rails 3 DSL
- Converted named_scope to scope throughout models
- Converted find(:all, :conditions) to where() chains
- Fixed has_many :order to use ordering scope
- Updated session store and secret token configuration
- Fixed exception_notification middleware configuration
- Patched Ruby 2.4 / Rails 3.2 incompatibilities:
- Integer/Float duration arithmetic (ActiveSupport)
- Arel visit_Integer for PostgreSQL adapter
- create_database String/Integer coercion
- ActionController consider_all_requests_local
- Migrated taggings schema for acts-as-taggable-on
- Replaced dynamic_form gem with custom form_error_messages helper
- Fixed Rails 3 block helper syntax (form_for, form_tag, fields_for)
- Fixed admin layout yield
- Updated test suite for Rails 3 APIs
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/awesome_patch.rb | 16 | ||||
| -rw-r--r-- | lib/tasks/development_init.rake | 8 | ||||
| -rw-r--r-- | lib/tasks/test_db.rake | 19 |
3 files changed, 23 insertions, 20 deletions
diff --git a/lib/awesome_patch.rb b/lib/awesome_patch.rb deleted file mode 100644 index d9f738c..0000000 --- a/lib/awesome_patch.rb +++ /dev/null | |||
| @@ -1,16 +0,0 @@ | |||
| 1 | module CollectiveIdea | ||
| 2 | module Acts #:nodoc: | ||
| 3 | module NestedSet | ||
| 4 | module InstanceMethods | ||
| 5 | alias_method :move_to_original, :move_to | ||
| 6 | |||
| 7 | def move_to target, position | ||
| 8 | move_to_original target, position | ||
| 9 | if self.class == Node | ||
| 10 | self.update_unique_name | ||
| 11 | end | ||
| 12 | end | ||
| 13 | end | ||
| 14 | end | ||
| 15 | end | ||
| 16 | end \ No newline at end of file | ||
diff --git a/lib/tasks/development_init.rake b/lib/tasks/development_init.rake index 2ac9a83..94f323c 100644 --- a/lib/tasks/development_init.rake +++ b/lib/tasks/development_init.rake | |||
| @@ -25,19 +25,19 @@ namespace :cccms do | |||
| 25 | 25 | ||
| 26 | desc "Import the authors" | 26 | desc "Import the authors" |
| 27 | task :import_authors => :environment do |t| | 27 | task :import_authors => :environment do |t| |
| 28 | importer = AuthorsImporter.new("#{RAILS_ROOT}/db/authors.csv") | 28 | importer = AuthorsImporter.new(Rails.root.join('db', 'authors.csv').to_s) |
| 29 | importer.import_authors | 29 | importer.import_authors |
| 30 | end | 30 | end |
| 31 | 31 | ||
| 32 | desc "Update authors on pages" | 32 | desc "Update authors on pages" |
| 33 | task :update_authors_on_pages => :environment do |t| | 33 | task :update_authors_on_pages => :environment do |t| |
| 34 | i = ChaosImporter.new("#{RAILS_ROOT}/db/updates") | 34 | i = ChaosImporter.new(Rails.root.join('db', 'updates').to_s) |
| 35 | i.update_authors_on_pages | 35 | i.update_authors_on_pages |
| 36 | end | 36 | end |
| 37 | 37 | ||
| 38 | desc "Import the old XML Files" | 38 | desc "Import the old XML Files" |
| 39 | task :import_updates => :environment do |t| | 39 | task :import_updates => :environment do |t| |
| 40 | i = ChaosImporter.new("#{RAILS_ROOT}/db/updates") | 40 | i = ChaosImporter.new(Rails.root.join('db', 'updates').to_s) |
| 41 | i.import_updates | 41 | i.import_updates |
| 42 | end | 42 | end |
| 43 | 43 | ||
| @@ -134,4 +134,4 @@ namespace :cccms do | |||
| 134 | orphans.each { |page| page.destroy } | 134 | orphans.each { |page| page.destroy } |
| 135 | end | 135 | end |
| 136 | 136 | ||
| 137 | end \ No newline at end of file | 137 | end |
diff --git a/lib/tasks/test_db.rake b/lib/tasks/test_db.rake new file mode 100644 index 0000000..0a7a17d --- /dev/null +++ b/lib/tasks/test_db.rake | |||
| @@ -0,0 +1,19 @@ | |||
| 1 | namespace :db do | ||
| 2 | namespace :test do | ||
| 3 | task :load_schema do | ||
| 4 | ActiveRecord::Base.establish_connection(:test) | ||
| 5 | ActiveRecord::Schema.verbose = false | ||
| 6 | load "#{Rails.root}/db/schema.rb" | ||
| 7 | end | ||
| 8 | |||
| 9 | task :prepare => :environment do | ||
| 10 | begin | ||
| 11 | ActiveRecord::Base.establish_connection(:test) | ||
| 12 | ActiveRecord::Base.connection | ||
| 13 | rescue | ||
| 14 | system("psql -U postgres postgres -c \"CREATE DATABASE psql_test OWNER psql ENCODING 'UTF8';\"") | ||
| 15 | end | ||
| 16 | Rake::Task['db:test:load_schema'].invoke | ||
| 17 | end | ||
| 18 | end | ||
| 19 | end | ||
