2016-11-10 15:16:54 -05:00
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe PipelineSerializer do
|
2016-12-15 09:57:35 -05:00
|
|
|
let(:user) { create(:user) }
|
|
|
|
|
2016-11-10 15:16:54 -05:00
|
|
|
let(:serializer) do
|
|
|
|
described_class.new(user: user)
|
|
|
|
end
|
|
|
|
|
2017-01-27 07:02:59 -05:00
|
|
|
subject { serializer.represent(resource) }
|
2016-12-28 07:07:30 -05:00
|
|
|
|
2016-12-15 09:57:35 -05:00
|
|
|
describe '#represent' do
|
2016-12-28 07:07:30 -05:00
|
|
|
context 'when used without pagination' do
|
|
|
|
it 'created a not paginated serializer' do
|
|
|
|
expect(serializer).not_to be_paginated
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when a single object is being serialized' do
|
|
|
|
let(:resource) { create(:ci_empty_pipeline) }
|
|
|
|
|
|
|
|
it 'serializers the pipeline object' do
|
|
|
|
expect(subject[:id]).to eq resource.id
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when multiple objects are being serialized' do
|
|
|
|
let(:resource) { create_list(:ci_pipeline, 2) }
|
|
|
|
|
|
|
|
it 'serializers the array of pipelines' do
|
|
|
|
expect(subject).not_to be_empty
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when used with pagination' do
|
|
|
|
let(:request) { spy('request') }
|
|
|
|
let(:response) { spy('response') }
|
|
|
|
let(:pagination) { {} }
|
|
|
|
|
|
|
|
before do
|
2017-02-21 18:29:35 -05:00
|
|
|
allow(request).
|
|
|
|
to receive(:query_parameters).
|
|
|
|
and_return(pagination)
|
2016-12-28 07:07:30 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
let(:serializer) do
|
2017-02-21 18:29:35 -05:00
|
|
|
described_class.new(user: user).
|
|
|
|
with_pagination(request, response)
|
2016-12-28 07:07:30 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'created a paginated serializer' do
|
|
|
|
expect(serializer).to be_paginated
|
|
|
|
end
|
|
|
|
|
2017-02-03 05:41:23 -05:00
|
|
|
context 'when resource is not paginatable' do
|
2016-12-28 07:07:30 -05:00
|
|
|
context 'when a single pipeline object is being serialized' do
|
|
|
|
let(:resource) { create(:ci_empty_pipeline) }
|
|
|
|
let(:pagination) { { page: 1, per_page: 1 } }
|
|
|
|
|
|
|
|
it 'raises error' do
|
2017-02-06 09:07:13 -05:00
|
|
|
expect { subject }.to raise_error(
|
|
|
|
Gitlab::Serializer::Pagination::InvalidResourceError)
|
2016-12-28 07:07:30 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when resource is paginatable relation' do
|
|
|
|
let(:resource) { Ci::Pipeline.all }
|
|
|
|
let(:pagination) { { page: 1, per_page: 2 } }
|
|
|
|
|
|
|
|
context 'when a single pipeline object is present in relation' do
|
|
|
|
before { create(:ci_empty_pipeline) }
|
|
|
|
|
|
|
|
it 'serializes pipeline relation' do
|
|
|
|
expect(subject.first).to have_key :id
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when a multiple pipeline objects are being serialized' do
|
|
|
|
before { create_list(:ci_empty_pipeline, 3) }
|
|
|
|
|
|
|
|
it 'serializes appropriate number of objects' do
|
|
|
|
expect(subject.count).to be 2
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'appends relevant headers' do
|
|
|
|
expect(response).to receive(:[]=).with('X-Total', '3')
|
|
|
|
expect(response).to receive(:[]=).with('X-Total-Pages', '2')
|
|
|
|
expect(response).to receive(:[]=).with('X-Per-Page', '2')
|
2016-11-10 15:16:54 -05:00
|
|
|
|
2016-12-28 07:07:30 -05:00
|
|
|
subject
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2016-12-15 09:57:35 -05:00
|
|
|
end
|
|
|
|
end
|
2016-11-10 15:16:54 -05:00
|
|
|
end
|