Commit 047dcb86 authored by Angus MacArthur's avatar Angus MacArthur

additional fork check and enhanced tests

parent 934aacb3
...@@ -86,11 +86,16 @@ class GitlabProjects ...@@ -86,11 +86,16 @@ class GitlabProjects
def fork_project def fork_project
new_namespace = ARGV.shift new_namespace = ARGV.shift
# destination namespace must be provided
return false unless new_namespace return false unless new_namespace
#destination namespace must exist
namespaced_path = File.join(repos_path, new_namespace) namespaced_path = File.join(repos_path, new_namespace)
return false unless File.exists?(namespaced_path) return false unless File.exists?(namespaced_path)
#a project of the same name cannot already be within the destination namespace
full_destination_path = File.join(namespaced_path, project_name) full_destination_path = File.join(namespaced_path, project_name)
return false if File.exists?(full_destination_path)
cmd = "cd #{namespaced_path} && git clone --bare #{full_path} && #{create_hooks_to(full_destination_path)}" cmd = "cd #{namespaced_path} && git clone --bare #{full_path} && #{create_hooks_to(full_destination_path)}"
system(cmd) system(cmd)
......
...@@ -79,19 +79,30 @@ describe GitlabProjects do ...@@ -79,19 +79,30 @@ describe GitlabProjects do
describe :fork_project do describe :fork_project do
let(:gl_project_import) { build_gitlab_projects('import-project', repo_name, 'https://github.com/randx/six.git') } let(:gl_project_import) { build_gitlab_projects('import-project', repo_name, 'https://github.com/randx/six.git') }
let(:gl_projects) { build_gitlab_projects('fork-project', repo_name, 'forked-to-namespace')} let(:gl_projects_fork) { build_gitlab_projects('fork-project', repo_name, 'forked-to-namespace')}
let(:dest_repo) { File.join(tmp_repos_path, 'forked-to-namespace', repo_name) }
before do before do
FileUtils.mkdir_p(tmp_repo_path) FileUtils.mkdir_p(tmp_repo_path)
FileUtils.mkdir_p(File.join(tmp_repos_path, 'forked-to-namespace'))
gl_project_import.exec gl_project_import.exec
end end
it "should not fork into a namespace that doesn't exist" do
gl_projects_fork.exec.should be_false
end
it "should fork the repo" do it "should fork the repo" do
gl_projects.exec # create destination namespace
File.exists?(File.join(tmp_repos_path, 'forked-to-namespace', repo_name)).should be_true FileUtils.mkdir_p(File.join(tmp_repos_path, 'forked-to-namespace'))
File.exists?(File.join(tmp_repos_path, 'forked-to-namespace', repo_name, '/hooks/update')).should be_true gl_projects_fork.exec.should be_true
File.exists?(File.join(tmp_repos_path, 'forked-to-namespace', repo_name, '/hooks/post-receive')).should be_true File.exists?(dest_repo).should be_true
File.exists?(File.join(dest_repo, '/hooks/update')).should be_true
File.exists?(File.join(dest_repo, '/hooks/post-receive')).should be_true
end
it "should not fork if a project of the same name already exists" do
#trying to fork again should fail as the repo already exists
gl_projects_fork.exec.should be_false
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