Starting code for the GildedRose Refactoring Kata in many programming languages.
Go to file
Emily Bache de2d37904a
Merge pull request #203 from rubberduck203/master
Make rust text based approval tests pass
2020-12-21 08:52:57 +01:00
abap starting code and tests for ABAP 2016-03-21 10:57:47 -05:00
Ada Renames README files consistently. 2018-12-02 20:39:39 +01:00
c99 Add CMake and Unity test framework for c99 2018-10-30 18:29:14 +01:00
C Renames README files consistently. 2018-12-02 20:39:39 +01:00
clisp Common Lisp version by Rainer Joswig 2016-06-02 21:21:32 +02:00
COBOL/mf Add test project for mf cobol. 2018-10-10 15:27:55 +02:00
cpp added texttests fixture to cpp version 2020-05-06 09:21:24 +00:00
cpp-catch2 starting test should fail at the start 2020-06-08 13:58:55 +02:00
csharp fix approval tests to work on windows, and use Approvals framework 2019-08-28 10:30:34 +02:00
csharpcore fix approval tests to work on windows, and use Approvals framework 2019-08-28 10:30:34 +02:00
d Add D language version 2018-05-09 18:23:31 +02:00
dart removed pubspec.lock 2016-03-18 22:39:31 -04:00
Delphi Add .res files to .gitignore 2020-01-20 11:54:27 +00:00
elixir Moves language specific Git ignores into language subfolders. 2018-12-02 20:31:26 +01:00
elm Remove License 2020-01-22 12:46:01 -05:00
erlang Add Erlang version 2018-03-05 19:38:49 +01:00
fsharp add fsharp version 2015-10-26 13:38:45 +01:00
fsharp-core Added F# starter solution based on .NET Core 2019-02-28 13:48:45 -06:00
go Rename Go's texttest fixture, fix type in name. 2018-12-03 21:18:33 +01:00
Groovy Renames README files consistently. 2018-12-02 20:39:39 +01:00
haskell chore(haskell): update base and add stack file 2018-10-22 23:07:04 +02:00
Java update gradle wrapper & junit5 dependency 2020-06-04 10:22:28 +03:00
Java-Spock Renames Java with Spock language without blanks in folder name. 2018-12-02 20:48:45 +01:00
js-jasmine Add a text test fixture for javascript projects 2020-04-07 06:46:41 -03:00
js-jest Bump yargs-parser from 13.1.1 to 13.1.2 in /js-jest 2020-09-08 13:26:39 +00:00
js-mocha Add a text test fixture for javascript projects 2020-04-07 06:46:41 -03:00
Kotlin Upgrade kotlin to 1.4.0, junit to 5.6.2 & gradle to 6.6 2020-08-20 14:44:45 +02:00
pascal Port to (Turbo) Pascal. Feeling retro ;-) 2017-12-08 15:53:56 +01:00
perl add texttest fixture for Perl 5 code 2014-05-02 12:25:12 +02:00
perl6 Moves language specific Git ignores into language subfolders. 2018-12-02 20:31:26 +01:00
php Bump symfony/http-kernel from 5.0.8 to 5.1.5 in /php 2020-09-08 13:27:13 +00:00
plantuml added a slide-deck for a workshop 2019-12-31 14:17:03 +01:00
plpgsql typo 2020-01-23 19:53:15 +01:00
plsql Updated gilded rose to utplsql version 3 2019-07-02 15:40:46 +02:00
python Moves language specific Git ignores into language subfolders. 2018-12-02 20:31:26 +01:00
R Eclipse/StatET R environment configuration (can be imported as existing 2014-12-05 20:09:51 +01:00
ruby Change line separator from CRLF to LF 2020-09-25 16:45:40 +02:00
rust Make rust text based approval tests pass 2020-12-20 14:06:26 -05:00
scala Update ScalaTest version to 3.1.1 2020-04-05 13:17:19 +02:00
scheme Fixes bug in Scheme version, not deeply nested enough. 2018-12-03 22:45:26 +01:00
Smalltalk Fixes encoding Smalltalk source. 2018-12-02 21:48:42 +01:00
sql Add SQL (without test support) 2019-12-18 21:58:10 +01:00
swift Swift: Delete unusual blank lines 2019-12-29 13:31:55 -08:00
texttests Create texttest settings for TypeScript version 2020-07-24 21:45:33 +01:00
TypeScript excluded none spec files from test runner 2018-12-10 13:01:57 +01:00
xslt Description how to run the XSLT. 2018-12-07 23:53:54 +01:00
.bettercodehub.yml adding config file for bettercodehub so I can see how many refactoring targets it finds in this repo 2017-05-12 11:29:38 +02:00
.gitignore added texttests fixture to cpp version 2020-05-06 09:21:24 +00:00
GildedRoseRequirements_es.md Update GildedRoseRequirements_es.md 2018-03-03 12:24:57 +01:00
GildedRoseRequirements_fr.md Adjust a bit French description 2020-09-06 16:00:37 +02:00
GildedRoseRequirements_jp.md Update GildedRoseRequirements_jp.md 2020-08-17 10:47:34 +09: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_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 Remove broken links to cyber-dojo from README.md 2020-12-10 14:15:07 -05:00

Gilded Rose Refactoring Kata

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.

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 "Text-Based" tests provided in this repository. (Read more about that in the next section)

Whichever testing approach you choose, 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 designing tests, taking small steps, running the tests often, and incrementally improving the design.

Text-Based Approval Testing

This code comes with comprehensive tests that use this approach. For information about how to run them, see the texttests README

Better Code Hub

I analysed this repo according to the clean code standards on Better Code Hub just to get an independent opinion of how bad the code is. Perhaps unsurprisingly, the compliance score is low!

BCH compliance