-
Notifications
You must be signed in to change notification settings - Fork 13
Getting Started
Die vorliegende Anleitung führt durch die Installation der Entwicklungsumgebung bis zur Ausführung der automatisierten Tests der Wingolfsplattform.
Betriebsystem:
- Aufgrund ihrer aktuellen Popularität geht diese Anleitung exemplarisch von einer frischen Installation der Linux-Distribution Ubuntu aus.
- Tipps für Arch Linux
- Tipps für Gentoo
- Tipps für Mac OS
- Tipps für Umgebung mit Docker
Hier eine kurze Auswahl einführender Literatur zur Versionsverwaltungs-Software git und zum Ruby-on-Rails-Framework, die helfen soll, sich überblicksartig mit diesen Werkzeugen vertraut zu machen.
- http://try.github.com/
- http://gitreal.codeschool.com/
- https://help.github.com/articles/set-up-git
- http://git-scm.com/book/ch1-3.html
- http://tryruby.org/ (Interaktiv)
- http://railscasts.com/episodes/310-getting-started-with-rails
- http://ruby.railstutorial.org/ruby-on-rails-tutorial-book
- http://guides.rubyonrails.org/getting_started.html
Unter Ubuntu wird git wie folgt installiert.
# bash
sudo apt install git
Bevor fortgefahren wird, ist es wichtig, dass git korrekt konfiguriert wird. Insbesondere ist es wichtig, die Daten zur eigenen Identifikation anzugeben, damit andere Entwickler sehen können, wer welche Änderungen am Code vorgenommen hat.
# bash
# Identifikation:
git config --global user.name 'Your Name'
git config --global user.email '[email protected]'
# Empfohlene Befehls-Kürzel:
git config --global alias.st status
git config --global alias.ci commit
git config --global alias.co checkout
git config --global alias.br branch
git config --global alias.graph 'log --oneline --decorate --graph'
git config --global alias.last 'log -1 HEAD'
# Weitere Konfiguration:
git config --global core.editor 'emacs' # or 'vi' or 'nano' or 'gedit' or your favorite editor.
git config --global color.branch auto
git config --global color.diff auto
git config --global color.interactive auto
git config --global color.status auto
Zum Zugriff auf das Repository auf Github ist ein Github-Account erforderlich, der hier angelegt werden kann.
Der Zugriff auf die Repositories erfolgt über das SSH-Protokoll. Zum einfacheren Zugriff sollte ein SSH-Key erzeugt und bei Github hinterlegt werden:
# bash
ssh-keygen -t rsa -C "[email protected]"
Der so erzeugte Schlüssel kann mit cat .ssh/id_rsa.pub
angezeigt werden. Der so angezeigte Schlüssel muss dann auf https://github.com/settings/ssh kopiert werden.
Weitere Informationen: https://help.github.com/articles/generating-ssh-keys
Der Quellcode der Wingolfsplattform ist in zwei Teile aufgeteilt. In "YourPlatform", dem größeren Teil, befindet sich die Plattform so weit, wie sie auch von anderen Organisationen genutzt werden kann. In "Wingolfsplattform" befinden sich lediglich die Wingolfs-Spezifika, z.B. die Definition von Aktivitätszahlen oder Bezirksverbänden.
Um an der Plattform mitzuentwickeln, erstellt man zunächst jeweils einen Github-Fork der beiden Projekte:
Danach wird das Projekt auf die lokale Entwicklungsmaschine geklont:
# bash
mkdir ~/rails
cd ~/rails
git clone [email protected]:your-username/wingolfsplattform.git
git clone [email protected]:your-username/your_platform.git
Damit wird das Code-Repository der Wingolfsplattform in das lokale Verzeichnis ~/rails/wingolfsplattform
kopiert. Die YourPlatform-Engine, die den Großteil des Codes enthält, wird nach ~/rails/your_platform
geklont.
Um die Applikation lokal auszuführen, wird eine Reihe von Hilfspaketen benötigt. Unter Ubuntu beispielsweise können diese mit apt-get install
installiert werden.
# bash
sudo apt install libssl-dev g++ libxml2 libxslt-dev libreadline-dev libicu-dev imagemagick libmagick-dev pwgen
Andere Systeme:
Wir empfehlen die Verwendung von rbenv, einer Software zur Verwaltung verschiedener Ruby-Versionen auf einer Entwicklungsmaschine.
# bash
sudo apt install rbenv ruby-build ruby-dev
rbenv init
echo 'eval "$(rbenv init -)"' >> ~/.bashrc
bash
Aktuell verwenden wir jeweils die Ruby-Version, die in der Datei .ruby-version angegeben ist.
# bash
rbenv install 2.3.3
rbenv global 2.3.3
ruby --version
Docker installieren:
# bash
sudo apt install docker.io docker-compose
Den Benutzer in die Docker-Gruppe eintragen, damit man Docker steuern kann:
# bash
sudo addgroup --system docker
sudo adduser $USER docker
newgrp docker
sudo snap disable docker
sudo snap enable docker
Danach neu einloggen, damit man Mitglied der Gruppe wird.
Als Orchestrierungswerkzeug verwenden wir Docker-Compose. Wenn die oben installierte Version zu alt sein sollte, kann man wie folgt eine neuere nachinstallieren:
# bash
docker-compose --version
sudo curl -o /usr/local/bin/docker-compose -L "https://github.com/docker/compose/releases/download/1.15.0/docker-compose-$(uname -s)-$(uname -m)"
sudo chmod +x /usr/local/bin/docker-compose
Quelle: https://www.digitalocean.com/community/tutorials/how-to-install-docker-compose-on-ubuntu-16-04
# bash
sudo apt install mysql-server libmysql++-dev libmysqlclient-dev
# bash
mysql_secure_installation
Hierbei sollte ein Passwort für den Datenbank-Root-Benutzer generiert werden (standardmäßig leer).
Ein neues Passwort kann hierbei beispielsweise mit pwgen 20
generiert werden. (Sonderzeichen bereiten unter Umständen Probleme. Daher nicht die pwgen
-Option -y
verwenden.)
Für die restlichen Einstellungen kann jeweils der Standard-Option gefolgt werden.
Als Vorlage für die Datenbank-Konfiguration liegt dem Repository eine Beispiel-Datei bei:
# bash
cp config/database.yml.example config/database.yml
Die in der MySQL-Konfiguration angegebenen Benutzerdaten für den root
-Datenbankbenutzer können nun direkt in der Datenbank-Konfiguration der Applikation angegeben werden.
# config/database.yml
# ...
development:
adapter: mysql2
encoding: utf8
reconnect: false
database: wingolfsplattform_development
pool: 5
username: root
password: YOUR PASSWORD HERE
host: localhost
test:
adapter: mysql2
encoding: utf8
reconnect: false
database: wingolfsplattform_test
pool: 5
username: root
password: YOUR PASSWORD HERE
host: localhost
Weitere Schritte:
- Wenn lokal auch andere Anwendungen MySQL verwenden, sollte ein eigener Datenbank-Benutzer für die Wingolfsplattform erstellt werden.
- Falls das Root-Passwort zurückgesetzt werden muss, findet sich hier eine Anleitung.
Zum Caching und für Worker-Abläufe verwenden wir eine Redis-Datenbank. Es muss also zunächst redis installiert werden:
# bash
sudo apt install redis-server
Als Graph-Datenbank verwenden wir Neo4j.
Neo4j betreiben wir als Docker-Container, sodass Neo4j nicht manuell installiert und eingerichtet werden muss, sondern lediglich das Repository mit der entsprechenden Konfiguration geklont werden muss:
# bash
cd ~/rails
git clone [email protected]:fiedl/wingolfsplattform-docker.git
Damit kann Neo4j dann gestartet werden, am Besten in einem separaten Terminal-Tab.
# bash
cd ~/rails/wingolfsplattform-docker
docker-compose up wingolfsplattform_neo4j wingolfsplattform_neo4j_test
Durch das obige Kommando werden zwei Neo4j-Datenbank-Services gestartet, einer für die Entwicklungsumgebung und einer für die automatisierten Tests.
Testhalber kann http://localhost:7474/ im Browser öffnen (Benutzer: neo4j, Passwort: trinity), um sich die (noch leere) Graph-Datenbank anzusehen.
Damit auch die Plattform weiß, wie sie sich zu Neo4j verbinden soll, müssen noch zwei Umgebungsvariablen gesetzt werden:
# bash
echo 'export NEO4J_REST_URL_TEST="http://neo4j:trinity@localhost:7475/"' >> ~/.bashrc
echo 'export NEO4J_REST_URL="http://neo4j:trinity@localhost:7474/"' >> ~/.bashrc
Ruby bringt eine eigene Paketverwaltung mit, mit deren Hilfe schnell die Ruby-Pakete installiert werden können, die für ein Projekt notwendig sind. Die nötigen Pakete sind in der Datei Gemfile spezifiziert und können mit dem Bundler installiert werden. Der Bundler muss hierzu vorher wie folgt installiert werden:
# bash
cd ~/rails/wingolfsplattform
gem install bundler
rbenv rehash
Damit die lokale Entwicklungsversion der Wingolfsplattform weiß, dass sie auch den lokalen Quellcode von YourPlatform verwenden soll:
# bash
cd ~/rails/wingolfsplattform
bundle config local.your_platform ~/rails/your_platform
Nachdem der Bundler installiert ist, können die jeweils aktuellen Pakete für die Wingolfsplattform wie folgt installiert werden:
# bash
cd ~/rails/wingolfsplattform
bundle install
NodeJS installieren:
# bash
sudo apt install build-essential libssl-dev
curl -sL https://deb.nodesource.com/setup_7.x | sudo bash
sudo apt install nodejs
node --version
Node-Package-Manager installieren:
# bash
sudo apt install npm
Yarn installieren:
# bash
npm i -g yarn
Geheime Informationen wie SMTP-Passwörter, API-Schlüssel zu externen Anwendungen werden in config/secrets.yml
gespeichert. Für die lokale Entwicklungsumgebung braucht man nur einen Schlüssel, nämlich secret_key_base
, das zur Verschlüsselung verwendet wird.
Man braucht zwei Schlüssel: Einen für die Entwicklungsumgebung, einen für die Test-Umgebung. Einfach mit pwgen 100
erstellen.
Die beiden Schlüssel fügt man dann in die Datei config/secrets.yml
ein:
# ~/rails/wingolfsplattform/config/secrets.yml
development:
secret_key_base: your-secret-key-base-for-development-here
test:
secret_key_base: your-secret-key-base-for-testing-here
# bash
cd ~/rails/wingolfsplattform
# create database
bundle exec rake db:create db:migrate
# bash
cd ~/rails/wingolfsplattform
bundle exec rake db:test:prepare
bundle exec rake
Wenn alles gut geht, sollten die Tests nach einigen Minuten mit 0 failures
abschließen.
# bash
cd ~/rails/wingolfsplattform
bundle exec rails server
Dieser Server-Prozess muss im Hintergrund weiter laufen. Es bietet sich an, ihn in einem eigenen Terminal-Tab zu starten, um die Debug-Meldungen dort lesen zu können.
Nach Start des Servers ist die lokale Anwendung im Browser unter der Url http://localhost:3000 erreichbar.
Um sich im Browser am System anzumelden, muss zunächst ein Benutzer erstellt werden:
# bash
cd ~/rails/wingolfsplattform
bundle exec rails console
# rails console
user = User.create( first_name: "Your First Name", last_name: "Your Last Name", email: "[email protected]", alias: "your.username" )
user.activate_account
user.global_admin = true
Ein Passwort wird an die angegebene Adresse per E-Mail übermittelt.
-
Sollte beim Öffnen der Rails-Console ein Fehler bezüglich Readline angezeigt werden ("uninitialized constant IRB::ReadlineInputMethod::Readline (NameError)"), muss die Ruby-Version erneut installiert werden (oben wurde rb-readline via bundler installiert, da dieses Ruby-Paket im Gemfile vorkommt.):
rbenv install 2.0.0-p247 CONFIGURE_OPTS="--with-readline-dir=/usr/include/readline"
. -
Manuelles Setzen des Passwortes: Es ist ein Passwort mit mindestens 8 Zeichen erforderlich.
# rails console
user = User.first
account = user.account
account.password = "my_secret!password"
account.save
-
E-Mail kommt nicht an: Überprüfen, ob in
/var/log/mail.err
der FehlerMy unqualified host name unknown
gemeldet wird, lässt sich das Problem beheben, indem die/etc/hosts
korrigiert wird: Es darf nur eine Zeile mit127.0.0.1
beginnen. Siehe auch: http://serverfault.com/questions/58363
Die Anwendung verwendet Worker-Prozesse, die im Hintergrund Aufgaben ausführen, etwa E-Mails bearbeiten.
Die Liste der Hintergrund-Worker-Prozesse befindet sich in der Datei Procfile im Repository. Zur Verwaltung der Worker wird foreman verwendet.
Um die Worker auf der lokalen Entwicklungsmaschine zu starten bzw. zu stoppen, sind folgende Kommandos möglich:
# bash (auf der Entwicklungsmaschine)
cd ~/rails/wingolfsplattform
foreman start # Worker starten
foreman stop # Worker ausschalten. Oder: Ctrl+C.
Auf dem Produktiv-Server erzeugt das Deployment-Skript einen Service wingolfsplattform-workers
, der die Foreman-Worker in Procfile startet. Dieser Service wird seinerseits von monit verwaltet.
Bei der Arbeit in der Shell ist es hilfreich, den aktuellen Git-Branch anzeigen zu lassen. Beispielsweise:
# ~/.bashrc
# ...
PS1='\n\u@\h:\w$(__git_ps1 " (%s)")\$ '
Um stets sicherzustellen, dass die gems in der für das Projekt richtigen Version verwendet werden, wird jeder Aufruf von Ruby-Skripten mit bundle exec
gepräfixt, z.B. bundle exec rails server
, bundle exec rails console
oder bundle exec guard
. Um Schreibaufwand zu sparen, ohne aber Bin-Stubs installieren zu müssen, empfiehlt sich ein entsprechender Kurzbefehl-Alias:
# ~/.bashrc
# ...
alias be='bundle exec'
alias bi='bundle install'
alias bu='bundle update'
Es empfiehlt sich Kurzbefehle für häufig verwendete Pfade anzulegen, um beispielsweise mit dem Kurzbefehl cdw
ins Verzeichnis ~/rails/wingolfsplattform
zu wechseln.
# ~/.bashrc
# ...
alias cdw='cd ~/rails/wingolfsplattform'
alias cdy='cd ~/rails/wingolfsplattform/vendor/engines/your_platform'
alias cda='cd ~/rails/wingolfsplattform/vendor/engines/your_platform/app/assets/javascripts/'
- Editor-Einstellungen für
vim
- Mac OS: Am Besten Textmate verwenden!