2019-12-21 20:55:43 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe ContainerRepositoryEntity do
|
2020-04-08 14:13:33 +05:30
|
|
|
let_it_be(:project) { create(:project) }
|
|
|
|
let_it_be(:user) { create(:user) }
|
|
|
|
let_it_be(:repository) { create(:container_repository, project: project) }
|
2021-04-29 21:17:54 +05:30
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
let(:entity) { described_class.new(repository, request: request) }
|
2018-03-17 18:26:18 +05:30
|
|
|
let(:request) { double('request') }
|
|
|
|
|
|
|
|
subject { entity.as_json }
|
|
|
|
|
|
|
|
before do
|
|
|
|
stub_container_registry_config(enabled: true)
|
2020-06-23 00:09:42 +05:30
|
|
|
stub_container_registry_tags(repository: :any,
|
|
|
|
tags: %w[stable latest])
|
2018-03-17 18:26:18 +05:30
|
|
|
allow(request).to receive(:project).and_return(project)
|
|
|
|
allow(request).to receive(:current_user).and_return(user)
|
|
|
|
end
|
|
|
|
|
2019-03-02 22:35:43 +05:30
|
|
|
it 'exposes required informations' do
|
2020-06-23 00:09:42 +05:30
|
|
|
expect(subject).to include(:id, :path, :location, :tags_path, :tags_count)
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
|
2019-12-21 20:55:43 +05:30
|
|
|
context 'when project is not preset in the request' do
|
|
|
|
before do
|
|
|
|
allow(request).to receive(:respond_to?).and_return(false)
|
|
|
|
allow(request).to receive(:project).and_return(nil)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'uses project from the object' do
|
|
|
|
expect(request.project).not_to equal(project)
|
|
|
|
expect(subject).to include(:tags_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
context 'when user can manage repositories' do
|
|
|
|
before do
|
|
|
|
project.add_developer(user)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'exposes destroy_path' do
|
|
|
|
expect(subject).to include(:destroy_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when user cannot manage repositories' do
|
|
|
|
it 'does not expose destroy_path' do
|
|
|
|
expect(subject).not_to include(:destroy_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|