Commit f42ff58c authored by charlie ablett's avatar charlie ablett

Merge branch '32596-add-rubocop-to-enforce-datetime-with-timezone' into 'master'

Enforce use of datetime_with_timezone on create_table migrations

Closes #32596

See merge request gitlab-org/gitlab!28690
parents bb893a3c d766f2be
...@@ -6,6 +6,7 @@ ...@@ -6,6 +6,7 @@
# rubocop:disable Migration/AddConcurrentForeignKey # rubocop:disable Migration/AddConcurrentForeignKey
# rubocop:disable Style/WordArray # rubocop:disable Style/WordArray
# rubocop:disable Migration/AddLimitToStringColumns # rubocop:disable Migration/AddLimitToStringColumns
# rubocop:disable Migration/Datetime
class InitSchema < ActiveRecord::Migration[4.2] class InitSchema < ActiveRecord::Migration[4.2]
DOWNTIME = false DOWNTIME = false
......
...@@ -9,7 +9,7 @@ class CreateLfsFileLocks < ActiveRecord::Migration[4.2] ...@@ -9,7 +9,7 @@ class CreateLfsFileLocks < ActiveRecord::Migration[4.2]
create_table :lfs_file_locks do |t| create_table :lfs_file_locks do |t|
t.references :project, null: false, foreign_key: { on_delete: :cascade } t.references :project, null: false, foreign_key: { on_delete: :cascade }
t.references :user, null: false, index: true, foreign_key: { on_delete: :cascade } t.references :user, null: false, index: true, foreign_key: { on_delete: :cascade }
t.datetime :created_at, null: false t.datetime :created_at, null: false # rubocop:disable Migration/Datetime
t.string :path, limit: 511 t.string :path, limit: 511
end end
......
...@@ -14,9 +14,9 @@ class CreateRemoteMirrors < ActiveRecord::Migration[4.2] ...@@ -14,9 +14,9 @@ class CreateRemoteMirrors < ActiveRecord::Migration[4.2]
t.string :url t.string :url
t.boolean :enabled, default: true t.boolean :enabled, default: true
t.string :update_status t.string :update_status
t.datetime :last_update_at t.datetime :last_update_at # rubocop:disable Migration/Datetime
t.datetime :last_successful_update_at t.datetime :last_successful_update_at # rubocop:disable Migration/Datetime
t.datetime :last_update_started_at t.datetime :last_update_started_at # rubocop:disable Migration/Datetime
t.string :last_error t.string :last_error
t.boolean :only_protected_branches, default: false, null: false t.boolean :only_protected_branches, default: false, null: false
t.string :remote_name t.string :remote_name
......
# frozen_string_literal: true # frozen_string_literal: true
# rubocop:disable Migration/Datetime
class DropForkedProjectLinksTable < ActiveRecord::Migration[6.0] class DropForkedProjectLinksTable < ActiveRecord::Migration[6.0]
include Gitlab::Database::MigrationHelpers include Gitlab::Database::MigrationHelpers
......
...@@ -2,10 +2,10 @@ class CreateProjectRegistry < ActiveRecord::Migration[4.2] ...@@ -2,10 +2,10 @@ class CreateProjectRegistry < ActiveRecord::Migration[4.2]
def change def change
create_table :project_registry do |t| create_table :project_registry do |t|
t.integer :project_id, null: false t.integer :project_id, null: false
t.datetime :last_repository_synced_at t.datetime :last_repository_synced_at # rubocop:disable Migration/Datetime
t.datetime :last_repository_successful_sync_at t.datetime :last_repository_successful_sync_at # rubocop:disable Migration/Datetime
t.datetime :created_at, null: false t.datetime :created_at, null: false # rubocop:disable Migration/Datetime
end end
end end
end end
...@@ -6,7 +6,7 @@ class CreateFileRegistry < ActiveRecord::Migration[4.2] ...@@ -6,7 +6,7 @@ class CreateFileRegistry < ActiveRecord::Migration[4.2]
t.integer :bytes t.integer :bytes
t.string :sha256 # rubocop:disable Migration/AddLimitToStringColumns t.string :sha256 # rubocop:disable Migration/AddLimitToStringColumns
t.datetime :created_at, null: false t.datetime :created_at, null: false # rubocop:disable Migration/Datetime
end end
add_index :file_registry, :file_type add_index :file_registry, :file_type
......
...@@ -9,9 +9,9 @@ class AddContainerRepositoryRegistry < ActiveRecord::Migration[5.0] ...@@ -9,9 +9,9 @@ class AddContainerRepositoryRegistry < ActiveRecord::Migration[5.0]
t.string :state # rubocop:disable Migration/AddLimitToStringColumns t.string :state # rubocop:disable Migration/AddLimitToStringColumns
t.integer :retry_count, default: 0 t.integer :retry_count, default: 0
t.string :last_sync_failure # rubocop:disable Migration/AddLimitToStringColumns t.string :last_sync_failure # rubocop:disable Migration/AddLimitToStringColumns
t.datetime :retry_at t.datetime :retry_at # rubocop:disable Migration/Datetime
t.datetime :last_synced_at t.datetime :last_synced_at # rubocop:disable Migration/Datetime
t.datetime :created_at, null: false t.datetime :created_at, null: false # rubocop:disable Migration/Datetime
t.index :container_repository_id, name: :index_container_repository_registry_on_repository_id, using: :btree t.index :container_repository_id, name: :index_container_repository_registry_on_repository_id, using: :btree
t.index :retry_at, name: :index_container_repository_registry_on_retry_at, using: :btree t.index :retry_at, name: :index_container_repository_registry_on_retry_at, using: :btree
......
...@@ -16,9 +16,9 @@ class AddDesignRegistry < ActiveRecord::Migration[5.2] ...@@ -16,9 +16,9 @@ class AddDesignRegistry < ActiveRecord::Migration[5.2]
t.string :last_sync_failure # rubocop:disable Migration/AddLimitToStringColumns t.string :last_sync_failure # rubocop:disable Migration/AddLimitToStringColumns
t.boolean :force_to_redownload t.boolean :force_to_redownload
t.boolean :missing_on_primary t.boolean :missing_on_primary
t.datetime :retry_at t.datetime :retry_at # rubocop:disable Migration/Datetime
t.datetime :last_synced_at t.datetime :last_synced_at # rubocop:disable Migration/Datetime
t.datetime :created_at, null: false t.datetime :created_at, null: false # rubocop:disable Migration/Datetime
t.index :project_id, name: :index_design_registry_on_project_id, using: :btree t.index :project_id, name: :index_design_registry_on_project_id, using: :btree
t.index :retry_at, name: :index_design_registry_on_retry_at, using: :btree t.index :retry_at, name: :index_design_registry_on_retry_at, using: :btree
......
...@@ -14,7 +14,7 @@ module RuboCop ...@@ -14,7 +14,7 @@ module RuboCop
return unless in_migration?(node) return unless in_migration?(node)
node.each_descendant(:send) do |send_node| node.each_descendant(:send) do |send_node|
method_name = node.children[1] method_name = send_node.children[1]
if method_name == :datetime || method_name == :timestamp if method_name == :datetime || method_name == :timestamp
add_offense(send_node, location: :selector, message: format(MSG, method_name)) add_offense(send_node, location: :selector, message: format(MSG, method_name))
......
...@@ -12,9 +12,69 @@ describe RuboCop::Cop::Migration::Datetime do ...@@ -12,9 +12,69 @@ describe RuboCop::Cop::Migration::Datetime do
subject(:cop) { described_class.new } subject(:cop) { described_class.new }
let(:migration_with_datetime) do let(:create_table_migration_with_datetime) do
%q( %q(
class Users < ActiveRecord::Migration[4.2] class Users < ActiveRecord::Migration[6.0]
DOWNTIME = false
def change
create_table :users do |t|
t.string :username, null: false
t.datetime :last_sign_in
end
end
end
)
end
let(:create_table_migration_with_timestamp) do
%q(
class Users < ActiveRecord::Migration[6.0]
DOWNTIME = false
def change
create_table :users do |t|
t.string :username, null: false
t.timestamp :last_sign_in
end
end
end
)
end
let(:create_table_migration_without_datetime) do
%q(
class Users < ActiveRecord::Migration[6.0]
DOWNTIME = false
def change
create_table :users do |t|
t.string :username, null: false
t.string :password
end
end
end
)
end
let(:create_table_migration_with_datetime_with_timezone) do
%q(
class Users < ActiveRecord::Migration[6.0]
DOWNTIME = false
def change
create_table :users do |t|
t.string :username, null: false
t.datetime_with_timezone :last_sign_in
end
end
end
)
end
let(:add_column_migration_with_datetime) do
%q(
class Users < ActiveRecord::Migration[6.0]
DOWNTIME = false DOWNTIME = false
def change def change
...@@ -25,9 +85,9 @@ describe RuboCop::Cop::Migration::Datetime do ...@@ -25,9 +85,9 @@ describe RuboCop::Cop::Migration::Datetime do
) )
end end
let(:migration_with_timestamp) do let(:add_column_migration_with_timestamp) do
%q( %q(
class Users < ActiveRecord::Migration[4.2] class Users < ActiveRecord::Migration[6.0]
DOWNTIME = false DOWNTIME = false
def change def change
...@@ -38,9 +98,9 @@ describe RuboCop::Cop::Migration::Datetime do ...@@ -38,9 +98,9 @@ describe RuboCop::Cop::Migration::Datetime do
) )
end end
let(:migration_without_datetime) do let(:add_column_migration_without_datetime) do
%q( %q(
class Users < ActiveRecord::Migration[4.2] class Users < ActiveRecord::Migration[6.0]
DOWNTIME = false DOWNTIME = false
def change def change
...@@ -50,9 +110,9 @@ describe RuboCop::Cop::Migration::Datetime do ...@@ -50,9 +110,9 @@ describe RuboCop::Cop::Migration::Datetime do
) )
end end
let(:migration_with_datetime_with_timezone) do let(:add_column_migration_with_datetime_with_timezone) do
%q( %q(
class Users < ActiveRecord::Migration[4.2] class Users < ActiveRecord::Migration[6.0]
DOWNTIME = false DOWNTIME = false
def change def change
...@@ -68,18 +128,54 @@ describe RuboCop::Cop::Migration::Datetime do ...@@ -68,18 +128,54 @@ describe RuboCop::Cop::Migration::Datetime do
allow(cop).to receive(:in_migration?).and_return(true) allow(cop).to receive(:in_migration?).and_return(true)
end end
it 'registers an offense when the ":datetime" data type is used' do it 'registers an offense when the ":datetime" data type is used on create_table' do
inspect_source(migration_with_datetime) inspect_source(create_table_migration_with_datetime)
aggregate_failures do
expect(cop.offenses.size).to eq(1)
expect(cop.offenses.map(&:line)).to eq([8])
expect(cop.offenses.first.message).to include('`datetime`')
end
end
it 'registers an offense when the ":timestamp" data type is used on create_table' do
inspect_source(create_table_migration_with_timestamp)
aggregate_failures do
expect(cop.offenses.size).to eq(1)
expect(cop.offenses.map(&:line)).to eq([8])
expect(cop.offenses.first.message).to include('timestamp')
end
end
it 'does not register an offense when the ":datetime" data type is not used on create_table' do
inspect_source(create_table_migration_without_datetime)
aggregate_failures do
expect(cop.offenses.size).to eq(0)
end
end
it 'does not register an offense when the ":datetime_with_timezone" data type is used on create_table' do
inspect_source(create_table_migration_with_datetime_with_timezone)
aggregate_failures do
expect(cop.offenses.size).to eq(0)
end
end
it 'registers an offense when the ":datetime" data type is used on add_column' do
inspect_source(add_column_migration_with_datetime)
aggregate_failures do aggregate_failures do
expect(cop.offenses.size).to eq(1) expect(cop.offenses.size).to eq(1)
expect(cop.offenses.map(&:line)).to eq([7]) expect(cop.offenses.map(&:line)).to eq([7])
expect(cop.offenses.first.message).to include('datetime') expect(cop.offenses.first.message).to include('`datetime`')
end end
end end
it 'registers an offense when the ":timestamp" data type is used' do it 'registers an offense when the ":timestamp" data type is used on add_column' do
inspect_source(migration_with_timestamp) inspect_source(add_column_migration_with_timestamp)
aggregate_failures do aggregate_failures do
expect(cop.offenses.size).to eq(1) expect(cop.offenses.size).to eq(1)
...@@ -88,16 +184,16 @@ describe RuboCop::Cop::Migration::Datetime do ...@@ -88,16 +184,16 @@ describe RuboCop::Cop::Migration::Datetime do
end end
end end
it 'does not register an offense when the ":datetime" data type is not used' do it 'does not register an offense when the ":datetime" data type is not used on add_column' do
inspect_source(migration_without_datetime) inspect_source(add_column_migration_without_datetime)
aggregate_failures do aggregate_failures do
expect(cop.offenses.size).to eq(0) expect(cop.offenses.size).to eq(0)
end end
end end
it 'does not register an offense when the ":datetime_with_timezone" data type is used' do it 'does not register an offense when the ":datetime_with_timezone" data type is used on add_column' do
inspect_source(migration_with_datetime_with_timezone) inspect_source(add_column_migration_with_datetime_with_timezone)
aggregate_failures do aggregate_failures do
expect(cop.offenses.size).to eq(0) expect(cop.offenses.size).to eq(0)
...@@ -107,10 +203,10 @@ describe RuboCop::Cop::Migration::Datetime do ...@@ -107,10 +203,10 @@ describe RuboCop::Cop::Migration::Datetime do
context 'outside of migration' do context 'outside of migration' do
it 'registers no offense' do it 'registers no offense' do
inspect_source(migration_with_datetime) inspect_source(add_column_migration_with_datetime)
inspect_source(migration_with_timestamp) inspect_source(add_column_migration_with_timestamp)
inspect_source(migration_without_datetime) inspect_source(add_column_migration_without_datetime)
inspect_source(migration_with_datetime_with_timezone) inspect_source(add_column_migration_with_datetime_with_timezone)
expect(cop.offenses.size).to eq(0) expect(cop.offenses.size).to eq(0)
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment