Деплоим из Github в репозиторий плагинов WordPress.org

Владислав Белецкий
Владислав Белецкий .
Категория:
Комментариев: 0

github-to-wordpress-plugin-svn[1]

Недавно при работе над плагином для WordPress, расположенном в репозитории плагинов WordPress.org, в виду того, что Github мы используем в качестве системы контроля версий и она нам очень нравится и мы повсеместно ее используем, мы устали постоянно держать локальную копию SVN и делать все вручную.

После некоторого времени гугления мы неожиданно нашли баш скрипт, который позволяет вам разворачивать прямо из репозитория Github без необходимости держать локальную копию репозитория SVN, и достаточно просто добавить скрипт ниже в ваш репозиторий Github, изменить несколько строк в скрипте и затем выполнять его тогда, когда вам нужно деплоить в репозиторий плагинов WordPress.org.

Авторство скрипта не нашел, по сути он был создан одним из разработчиков WooCommerce, Brent Shepherd, его авторство также у расширения WooCommerce Subscriptions.

Для того, чтобы деплоить прямо из вашего репозитория Github в SVN репозиторий плагинов WordPress.org, просто скопируйте баш скрипт ниже и поместите его в новый файл в вашем репозитории Github. Мы используем deploy.sh, как только файл появится, можно его закомитить и он будет частью вашего плагина, затем открыть файл и отредактировать следующие параметры.

PLUGINSLUG – Измените это на slug плагина на WordPress.org
MAINFILE – Измените это на основной файл PHP, который содержит номер версии WordPress плагина
SVNUSER – Измените это на имя пользователя на WordPress.org пользователя, которому принадлежит этот плагин, под этим именем будет сделать коммит.

Вот и все. После изменений в файле необходимо сделать его исполняемым (chmod u+x deploy.sh) через терминал, и затем можно использовать для деплоя. Переходим в ваш репозиторий Github, где у вас хранится файл deploy.sh и выполнить следующую команду в терминале ./deploy.sh

Скрипт задаст вам несколько вопросом во время своего выполнения, а также сделаем несколько проверок.

#! /bin/bash
# Модификация скрипта Dean Clatworthy'а, найденного здесь: https://github.com/deanc/wordpress-plugin-git-svn
# Различие только в том, что этот скрипт живет в git-репозитории плагина и не требует существующего репозитория SVN.
 
# main config
PLUGINSLUG="camptix-payfast-gateway"
CURRENTDIR=`pwd`
MAINFILE="camptix-payfast.php" # this should be the name of your main php file in the wordpress plugin
 
# git config
GITPATH="$CURRENTDIR/" # this file should be in the base of your git repository
 
# svn config
SVNPATH="/tmp/$PLUGINSLUG" # path to a temp SVN repo. No trailing slash required and don't add trunk.
SVNURL="http://plugins.svn.wordpress.org/$PLUGINSLUG/" # Remote SVN repo on wordpress.org, with no trailing slash
SVNUSER="Kloon" # your svn username
 
 
# Let's begin...
echo ".........................................."
echo 
echo "Preparing to deploy wordpress plugin"
echo 
echo ".........................................."
echo 
 
# Check version in readme.txt is the same as plugin file after translating both to unix line breaks to work around grep's failure to identify mac line breaks
NEWVERSION1=`grep "^Stable tag:" $GITPATH/readme.txt | awk -F' ' '{print $NF}'`
echo "readme.txt version: $NEWVERSION1"
echo "$GITPATH$MAINFILE"
NEWVERSION2=`grep "Version:" $GITPATH$MAINFILE | awk -F' ' '{print $NF}'`
echo "$MAINFILE version: $NEWVERSION2"
 
if [ "$NEWVERSION1" -ne "$NEWVERSION2" ]; then echo "Version in readme.txt & $MAINFILE don't match. Exiting...."; exit 1; fi
 
echo "Versions match in readme.txt and $MAINFILE. Let's proceed..."
 
if git show-ref --tags --quiet --verify -- "refs/tags/$NEWVERSION1"
    then 
		echo "Version $NEWVERSION1 already exists as git tag. Exiting...."; 
		exit 1; 
	else
		echo "Git version does not exist. Let's proceed..."
fi
 
cd $GITPATH
echo -e "Enter a commit message for this new version: c"
read COMMITMSG
git commit -am "$COMMITMSG"
 
echo "Tagging new version in git"
git tag -a "$NEWVERSION1" -m "Tagging version $NEWVERSION1"
 
echo "Pushing latest commit to origin, with tags"
git push origin master
git push origin master --tags
 
echo 
echo "Creating local copy of SVN repo ..."
svn co $SVNURL $SVNPATH
 
echo "Exporting the HEAD of master from git to the trunk of SVN"
git checkout-index -a -f --prefix=$SVNPATH/trunk/
 
echo "Ignoring github specific files and deployment script"
svn propset svn:ignore "deploy.sh
README.md
.git
.gitignore" "$SVNPATH/trunk/"
 
echo "Changing directory to SVN and committing to trunk"
cd $SVNPATH/trunk/
# Add all new files that are not set to be ignored
svn status | grep -v "^.[ t]*..*" | grep "^?" | awk '{print $2}' | xargs svn add
svn commit --username=$SVNUSER -m "$COMMITMSG"
 
echo "Creating new SVN tag & committing it"
cd $SVNPATH
svn copy trunk/ tags/$NEWVERSION1/
cd $SVNPATH/tags/$NEWVERSION1
svn commit --username=$SVNUSER -m "Tagging version $NEWVERSION1"
 
echo "Removing temporary directory $SVNPATH"
rm -fr $SVNPATH/
 
echo "*** FIN ***"

По всем вопросам и отзывам просьба писать в комментарии ниже.

Не забывайте, по возможности, оценивать понравившиеся записи количеством звездочек на ваше усмотрение.

VN:F [1.9.22_1171]

Подписаться
Уведомить о
guest
0 комментариев
Межтекстовые Отзывы
Посмотреть все комментарии