Commit ebe7c4c8 authored by Aleksei Lipniagov's avatar Aleksei Lipniagov

Add feature flag and comments on hash structure

parent 334a9775
...@@ -79,6 +79,11 @@ module Gitlab ...@@ -79,6 +79,11 @@ module Gitlab
@tree = tree @tree = tree
end end
# With the usage of `JSONBatchRelation`, it returns partially
# serialized hash which is not easily accessible.
# It means you can only manipulate and replace top-level objects.
# All future mutations of the hash (such as `fix_project_tree`)
# should be aware of that.
def execute def execute
simple_serialize.merge(serialize_includes) simple_serialize.merge(serialize_includes)
end end
...@@ -131,7 +136,12 @@ module Gitlab ...@@ -131,7 +136,12 @@ module Gitlab
data = [] data = []
record.in_batches(of: @batch_size) do |batch| # rubocop:disable Cop/InBatches record.in_batches(of: @batch_size) do |batch| # rubocop:disable Cop/InBatches
if Feature.enabled?(:export_fast_serialize_with_raw_json, default_enabled: true)
data.append(JSONBatchRelation.new(batch, options, preloads[key]).tap(&:raw_json)) data.append(JSONBatchRelation.new(batch, options, preloads[key]).tap(&:raw_json))
else
batch = batch.preload(preloads[key]) if preloads&.key?(key)
data += batch.as_json(options)
end
end end
data data
......
...@@ -31,6 +31,8 @@ module Gitlab ...@@ -31,6 +31,8 @@ module Gitlab
private private
# Aware that the resulting hash needs to be pure-hash and
# does not include any AR objects anymore, only objects that run `.to_json`
def fix_project_tree(project_tree) def fix_project_tree(project_tree)
if @params[:description].present? if @params[:description].present?
project_tree['description'] = @params[:description] project_tree['description'] = @params[:description]
......
require 'spec_helper' require 'spec_helper'
describe Gitlab::ImportExport::FastHashSerializer do describe Gitlab::ImportExport::FastHashSerializer do
# FastHashSerializer#execute generates the hash which is not easily accessible
# and includes `JSONBatchRelation` items which are serialized at this point.
# Wrapping the result into JSON generating/parsing is for making
# the testing more convenient. Doing this, we can check that
# all items are properly serialized while traversing the simple hash.
subject { JSON.parse(JSON.generate(described_class.new(project, tree).execute)) } subject { JSON.parse(JSON.generate(described_class.new(project, tree).execute)) }
let!(:project) { setup_project } let!(:project) { setup_project }
......
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