Ce document a pour but de donner les clés pour créer un environnement de développement correct afin de développer sur le cœur de YunoHost. Il peut également vous permettre de tester vos applications que ce soit avec les versions stable
, testing
, unstable
ou même des versions customisées issues des branches des dépôts.
Installer, avec le gestionnaire de paquet de votre système d’exploitation, Vagrant ou Docker suivant celui que vous souhaitez utiliser.
# Debian, Ubuntu, Mint
sudo apt-get install docker vagrant
# Fedora
sudo dnf install docker vagrant vagrant-libvirt
Une ligne de commande ynh-dev
a été créée afin de simplifier la gestion de votre environnement de développement.
wget https://raw.githubusercontent.com/yunohost/ynh-dev/master/ynh-dev
chmod u+x ynh-dev
Pour créer votre environnement, commencez par faire un create-env
./ynh-dev create-env ~/project/my/yunohost/env
Cette sous commande va cloner les dépôts principaux au fonctionnement de YunoHost et les positionner en unstable
. Si vous avez vos propres fork, vous pouvez ensuite faire ce qu’il faut pour changer l’origine et le remote repository.
Positionner vous dans votre environnement, puis créer et entrer dans une vm à l’aide de ynh-dev run
cd ~/project/my/yunohost/env
./ynh-dev run exemple.local docker stable8
root@yunohost:/# cd yunohost
root@yunohost:/yunohost/# ls
Dockerfile LICENSE README.md SSOwat apps backup moulinette ynh-dev yunohost yunohost-admin yunohost-vagrant
Si la vm n’est pas à jour lancez un ynh-dev upgrade
:
root@yunohost:/yunohost/# ./ynh-dev upgrade
Pour déployer les sources se trouvant dans votre environnement de développement faites :
root@yunohost:/yunohost/# ./ynh-dev deploy
Avec Docker
root@yunohost:/yunohost/# postinstall
Avec VirtualBox/Vagrant
root@yunohost:/yunohost/# yunohost tools postinstall
si vous ne connaissez pas l’IP de votre vm :
root@yunohost:/yunohost/# ./ynh-dev ip
172.17.0.1
Pour tester dans votre navigateur vous pouvez modifier votre fichier /etc/hosts
afin de faire pointer votre domaine sur la bonne adresse IP. Par exemple en y ajoutant une ligne semblable à celle-ci :
172.17.0.1 exemple.local
root@yunohost:/yunohost/# ./ynh-dev watch
Astuce : dans le cas de modification sur yunohost-admin, cette commande est très pratique couplée avec un gulp watch
sur la machine hôte.