Skip to content

Commit

Permalink
Add CONTRIBUTING.md
Browse files Browse the repository at this point in the history
  • Loading branch information
ilesoft committed Mar 11, 2024
1 parent b2ed681 commit f28d853
Showing 1 changed file with 59 additions and 0 deletions.
59 changes: 59 additions & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
# Kipan kehittäminen

Tämä tiedosto sisältää periaatteita ja ohjeita, joiden mukaan Kipaa olisi hyvä kehittää eteenpäin. Ohjeet ja periaatteet elävät ajassa, niistä pitää keskustella ja niihin voidaan tarvittaessa tehdä muutoksia ja laajennuksia.

## Kieli

Koodissa, kommenteissa, commiteissa ja tiedostonimissä olisi hyvä pyrkiä käyttämään englantia. Englanti on luonteva valinta jo pelkästään Pythonin englantimaisuuden takia. Koodi tosin on monessa kohtaa suomen kielellä, eikä sitä välttämättä erikseen tarvitse lähteä kääntämään. Joitakin termejä voi olla helpompi käsitellä suomeksi.

Pull requesteissa, issueissa, katselmoinneisssa, käyttöliittymässä, dokumentaatiossa ja julkaisutiedotteissa käytetään suomea.

## Versionhallinta

Lyhyt ohje git-versionhallinan käyttämisestä niin, että historiasta tulisi mahdollisimman hyödyllinen.

### Yleistä

Ominaisuudet tai muut kokonaisuudet toteutetaan omissa haaroissaan ja sitten haarasta tehdään PR katselmointia varten.

Mahdolliset viitteet tiketöintijärjestelmän tiketteihin tai PR:iin ovat tärkeitä. Kun PR mergetään masteriin on merge-commitin otsikon hyvä olla muotoa `#<PR-numero> <Kuvaus kokonaisuudesta>`. Merge-committeja ei ole fiksua jättää gitin ehdottamiksi "Merge pull request #42 'user/feature-fix-stuff'", sillä haaran nimi saattaa olla PR:n valmistuessa katselmoitavaksi jo vanhentunut. Commitin tietää merge-commitiksi vaikkei sitä commit-viestin otsikossa lukisikaan.

### Haarat

Käytössä on kolme jatkuvaa haaraa:

* `master`: Julkaisukelpoinen koodi.
* `develop`: Kehityksessä käytettävä haara. pull requestien kohde. Mergetään masteriin tehtäessä uutta julkaisua.
* `gh-pages`: Kipan verkkosivujen sisältö.

### Merge

PR mergetään erillisen merge-commitin kanssa. Näin saadaan eroteltua kahden eri tason loogiset muutokset.

Koodin tasolla loogiset yhteen kuuluvat muutokset muodostavat commitin. Kehitettävä _ominaisuus_ taas on kehitettävän järjestelmän tasolla looginen muutos, joka muodostuu commiteista ja ilmenee useimmiten PR:änä. Näitä kahta erottelun tasoa ei pidä seikoittaa keskenään squashaamalla committeja, jolloin tieto committien sisällöstä jäisi yksinomaan GitHubiin.

Ominaisuuden ollessa valmis katselmoitavaksi se rebasetaan kohdehaaraan (useimmiten develop). Tämä tehdään jotta vältytään tekemästä kohdehaarasta kohti ominaisuushaaraa tehtäviä mergejä. Rebasella saadaan myös aikaiseksi "lineaarinen" historia, jota on helpompi ymmärtää ja siitä luodut graafit ovat kauniimpia.

Ominaisuus valmis katselmoitavaksi:

* 19e9c5d (feature) Add integration test
* 0825abc Add feature logic
* 9247ab4 Refactor foo to do bar
/
* 328ac08 Add main.py
* 9659eb1 initial commit

Ominaisuus mergetään `git merge --no-ff feature`:

* 48b55b6 (HEAD -> develop) #42 Add feature
|\
| * cbde34c (feature) Add integration test
| * 0825abc Add feature logic
| * 9247ab4 Refactor foo to fo bar
|/
* 328ac08 Add main.py
* 9659eb1 initial commit

Tätä merge-strategiaa kutsutaan nimellä "semi linear merge". Azure DevOps:issa voi tämän strategian asettaa käyttöön repositoriotasolla, mutta githubissa ei ole erillistä toimintoa tätä varten.

Mikäli PR muodostuu vain yhdestä commitista, jää merge-commitin tehtäväksi lähinnä viittaaminen githubin PR:ään ja mahdollisiin tiketteihin.

0 comments on commit f28d853

Please sign in to comment.