debian-mirror-gitlab/spec/services/files/delete_service_spec.rb

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

76 lines
2.3 KiB
Ruby
Raw Permalink Normal View History

2019-07-31 22:56:46 +05:30
# frozen_string_literal: true
2018-03-17 18:26:18 +05:30
require "spec_helper"
2023-05-27 22:25:52 +05:30
RSpec.describe Files::DeleteService, feature_category: :source_code_management do
2018-03-17 18:26:18 +05:30
subject { described_class.new(project, user, commit_params) }
let(:project) { create(:project, :repository) }
2018-12-05 23:21:45 +05:30
let(:user) { create(:user, :commit_email) }
2018-03-17 18:26:18 +05:30
let(:file_path) { 'files/ruby/popen.rb' }
let(:branch_name) { project.default_branch }
let(:last_commit_sha) { nil }
2018-12-05 23:21:45 +05:30
let(:commit) { project.repository.head_commit }
2018-03-17 18:26:18 +05:30
let(:commit_params) do
{
file_path: file_path,
commit_message: "Delete File",
last_commit_sha: last_commit_sha,
start_project: project,
start_branch: project.default_branch,
branch_name: branch_name
}
end
shared_examples 'successfully deletes the file' do
it 'returns a hash with the :success status' do
results = subject.execute
expect(results[:status]).to match(:success)
end
it 'deletes the file' do
subject.execute
blob = project.repository.blob_at_branch(project.default_branch, file_path)
expect(blob).to be_nil
end
2018-12-05 23:21:45 +05:30
it 'uses the commit email' do
subject.execute
expect(user.commit_email).not_to eq(user.email)
expect(commit.author_email).to eq(user.commit_email)
expect(commit.committer_email).to eq(user.commit_email)
end
2018-03-17 18:26:18 +05:30
end
before do
2018-11-18 11:00:15 +05:30
project.add_maintainer(user)
2018-03-17 18:26:18 +05:30
end
describe "#execute" do
2023-05-27 22:25:52 +05:30
context "when the file's last commit is earlier than the latest commit for this branch" do
let(:last_commit_sha) { Gitlab::Git::Commit.last_for_path(project.repository, project.default_branch, file_path).parent_id }
2018-03-17 18:26:18 +05:30
2021-02-22 17:27:13 +05:30
it "returns a hash with the correct error message and a :error status" do
2018-03-17 18:26:18 +05:30
expect { subject.execute }
.to raise_error(Files::UpdateService::FileChangedError,
"You are attempting to delete a file that has been previously updated.")
end
end
context "when the file's last commit sha does match the supplied last_commit_sha" do
let(:last_commit_sha) { Gitlab::Git::Commit.last_for_path(project.repository, project.default_branch, file_path).sha }
it_behaves_like 'successfully deletes the file'
end
context "when the last_commit_sha is not supplied" do
it_behaves_like 'successfully deletes the file'
end
end
end