Назад | Перейти на главную страницу

Git Pull в CGI и в командной строке дают разные результаты

У меня есть веб-перехватчик «после нажатия» на GitHub, который вызывает сценарий CGI для обновления веб-сайта Jekyll.

Сценарий:

user@server [~/_repo]# cat cgi-bin/githook.cgi
#!/bin/bash
echo Content-type: text/plain
echo

if [ -z "$HOME" ] ; then
HOME=/home/user
fi

GIT_REPO=$HOME/_repo
PUBLIC_WWW=$HOME/public_html

pushd $GIT_REPO
git pull
echo "$HOME/.rvm/bin/ts_jekyll build --source $GIT_REPO --destination $PUBLIC_WWW"
$HOME/.rvm/bin/ts_jekyll build --source $GIT_REPO --destination $PUBLIC_WWW
popd
echo DONE

GitHub сохраняет вывод скрипта как:

~/_repo ~/public_html/cgi-bin
Updating OLD_COMMIT_SHA..NEW_COMMIT_SHA
/home/user/.rvm/bin/ts_jekyll build --source /home/user/_repo/ --destination /home/user/public_html
Configuration file: /home/user/_repo/_config.yml
            Source: /home/user/_repo/
       Destination: /home/user/public_html
      Generating... 
                    done.
 Auto-regeneration: disabled. Use --watch to enable.
~/public_html/cgi-bin
DONE

Это ожидаемый результат, но сайт не обновляется.
Когда я вхожу в систему с помощью SSH и запускаю user@server [~]# _repo/cgi-bin/githook.cgi, Я обычно снова получаю тот же результат, и сайт правильно обновляется.

Если я внесу изменения в локальную копию, веб-ловушка по-прежнему будет работать (хотя и не должна), а версия в командной строке покажет соответствующее сообщение о перезаписи локальных изменений.

Что могло вызвать это?