aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2013-06-05 17:56:46 +0900
committerAaron Patterson <aaron.patterson@gmail.com>2013-06-05 17:56:46 +0900
commit3970432fcb6a04e6f003e8295e9b2ee8e5b22390 (patch)
tree999c449042d8a6ae27068c9f1c472d74620ca35f /activerecord
parent8ae73f11469e12d5f3f119189a4733a3a25ca785 (diff)
downloadrails-3970432fcb6a04e6f003e8295e9b2ee8e5b22390.tar.gz
rails-3970432fcb6a04e6f003e8295e9b2ee8e5b22390.tar.bz2
rails-3970432fcb6a04e6f003e8295e9b2ee8e5b22390.zip
only check pending migrations if there are new files
Diffstat (limited to 'activerecord')
-rw-r--r--activerecord/lib/active_record/migration.rb27
1 files changed, 25 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/migration.rb b/activerecord/lib/active_record/migration.rb
index 20505d8f08..bce4802d0a 100644
--- a/activerecord/lib/active_record/migration.rb
+++ b/activerecord/lib/active_record/migration.rb
@@ -357,10 +357,15 @@ module ActiveRecord
class CheckPending
def initialize(app)
@app = app
+ @last_check = 0
end
def call(env)
- ActiveRecord::Migration.check_pending!
+ mtime = ActiveRecord::Migrator.last_migration.mtime.to_i
+ if @last_check < mtime
+ ActiveRecord::Migration.check_pending!
+ @last_check = mtime
+ end
@app.call(env)
end
end
@@ -698,6 +703,10 @@ module ActiveRecord
File.basename(filename)
end
+ def mtime
+ File.mtime filename
+ end
+
delegate :migrate, :announce, :write, :disable_ddl_transaction, to: :migration
private
@@ -713,6 +722,16 @@ module ActiveRecord
end
+ class NullMigration < MigrationProxy
+ def initialize(name, version, filename, scope)
+ super(nil, 0, nil, nil)
+ end
+
+ def mtime
+ 0
+ end
+ end
+
class Migrator#:nodoc:
class << self
attr_writer :migrations_paths
@@ -783,7 +802,11 @@ module ActiveRecord
end
def last_version
- migrations(migrations_paths).last.try(:version)||0
+ last_migration.version
+ end
+
+ def last_migration # :nodoc:
+ migrations(migrations_paths).last || NullMigration.new
end
def proper_table_name(name)