2016-08-07 23:29:23 -04:00
|
|
|
require "spec_helper"
|
|
|
|
|
|
|
|
describe Files::UpdateService do
|
|
|
|
subject { described_class.new(project, user, commit_params) }
|
|
|
|
|
|
|
|
let(:project) { create(:project) }
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:file_path) { 'files/ruby/popen.rb' }
|
2016-11-04 14:48:58 -04:00
|
|
|
let(:new_contents) { 'New Content' }
|
|
|
|
let(:target_branch) { project.default_branch }
|
|
|
|
let(:last_commit_sha) { nil }
|
|
|
|
|
2016-08-07 23:29:23 -04:00
|
|
|
let(:commit_params) do
|
|
|
|
{
|
|
|
|
file_path: file_path,
|
|
|
|
commit_message: "Update File",
|
|
|
|
file_content: new_contents,
|
|
|
|
file_content_encoding: "text",
|
|
|
|
last_commit_sha: last_commit_sha,
|
2017-01-06 10:50:08 -05:00
|
|
|
start_project: project,
|
|
|
|
start_branch: project.default_branch,
|
2016-11-04 14:48:58 -04:00
|
|
|
target_branch: target_branch
|
2016-08-07 23:29:23 -04:00
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
project.team << [user, :master]
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#execute" do
|
|
|
|
context "when the file's last commit sha does not match the supplied last_commit_sha" do
|
|
|
|
let(:last_commit_sha) { "foo" }
|
|
|
|
|
|
|
|
it "returns a hash with the correct error message and a :error status " do
|
|
|
|
expect { subject.execute }.
|
|
|
|
to raise_error(Files::UpdateService::FileChangedError,
|
|
|
|
"You are attempting to update a file that has changed since you started editing it.")
|
|
|
|
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 "returns a hash with the :success status " do
|
|
|
|
results = subject.execute
|
|
|
|
|
2016-08-29 19:58:32 -04:00
|
|
|
expect(results[:status]).to match(:success)
|
2016-08-07 23:29:23 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "updates the file with the new contents" do
|
|
|
|
subject.execute
|
|
|
|
|
|
|
|
results = project.repository.blob_at_branch(project.default_branch, file_path)
|
|
|
|
|
|
|
|
expect(results.data).to eq(new_contents)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the last_commit_sha is not supplied" do
|
|
|
|
it "returns a hash with the :success status " do
|
|
|
|
results = subject.execute
|
|
|
|
|
2016-08-29 19:58:32 -04:00
|
|
|
expect(results[:status]).to match(:success)
|
2016-08-07 23:29:23 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "updates the file with the new contents" do
|
|
|
|
subject.execute
|
|
|
|
|
|
|
|
results = project.repository.blob_at_branch(project.default_branch, file_path)
|
|
|
|
|
|
|
|
expect(results.data).to eq(new_contents)
|
|
|
|
end
|
|
|
|
end
|
2016-11-04 14:48:58 -04:00
|
|
|
|
|
|
|
context 'when target branch is different than source branch' do
|
|
|
|
let(:target_branch) { "#{project.default_branch}-new" }
|
|
|
|
|
|
|
|
it 'fires hooks only once' do
|
|
|
|
expect(GitHooksService).to receive(:new).once.and_call_original
|
|
|
|
|
|
|
|
subject.execute
|
|
|
|
end
|
|
|
|
end
|
2016-08-07 23:29:23 -04:00
|
|
|
end
|
|
|
|
end
|