Commit c8a713cb authored by Dmitriy Zaporozhets's avatar Dmitriy Zaporozhets

Add support for import repo timeout

Signed-off-by: default avatarDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
parent 3df55367
......@@ -36,8 +36,12 @@ Remove repo
Import repo
# Default timeout is 2 minutes
./bin/gitlab-projects import-project randx/six.git https://github.com/randx/six.git
# Override timeout in seconds
./bin/gitlab-projects import-project randx/six.git https://github.com/randx/six.git 90
Fork repo
./bin/gitlab-projects fork-project gitlab/gitlab-ci.git randx
......
require 'fileutils'
require 'timeout'
require_relative 'gitlab_config'
require_relative 'gitlab_logger'
......@@ -92,9 +93,23 @@ class GitlabProjects
# URL must be publicly cloneable
def import_project
@source = ARGV.shift
# timeout for clone
timeout = (ARGV.shift || 120).to_i
$logger.info "Importing project #{@project_name} from <#{@source}> to <#{full_path}>."
cmd = %W(git clone --bare -- #{@source} #{full_path})
system(*cmd) && self.class.create_hooks(full_path)
begin
Timeout.timeout(timeout) do
system(*cmd)
end
rescue
$logger.error "Importing project #{@project_name} from <#{@source}> failed due to timeout."
FileUtils.rm_rf(full_path)
false
else
self.class.create_hooks(full_path)
end
end
# Move repository from one directory to another
......
......@@ -196,8 +196,11 @@ describe GitlabProjects do
end
describe :import_project do
context 'success import' do
let(:gl_projects) { build_gitlab_projects('import-project', repo_name, 'https://github.com/randx/six.git') }
it { gl_projects.exec.should be_true }
it "should import a repo" do
gl_projects.exec
File.exists?(File.join(tmp_repo_path, 'HEAD')).should be_true
......@@ -210,6 +213,24 @@ describe GitlabProjects do
end
end
context 'timeout' do
let(:gl_projects) { build_gitlab_projects('import-project', repo_name, 'https://dev.gitlab.org/samples/private.git', '1') }
it { gl_projects.exec.should be_false }
it "should not import a repo" do
gl_projects.exec
File.exists?(File.join(tmp_repo_path, 'HEAD')).should be_false
end
it "should log an import-project event" do
message = "Importing project #{repo_name} from <https://dev.gitlab.org/samples/private.git> failed due to timeout."
$logger.should_receive(:error).with(message)
gl_projects.exec
end
end
end
describe :fork_project do
let(:source_repo_name) { File.join('source-namespace', repo_name) }
let(:dest_repo) { File.join(tmp_repos_path, 'forked-to-namespace', repo_name) }
......
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