Commit c146461e authored by Grzegorz Bizon's avatar Grzegorz Bizon

Merge branch 'fix-bulk-insert-safe' into 'master'

Fix BulkInsertSafe to support encrypted and enums fields

See merge request gitlab-org/gitlab!27203
parents 38d31ac2 79adf0d1
...@@ -100,7 +100,13 @@ module BulkInsertSafe ...@@ -100,7 +100,13 @@ module BulkInsertSafe
def _bulk_insert_item_attributes(items, validate_items) def _bulk_insert_item_attributes(items, validate_items)
items.map do |item| items.map do |item|
item.validate! if validate_items item.validate! if validate_items
attributes = item.attributes
attributes = {}
column_names.each do |name|
value = item.read_attribute(name)
value = item.type_for_attribute(name).serialize(value) # rubocop:disable Cop/ActiveRecordSerialize
attributes[name] = value
end
_bulk_insert_reject_primary_key!(attributes, item.class.primary_key) _bulk_insert_reject_primary_key!(attributes, item.class.primary_key)
......
...@@ -6,7 +6,19 @@ describe BulkInsertSafe do ...@@ -6,7 +6,19 @@ describe BulkInsertSafe do
class BulkInsertItem < ApplicationRecord class BulkInsertItem < ApplicationRecord
include BulkInsertSafe include BulkInsertSafe
validates :name, presence: true validates :name, :enum_value, :secret_value, presence: true
ENUM_VALUES = {
case_1: 1
}.freeze
enum enum_value: ENUM_VALUES
attr_encrypted :secret_value,
mode: :per_attribute_iv,
algorithm: 'aes-256-gcm',
key: Settings.attr_encrypted_db_key_base_32,
insecure_mode: false
end end
module InheritedUnsafeMethods module InheritedUnsafeMethods
...@@ -29,8 +41,13 @@ describe BulkInsertSafe do ...@@ -29,8 +41,13 @@ describe BulkInsertSafe do
ActiveRecord::Schema.define do ActiveRecord::Schema.define do
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.text :encrypted_secret_value, null: false
t.string :encrypted_secret_value_iv, null: false
end end
end end
BulkInsertItem.reset_column_information
end end
after(:all) do after(:all) do
...@@ -41,13 +58,21 @@ describe BulkInsertSafe do ...@@ -41,13 +58,21 @@ describe BulkInsertSafe do
def build_valid_items_for_bulk_insertion def build_valid_items_for_bulk_insertion
Array.new(10) do |n| Array.new(10) do |n|
BulkInsertItem.new(name: "item-#{n}") BulkInsertItem.new(
name: "item-#{n}",
enum_value: 'case_1',
secret_value: "my-secret"
)
end end
end end
def build_invalid_items_for_bulk_insertion def build_invalid_items_for_bulk_insertion
Array.new(10) do Array.new(10) do
BulkInsertItem.new # requires `name` to be set BulkInsertItem.new(
name: nil, # requires `name` to be set
enum_value: 'case_1',
secret_value: "my-secret"
)
end end
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