Starting code for the GildedRose Refactoring Kata in many programming languages.
Go to file
2023-09-18 23:45:26 +02:00
.github Change PR close comment 2023-08-29 13:07:54 +02:00
abap Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
Ada Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
c99 Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
C Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
clojure Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
COBOL Add add script that helps you add items 2022-09-26 15:28:05 +02:00
common-lisp-parachute Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
commonlisp Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
cpp Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
cpp-catch2 Update catch2 version in CMakeLists.txt 2023-06-20 09:14:54 +02:00
csharp Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
csharpcore Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
csharpcore-Verify.xunit Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
d Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
dart Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
Delphi Add .res files to .gitignore 2020-01-20 11:54:27 +00:00
elixir Add initial failing test for Elixir 2021-09-08 17:26:38 -04:00
elm Remove License 2020-01-22 12:46:01 -05:00
erlang Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
fortran Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
fsharp Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
fsharp-core Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
go Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
Groovy Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
haskell Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
janet Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
Java Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
Java-Approvals Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
Java-Cucumber Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
Java-Spock Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
jq Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
js-jasmine Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
js-jest Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
js-mocha Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
julia Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
Kotlin Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
lfe Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
pascal Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
perl Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
perl6 Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
php Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
plantuml added a slide-deck for a workshop 2019-12-31 14:17:03 +01:00
plpgsql Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
plsql Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
python Update test_gilded_rose.py 2021-02-18 23:01:21 +01:00
R Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
rescript Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
ruby Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
rust Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
scala Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
scheme Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
Smalltalk Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
sql Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
swift Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
texttests Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
TypeScript Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
vbnet Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
xslt Update texttest output and fixtures to match spec 2023-09-18 23:45:26 +02:00
.gitignore Ignore received.txt 2023-04-08 14:54:20 +01:00
GildedRoseRequirements_de.md improve language 2022-02-11 21:08:27 +01:00
GildedRoseRequirements_es.md Update GildedRoseRequirements_es.md 2018-03-03 12:24:57 +01:00
GildedRoseRequirements_fr.md removed a word that didn't mean anything in the sentence in french 2022-11-07 09:31:27 +01:00
GildedRoseRequirements_it.md Update Italian translation: 2023-09-06 12:38:04 +02:00
GildedRoseRequirements_jp.md Update GildedRoseRequirements_jp.md 2020-08-17 10:47:34 +09:00
GildedRoseRequirements_kr.md Update GildedRoseRequirements_kr.md 2023-01-12 14:08:50 +09:00
GildedRoseRequirements_pl.md add polish translation of requirements 2022-06-09 20:17:36 +02:00
GildedRoseRequirements_pt-BR.md Update GildedRoseRequirements_pt-BR.md 2017-07-13 18:46:22 -03:00
GildedRoseRequirements_ru.txt Added requirements specification in russian language. 2016-06-11 23:53:18 +04:00
GildedRoseRequirements_th.md Update GildedRoseRequirements_th.md 2021-03-16 15:28:32 +07:00
GildedRoseRequirements_zh.txt Update GildedRoseRequirements_zh.txt 2020-09-25 13:05:39 +08:00
GildedRoseRequirements.txt fix typo in requirements 2016-01-25 20:42:55 +01:00
license.txt added MIT license 2015-07-07 19:46:17 +02:00
README.md Update Italian translation: 2023-09-06 12:38:04 +02:00

Gilded Rose Refactoring Kata

You can find out more about this exercise in my YouTube video Why Developers LOVE The Gilded Rose Kata.

I use this kata as part of my work as a technical coach. I wrote a lot about the coaching method I use in this book Technical Agile Coaching with the Samman method. A while back I wrote this article "Writing Good Tests for the Gilded Rose Kata" about how you could use this kata in a coding dojo.

How to use this Kata

The simplest way is to just clone the code and start hacking away improving the design. You'll want to look at the "Gilded Rose Requirements" which explains what the code is for. I strongly advise you that you'll also need some tests if you want to make sure you don't break the code while you refactor.

You could write some unit tests yourself, using the requirements to identify suitable test cases. I've provided a failing unit test in a popular test framework as a starting point for most languages.

Alternatively, use the Approval tests provided in this repository. (Read more about that in the section "Text-based Approval Testing").

The idea of the exercise is to do some deliberate practice, and improve your skills at designing test cases and refactoring. The idea is not to re-write the code from scratch, but rather to practice taking small steps, running the tests often, and incrementally improving the design.

Please don't send me a pull request with your solution. It can be a bit confusing since GitHub encourages you to do so! Please only send me pull requests if you have a correction or improvement to the starting position. You don't want to spoil the fun of doing the exercise for other people!

Gilded Rose Requirements in other languages

Text-Based Approval Testing

Most language versions of this code have a TextTest fixture for Approval testing. For information about this, see the TextTests README

History of the exercise

This Kata was originally created by Terry Hughes (http://twitter.com/TerryHughes). It is already on GitHub here. See also Bobby Johnson's description of the kata.

I translated the original C# into a few other languages, (with a little help from my friends!), and slightly changed the starting position. This means I've actually done a small amount of refactoring already compared with the original form of the kata, and made it easier to get going with writing tests by giving you one failing unit test to start with. I also added test fixtures for Text-Based approval testing with TextTest (see the TextTests)

As Bobby Johnson points out in his article "Why Most Solutions to Gilded Rose Miss The Bigger Picture", it'll actually give you better practice at handling a legacy code situation if you do this Kata in the original C#. However, I think this kata is also really useful for practicing writing good tests using different frameworks and approaches, and the small changes I've made help with that. I think it's also interesting to compare what the refactored code and tests look like in different programming languages.

Translating this code

More translations are most welcome! I'm very open for pull requests that translate the starting position into additional languages.

Please note a translation should ideally include:

  • a translation of the production code for 'update_quality' and Item
  • one failing unit test complaining that "fixme" != "foo"
  • a TextTest fixture, ie a command-line program that runs update_quality on the sample data for the number of days specified.

Please don't write too much code in the starting position or add too many unit tests. The idea with the one failing unit test is to tempt people to work out how to fix it, discover it wasn't that hard, and now they understand what this test is doing they realize they can improve it.

If your programming language doesn't have an easy way to add a command-line interface, then the TextTest fixture is probably not necessary.