debian-mirror-gitlab/spec/services/work_items/create_service_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

85 lines
2.2 KiB
Ruby
Raw Normal View History

2022-03-02 08:16:31 +05:30
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe WorkItems::CreateService do
include AfterNextHelpers
2022-04-04 11:22:00 +05:30
let_it_be_with_reload(:project) { create(:project) }
let_it_be(:guest) { create(:user) }
let_it_be(:user_with_no_access) { create(:user) }
2022-03-02 08:16:31 +05:30
let(:spam_params) { double }
2022-04-04 11:22:00 +05:30
let(:current_user) { guest }
let(:opts) do
{
title: 'Awesome work_item',
description: 'please fix'
}
end
before_all do
project.add_guest(guest)
end
2022-03-02 08:16:31 +05:30
describe '#execute' do
2022-04-04 11:22:00 +05:30
subject(:service_result) { described_class.new(project: project, current_user: current_user, params: opts, spam_params: spam_params).execute }
2022-03-02 08:16:31 +05:30
before do
stub_spam_services
end
2022-04-04 11:22:00 +05:30
context 'when user is not allowed to create a work item in the project' do
let(:current_user) { user_with_no_access }
it { is_expected.to be_error }
2022-03-02 08:16:31 +05:30
2022-04-04 11:22:00 +05:30
it 'returns an access error' do
expect(service_result.errors).to contain_exactly('Operation not allowed')
2022-03-02 08:16:31 +05:30
end
2022-04-04 11:22:00 +05:30
end
2022-03-02 08:16:31 +05:30
2022-04-04 11:22:00 +05:30
context 'when params are valid' do
2022-03-02 08:16:31 +05:30
it 'created instance is a WorkItem' do
expect(Issuable::CommonSystemNotesService).to receive_message_chain(:new, :execute)
2022-04-04 11:22:00 +05:30
work_item = service_result[:work_item]
2022-03-02 08:16:31 +05:30
expect(work_item).to be_persisted
expect(work_item).to be_a(::WorkItem)
expect(work_item.title).to eq('Awesome work_item')
expect(work_item.description).to eq('please fix')
expect(work_item.work_item_type.base_type).to eq('issue')
end
end
2022-04-04 11:22:00 +05:30
context 'when params are invalid' do
let(:opts) { { title: '' } }
2022-03-02 08:16:31 +05:30
2022-04-04 11:22:00 +05:30
it { is_expected.to be_error }
it 'returns validation errors' do
expect(service_result.errors).to contain_exactly("Title can't be blank")
2022-03-02 08:16:31 +05:30
end
2022-04-04 11:22:00 +05:30
end
2022-03-02 08:16:31 +05:30
2022-04-04 11:22:00 +05:30
context 'checking spam' do
2022-03-02 08:16:31 +05:30
it 'executes SpamActionService' do
expect_next_instance_of(
Spam::SpamActionService,
{
spammable: kind_of(WorkItem),
spam_params: spam_params,
user: an_instance_of(User),
action: :create
}
) do |instance|
expect(instance).to receive(:execute)
end
2022-04-04 11:22:00 +05:30
service_result
2022-03-02 08:16:31 +05:30
end
end
end
end