58 lines
1.6 KiB
Ruby
58 lines
1.6 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'fast_spec_helper'
|
|
require_relative '../../../rubocop/cop/active_record_association_reload'
|
|
|
|
RSpec.describe RuboCop::Cop::ActiveRecordAssociationReload do
|
|
subject(:cop) { described_class.new }
|
|
|
|
context 'when using ActiveRecord::Base' do
|
|
it 'registers an offense on reload usage' do
|
|
expect_offense(<<~PATTERN)
|
|
users = User.all
|
|
users.reload
|
|
^^^^^^ Use reset instead of reload. For more details check the https://gitlab.com/gitlab-org/gitlab-foss/issues/60218.
|
|
PATTERN
|
|
end
|
|
|
|
it 'does not register an offense on reset usage' do
|
|
expect_no_offenses(<<~PATTERN)
|
|
users = User.all
|
|
users.reset
|
|
PATTERN
|
|
end
|
|
end
|
|
|
|
context 'when using ActiveRecord::Relation' do
|
|
it 'registers an offense on reload usage' do
|
|
expect_offense(<<~PATTERN)
|
|
user = User.new
|
|
user.reload
|
|
^^^^^^ Use reset instead of reload. For more details check the https://gitlab.com/gitlab-org/gitlab-foss/issues/60218.
|
|
PATTERN
|
|
end
|
|
|
|
it 'does not register an offense on reset usage' do
|
|
expect_no_offenses(<<~PATTERN)
|
|
user = User.new
|
|
user.reset
|
|
PATTERN
|
|
end
|
|
end
|
|
|
|
context 'when using on self' do
|
|
it 'registers an offense on reload usage' do
|
|
expect_offense(<<~PATTERN)
|
|
reload
|
|
^^^^^^ Use reset instead of reload. For more details check the https://gitlab.com/gitlab-org/gitlab-foss/issues/60218.
|
|
PATTERN
|
|
end
|
|
|
|
it 'does not register an offense on reset usage' do
|
|
expect_no_offenses(<<~PATTERN)
|
|
reset
|
|
PATTERN
|
|
end
|
|
end
|
|
end
|