summaryrefslogtreecommitdiff
path: root/lib/gitlab/satellite/satellite.rb
diff options
context:
space:
mode:
Diffstat (limited to 'lib/gitlab/satellite/satellite.rb')
-rw-r--r--lib/gitlab/satellite/satellite.rb12
1 files changed, 10 insertions, 2 deletions
diff --git a/lib/gitlab/satellite/satellite.rb b/lib/gitlab/satellite/satellite.rb
index 164af55d895..d8e8f58963b 100644
--- a/lib/gitlab/satellite/satellite.rb
+++ b/lib/gitlab/satellite/satellite.rb
@@ -3,6 +3,8 @@ module Gitlab
module Satellite
class Satellite
+ include Gitlab::Popen
+
PARKING_BRANCH = "__parking_branch"
attr_accessor :project
@@ -24,8 +26,10 @@ module Gitlab
end
def create
- create_cmd = "git clone #{project.url_to_repo} #{path}"
- if system(create_cmd)
+ output, status = popen("git clone #{project.url_to_repo} #{path}",
+ Gitlab.config.satellites.path)
+
+ if status.zero?
true
else
Gitlab::GitLogger.error("Failed to create satellite for #{project.name_with_namespace}")
@@ -66,6 +70,10 @@ module Gitlab
@repo ||= Grit::Repo.new(path)
end
+ def destroy
+ FileUtils.rm_rf(path)
+ end
+
private
# Clear the working directory