summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStan Hu <stanhu@gmail.com>2019-06-13 19:27:26 +0000
committerStan Hu <stanhu@gmail.com>2019-06-13 19:27:26 +0000
commit3db2e15b7235d2bfb002b46d85f37d3ae54876ec (patch)
tree105ab96aa450d05cc477949ce6c1eb63524d0090
parent40d309cc7875ebb7c1178da6a088399266ce263b (diff)
parent0c29aa0da38104c4c65cbadcc40abe25e56693aa (diff)
downloadgitlab-ce-3db2e15b7235d2bfb002b46d85f37d3ae54876ec.tar.gz
Merge branch 'ce-3861-use-serializers-for-project-group-boards' into 'master'
Use serialization for project boards See merge request gitlab-org/gitlab-ce!29263
-rw-r--r--app/controllers/concerns/boards_actions.rb8
-rw-r--r--app/controllers/concerns/boards_responses.rb6
-rw-r--r--app/serializers/board_serializer.rb5
-rw-r--r--app/serializers/board_simple_entity.rb5
-rw-r--r--spec/controllers/concerns/boards_responses_spec.rb23
-rw-r--r--spec/serializers/board_serializer_spec.rb20
6 files changed, 66 insertions, 1 deletions
diff --git a/app/controllers/concerns/boards_actions.rb b/app/controllers/concerns/boards_actions.rb
index ed7ea2f0e04..e4123d87137 100644
--- a/app/controllers/concerns/boards_actions.rb
+++ b/app/controllers/concerns/boards_actions.rb
@@ -35,4 +35,12 @@ module BoardsActions
boards.find(params[:id])
end
end
+
+ def serializer
+ BoardSerializer.new(current_user: current_user)
+ end
+
+ def serialize_as_json(resource)
+ serializer.represent(resource, serializer: 'board', include_full_project_path: board.group_board?)
+ end
end
diff --git a/app/controllers/concerns/boards_responses.rb b/app/controllers/concerns/boards_responses.rb
index 8b191c86397..7625600e452 100644
--- a/app/controllers/concerns/boards_responses.rb
+++ b/app/controllers/concerns/boards_responses.rb
@@ -69,7 +69,7 @@ module BoardsResponses
end
def serialize_as_json(resource)
- resource.as_json(only: [:id])
+ serializer.represent(resource).as_json
end
def respond_with(resource)
@@ -80,4 +80,8 @@ module BoardsResponses
end
end
end
+
+ def serializer
+ BoardSerializer.new
+ end
end
diff --git a/app/serializers/board_serializer.rb b/app/serializers/board_serializer.rb
new file mode 100644
index 00000000000..70a4c9ae282
--- /dev/null
+++ b/app/serializers/board_serializer.rb
@@ -0,0 +1,5 @@
+# frozen_string_literal: true
+
+class BoardSerializer < BaseSerializer
+ entity BoardSimpleEntity
+end
diff --git a/app/serializers/board_simple_entity.rb b/app/serializers/board_simple_entity.rb
new file mode 100644
index 00000000000..f297d993e27
--- /dev/null
+++ b/app/serializers/board_simple_entity.rb
@@ -0,0 +1,5 @@
+# frozen_string_literal: true
+
+class BoardSimpleEntity < Grape::Entity
+ expose :id
+end
diff --git a/spec/controllers/concerns/boards_responses_spec.rb b/spec/controllers/concerns/boards_responses_spec.rb
new file mode 100644
index 00000000000..bdebdf94761
--- /dev/null
+++ b/spec/controllers/concerns/boards_responses_spec.rb
@@ -0,0 +1,23 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+describe BoardsResponses do
+ let(:controller_class) do
+ Class.new do
+ include BoardsResponses
+ end
+ end
+
+ subject(:controller) { controller_class.new }
+
+ describe '#serialize_as_json' do
+ let!(:board) { create(:board) }
+
+ it 'serializes properly' do
+ expected = { "id" => board.id }
+
+ expect(subject.serialize_as_json(board)).to include(expected)
+ end
+ end
+end
diff --git a/spec/serializers/board_serializer_spec.rb b/spec/serializers/board_serializer_spec.rb
new file mode 100644
index 00000000000..8a633e46316
--- /dev/null
+++ b/spec/serializers/board_serializer_spec.rb
@@ -0,0 +1,20 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+describe BoardSerializer do
+ let(:resource) { create(:board) }
+ let(:json_entity) do
+ described_class.new
+ .represent(resource, serializer: serializer)
+ .with_indifferent_access
+ end
+
+ context 'serialization' do
+ let(:serializer) { 'board' }
+
+ it 'matches issue_sidebar json schema' do
+ expect(json_entity).to match_schema('board')
+ end
+ end
+end