Commit 7db1f226 authored by Grzegorz Bizon's avatar Grzegorz Bizon

Fix specs for services related to container registry

parent af42dd29
require 'spec_helper' require 'spec_helper'
describe ContainerImages::DestroyService, services: true do describe ContainerImages::DestroyService, '#execute', :services do
describe '#execute' do let(:user) { create(:user) }
let(:user) { create(:user) }
let(:container_repository) { create(:container_repository, name: '') } let(:container_repository) do
let(:project) { create(:project, path: 'test', namespace: user.namespace, container_repositorys: [container_repository]) } create(:container_repository, name: 'myimage', tags: %w[latest])
let(:example_host) { 'example.com' } end
let(:registry_url) { 'http://' + example_host }
let(:project) do
it { expect(container_repository).to be_valid } create(:project, path: 'test',
it { expect(project.container_repositorys).not_to be_empty } namespace: user.namespace,
container_repositories: [container_repository])
context 'when container image has tags' do end
before do
project.team << [user, :master] it { expect(container_repository).to be_valid }
end it { expect(project.container_repositories).not_to be_empty }
it 'removes all tags before destroy' do context 'when container image has tags' do
service = described_class.new(project, user) before do
project.add_master(user)
expect(container_repository).to receive(:delete_tags).and_return(true) end
expect { service.execute(container_repository) }.to change(project.container_repositorys, :count).by(-1)
end it 'removes all tags before destroy' do
service = described_class.new(project, user)
it 'fails when tags are not removed' do
service = described_class.new(project, user) expect(container_repository)
.to receive(:delete_tags).and_return(true)
expect(container_repository).to receive(:delete_tags).and_return(false) expect { service.execute(container_repository) }
expect { service.execute(container_repository) }.to raise_error(ActiveRecord::RecordNotDestroyed) .to change(project.container_repositories, :count).by(-1)
end end
it 'fails when tags are not removed' do
service = described_class.new(project, user)
expect(container_repository)
.to receive(:delete_tags).and_return(false)
expect { service.execute(container_repository) }
.to raise_error(ActiveRecord::RecordNotDestroyed)
end end
end end
end end
...@@ -95,7 +95,7 @@ describe Projects::DestroyService, services: true do ...@@ -95,7 +95,7 @@ describe Projects::DestroyService, services: true do
before do before do
stub_container_registry_config(enabled: true) stub_container_registry_config(enabled: true)
stub_container_registry_tags('tag') stub_container_registry_tags('tag')
project.container_repositorys << container_repository project.container_repositories << container_repository
end end
context 'images deletion succeeds' do context 'images deletion succeeds' do
......
...@@ -34,7 +34,7 @@ describe Projects::TransferService, services: true do ...@@ -34,7 +34,7 @@ describe Projects::TransferService, services: true do
before do before do
stub_container_registry_config(enabled: true) stub_container_registry_config(enabled: true)
stub_container_registry_tags('tag') stub_container_registry_tags('tag')
project.container_repositorys << container_repository project.container_repositories << container_repository
end end
subject { transfer_project(project, user, group) } subject { transfer_project(project, user, group) }
......
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