Я написал очень простой скрипт 'deploy', работающий как мой post-update
хук внутри моего чистого репозитория git.
Переменные выглядят следующим образом
live domain = ~/mydomain.com
staging domain = ~/stage.mydomain.com
git repo location = ~/git.mydomain.com/thisrepo.git (bare)
core = ~/git.mydomain.com/thisrepo.git
core == added remote into each live & stage gits
оба live
& stage
инициализировал репозитории git (не голые), и я добавил свое голое репо в качестве удаленного к каждому из них (с именем core
), чтобы git pull core stage
или git pull core live
извлекали обновленные файлы изсоответствующий branch
репо core
.
Сценарий выглядит следующим образом:
#!/usr/bin/env ruby
# Loop over each passed in argument
ARGV.each do |branch|
# If it matches the stage then 'update' the staging files
if branch == "refs/heads/stage"
puts ""
puts "Looks like the staging branch was updated."
puts "Running a tree checkout now…"
puts ""
`cd ~/stage.mydomain.com`
`unset GIT_DIR` # <= breaks!
`git pull core stage`
puts ""
puts "Tree pull completed on staging branch."
puts ""
# If it's a live site update, update those files
elsif branch == "refs/heads/live"
puts ""
puts "Looks like the live branch was updated."
puts "Running a tree checkout now…"
puts ""
`cd ~/mydomain.com`
`unset GIT_DIR` # <= breaks!
`git pull core live`
puts ""
puts "Tree checkout completed on live branch."
puts ""
end
end
Я попытался адаптировать «обновление» файлов из этого сценария bash здесь, который использует unset GIT_DIR
для запуска следующей команды git git pull core stage
, например.core
- это добавленное remote
моего bare
репо в другой папке на сервере.
Однако при выполнении приведенного выше сценария появляются следующие ошибки:
remote: hooks/post-update:35: command not found: unset GIT_DIR
remote: fatal: /usr/lib/git-core/git-pull cannot be used without a working tree.
Есть ли способ сделать то же самое, что и unset GIT_DIR
в скрипте bash в моем скрипте ruby?
Большое спасибо,
Яннис