Commit 6d9dcb9a authored by Igor Drozdov's avatar Igor Drozdov

Avoid calling belongs_to dynamically in tests

Calling belongs_to directly on a class modifies the state
of the class which may have impact on consequent tests.

Let's provide a way that avoids calling belongs_to,
but still tests its behavior
parent 9829525f
...@@ -5,6 +5,10 @@ require 'spec_helper' ...@@ -5,6 +5,10 @@ require 'spec_helper'
RSpec.describe BulkInsertSafe do RSpec.describe BulkInsertSafe do
before(:all) do before(:all) do
ActiveRecord::Schema.define do ActiveRecord::Schema.define do
create_table :bulk_insert_parent_items, force: true do |t|
t.string :name, null: false
end
create_table :bulk_insert_items, force: true do |t| create_table :bulk_insert_items, force: true do |t|
t.string :name, null: true t.string :name, null: true
t.integer :enum_value, null: false t.integer :enum_value, null: false
...@@ -12,6 +16,7 @@ RSpec.describe BulkInsertSafe do ...@@ -12,6 +16,7 @@ RSpec.describe BulkInsertSafe do
t.string :encrypted_secret_value_iv, null: false t.string :encrypted_secret_value_iv, null: false
t.binary :sha_value, null: false, limit: 20 t.binary :sha_value, null: false, limit: 20
t.jsonb :jsonb_value, null: false t.jsonb :jsonb_value, null: false
t.belongs_to :bulk_insert_parent_item, foreign_key: true, null: true
t.index :name, unique: true t.index :name, unique: true
end end
...@@ -21,9 +26,23 @@ RSpec.describe BulkInsertSafe do ...@@ -21,9 +26,23 @@ RSpec.describe BulkInsertSafe do
after(:all) do after(:all) do
ActiveRecord::Schema.define do ActiveRecord::Schema.define do
drop_table :bulk_insert_items, force: true drop_table :bulk_insert_items, force: true
drop_table :bulk_insert_parent_items, force: true
end end
end end
BulkInsertParentItem = Class.new(ActiveRecord::Base) do
self.table_name = :bulk_insert_parent_items
self.inheritance_column = :_type_disabled
def self.name
table_name.singularize.camelcase
end
end
let_it_be(:bulk_insert_parent_item) do
BulkInsertParentItem.create!(name: 'parent')
end
let_it_be(:bulk_insert_item_class) do let_it_be(:bulk_insert_item_class) do
Class.new(ActiveRecord::Base) do Class.new(ActiveRecord::Base) do
self.table_name = 'bulk_insert_items' self.table_name = 'bulk_insert_items'
...@@ -33,6 +52,8 @@ RSpec.describe BulkInsertSafe do ...@@ -33,6 +52,8 @@ RSpec.describe BulkInsertSafe do
validates :name, :enum_value, :secret_value, :sha_value, :jsonb_value, presence: true validates :name, :enum_value, :secret_value, :sha_value, :jsonb_value, presence: true
belongs_to :bulk_insert_parent_item
sha_attribute :sha_value sha_attribute :sha_value
enum enum_value: { case_1: 1 } enum enum_value: { case_1: 1 }
...@@ -51,8 +72,8 @@ RSpec.describe BulkInsertSafe do ...@@ -51,8 +72,8 @@ RSpec.describe BulkInsertSafe do
'BulkInsertItem' 'BulkInsertItem'
end end
def self.valid_list(count) def self.valid_list(count, bulk_insert_parent_item: nil)
Array.new(count) { |n| new(name: "item-#{n}", secret_value: 'my-secret') } Array.new(count) { |n| new(name: "item-#{n}", secret_value: 'my-secret', bulk_insert_parent_item: bulk_insert_parent_item) }
end end
def self.invalid_list(count) def self.invalid_list(count)
...@@ -117,6 +138,14 @@ RSpec.describe BulkInsertSafe do ...@@ -117,6 +138,14 @@ RSpec.describe BulkInsertSafe do
bulk_insert_item_class.bulk_insert!(items, batch_size: 5) bulk_insert_item_class.bulk_insert!(items, batch_size: 5)
end end
it 'inserts items with belongs_to association' do
items = bulk_insert_item_class.valid_list(10, bulk_insert_parent_item: bulk_insert_parent_item)
bulk_insert_item_class.bulk_insert!(items, batch_size: 5)
expect(bulk_insert_item_class.last(items.size).map(&:bulk_insert_parent_item)).to eq([bulk_insert_parent_item] * 10)
end
it 'items can be properly fetched from database' do it 'items can be properly fetched from database' do
items = bulk_insert_item_class.valid_list(10) items = bulk_insert_item_class.valid_list(10)
...@@ -129,8 +158,7 @@ RSpec.describe BulkInsertSafe do ...@@ -129,8 +158,7 @@ RSpec.describe BulkInsertSafe do
it 'rolls back the transaction when any item is invalid' do it 'rolls back the transaction when any item is invalid' do
# second batch is bad # second batch is bad
all_items = bulk_insert_item_class.valid_list(10) + all_items = bulk_insert_item_class.valid_list(10) + bulk_insert_item_class.invalid_list(10)
bulk_insert_item_class.invalid_list(10)
expect do expect do
bulk_insert_item_class.bulk_insert!(all_items, batch_size: 2) rescue nil bulk_insert_item_class.bulk_insert!(all_items, batch_size: 2) rescue nil
......
...@@ -30,10 +30,6 @@ RSpec.shared_examples 'a BulkInsertSafe model' do |klass| ...@@ -30,10 +30,6 @@ RSpec.shared_examples 'a BulkInsertSafe model' do |klass|
expect { target_class.set_callback(name) {} }.not_to raise_error expect { target_class.set_callback(name) {} }.not_to raise_error
end end
end end
it 'does not raise an error when the call is triggered by belongs_to' do
expect { target_class.belongs_to(:other_record) }.not_to raise_error
end
end end
describe '.bulk_insert!' do describe '.bulk_insert!' do
......
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