Commit 92aa4028 authored by Lin Jen-Shin's avatar Lin Jen-Shin

Add a test to make sure hooks are fire only once

when updating a file to a different branch.
parent 4b20cb5d
...@@ -6,7 +6,10 @@ describe Files::UpdateService do ...@@ -6,7 +6,10 @@ describe Files::UpdateService do
let(:project) { create(:project) } let(:project) { create(:project) }
let(:user) { create(:user) } let(:user) { create(:user) }
let(:file_path) { 'files/ruby/popen.rb' } let(:file_path) { 'files/ruby/popen.rb' }
let(:new_contents) { "New Content" } let(:new_contents) { 'New Content' }
let(:target_branch) { project.default_branch }
let(:last_commit_sha) { nil }
let(:commit_params) do let(:commit_params) do
{ {
file_path: file_path, file_path: file_path,
...@@ -16,7 +19,7 @@ describe Files::UpdateService do ...@@ -16,7 +19,7 @@ describe Files::UpdateService do
last_commit_sha: last_commit_sha, last_commit_sha: last_commit_sha,
source_project: project, source_project: project,
source_branch: project.default_branch, source_branch: project.default_branch,
target_branch: project.default_branch, target_branch: target_branch
} }
end end
...@@ -54,18 +57,6 @@ describe Files::UpdateService do ...@@ -54,18 +57,6 @@ describe Files::UpdateService do
end end
context "when the last_commit_sha is not supplied" do context "when the last_commit_sha is not supplied" do
let(:commit_params) do
{
file_path: file_path,
commit_message: "Update File",
file_content: new_contents,
file_content_encoding: "text",
source_project: project,
source_branch: project.default_branch,
target_branch: project.default_branch,
}
end
it "returns a hash with the :success status " do it "returns a hash with the :success status " do
results = subject.execute results = subject.execute
...@@ -80,5 +71,15 @@ describe Files::UpdateService do ...@@ -80,5 +71,15 @@ describe Files::UpdateService do
expect(results.data).to eq(new_contents) expect(results.data).to eq(new_contents)
end end
end end
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
end end
end end
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