У меня есть веб-перехватчик «после нажатия» на 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
, Я обычно снова получаю тот же результат, и сайт правильно обновляется.
Если я внесу изменения в локальную копию, веб-ловушка по-прежнему будет работать (хотя и не должна), а версия в командной строке покажет соответствующее сообщение о перезаписи локальных изменений.
Что могло вызвать это?