Commit ca7c80ce authored by Yorick Peterse's avatar Yorick Peterse

Merge branch 'fix-ionice' into 'master'

Fix short circuit logic between rsync with and without ionice for storage migrations

See merge request !96
parents fad9498c 9dc7a119
v3.6.4
- Fix short circuit logic between rsync with and without ionice for storage migrations
v3.6.3 v3.6.3
- Re-exposing GL_ID to custom hooks - Re-exposing GL_ID to custom hooks
......
...@@ -321,7 +321,9 @@ class GitlabProjects ...@@ -321,7 +321,9 @@ class GitlabProjects
rsync_path = 'ionice -c2 -n7 rsync' rsync_path = 'ionice -c2 -n7 rsync'
result = system(*%W(#{rsync_path} -a --delete --rsync-path="#{rsync_path}" #{source_path} #{new_full_path})) result = system(*%W(#{rsync_path} -a --delete --rsync-path="#{rsync_path}" #{source_path} #{new_full_path}))
unless result if result
true
else
# If the command fails with `ionice` (maybe because we're on a OS X # If the command fails with `ionice` (maybe because we're on a OS X
# development machine), try again without `ionice`. # development machine), try again without `ionice`.
rsync_path = 'rsync' rsync_path = 'rsync'
......
...@@ -227,6 +227,41 @@ describe GitlabProjects do ...@@ -227,6 +227,41 @@ describe GitlabProjects do
FileUtils.cd(new_repo_path) { Dir['**/*'].length.should_not be(0) } FileUtils.cd(new_repo_path) { Dir['**/*'].length.should_not be(0) }
end end
it "should attempt rsync with ionice first" do
expect(gl_projects).to receive(:system).with(
'ionice -c2 -n7 rsync', '-a', '--delete', '--rsync-path="ionice -c2 -n7 rsync"',
"#{tmp_repo_path}/", new_repo_path
).and_return(true)
gl_projects.exec.should be_true
end
it "should attempt rsync without ionice if with ionice fails" do
expect(gl_projects).to receive(:system).with(
'ionice -c2 -n7 rsync', '-a', '--delete', '--rsync-path="ionice -c2 -n7 rsync"',
"#{tmp_repo_path}/", new_repo_path
).and_return(false)
expect(gl_projects).to receive(:system).with(
'rsync', '-a', '--delete', '--rsync-path="rsync"', "#{tmp_repo_path}/", new_repo_path
).and_return(true)
gl_projects.exec.should be_true
end
it "should fail if both rsync attempts fail" do
expect(gl_projects).to receive(:system).with(
'ionice -c2 -n7 rsync', '-a', '--delete', '--rsync-path="ionice -c2 -n7 rsync"',
"#{tmp_repo_path}/", new_repo_path
).and_return(false)
expect(gl_projects).to receive(:system).with(
'rsync', '-a', '--delete', '--rsync-path="rsync"', "#{tmp_repo_path}/", new_repo_path
).and_return(false)
gl_projects.exec.should be_false
end
it "should fail if no destination path is provided" do it "should fail if no destination path is provided" do
incomplete = build_gitlab_projects('mv-storage', tmp_repos_path, repo_name) incomplete = build_gitlab_projects('mv-storage', tmp_repos_path, repo_name)
$logger.should_receive(:error).with("mv-storage failed: no destination storage path provided.") $logger.should_receive(:error).with("mv-storage failed: no destination storage path provided.")
......
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