Skip to the content.

GildedRose Kata - PHP Version

Ceci est une version adaptée du kata. Voir la version originale où il est également disponible dans d’autres langages.

Présentation de la Rose dorée

Bonjour et bienvenue dans l’équipe de la Rose dorée.

Comme vous le savez, notre petite taverne située à proximité d’une cité importante est dirigée par l’amicale aubergiste Allison.

Nous achetons et vendons uniquement les meilleurs produits. Malheureusement, la qualité de nos marchandises se dégrade constamment à l’approche de leur date de péremption.

Un système a été mis en place pour mettre à jour notre inventaire. Il a été développé par Leeroy, une personne pleine de bon sens qui est parti pour de nouvelles aventures.

Votre mission est d’ajouter une nouvelle fonctionnalité à notre système pour que nous puissions commencer à vendre un nouveau type de produits.

Mais d’abord, laissez-moi vous présenter notre système :

Plutôt simple, non ?

Attendez, ça devient intéressant :

Nous avons récemment signé un partenariat avec un fournisseur de produits invoqués. Cela nécessite une mise à jour de notre système :

Vous pouvez faire tous les changements que vous voulez, tant que tout fonctionne correctement. Cependant, nous devons vous prévenir, vous ne devez en aucun cas modifier le code de la classe Item ou ses propriétés car cette classe appartient au gobelin de l’étage et il entrera dans une rage instantanée et vous tuera sans délai.

Ah oui, juste une dernière précision : un produit ne peut jamais voir sa qualité augmenter au-dessus de 50, cependant Sulfuras est un objet légendaire et comme tel sa qualité est de 80 et elle ne change jamais.

Installation

Prérequis

Installation

git clone git@github.com:blanc-frederic/kata.git
cd kata/GildedRose
docker compose run composer install

Structure

Tests

Leeroy n’aime pas écrire des tests, il préfère foncer tout de suite dans le code. Il n’y a donc pas beaucoup de tests, mais vous pouvez les lancer avec la commande suivante :

docker compose run tests

Pour lancer les tests avec génération du code-coverage :

docker compose run coverage

Le rapport sera généré dans /var/coverage, vous pouvez le visualiser en ouvrant index.html dans un navigateur.