mirror of
https://github.com/emilybache/GildedRose-Refactoring-Kata.git
synced 2026-02-04 17:21:38 +00:00
Restructure documentation layout
This commit is contained in:
parent
361cd3dc01
commit
400c1091b6
2
.github/pull_request_template.md
vendored
2
.github/pull_request_template.md
vendored
@ -3,6 +3,6 @@
|
||||
Please do not submit a PR with your solution to the Gilded Rose Kata. This repo is intended to be used as a starting point for the kata.
|
||||
|
||||
- [ ] I acknowledge that this PR is not a solution to the Gilded Rose Kata, but an improvement to the template.
|
||||
- [ ] I acknowledge that I have read [this section of the README](https://github.com/emilybache/GildedRose-Refactoring-Kata/blob/main/README.md#translating-this-code)
|
||||
- [ ] I acknowledge that I have read [CONTRIBUTING.md](https://github.com/emilybache/GildedRose-Refactoring-Kata/blob/main/CONTRIBUTING.md)
|
||||
|
||||
## Please provide your PR description below this line
|
||||
|
||||
37
CONTRIBUTING.md
Normal file
37
CONTRIBUTING.md
Normal file
@ -0,0 +1,37 @@
|
||||
Contributing to Gilded Rose Refactoring Kata
|
||||
---
|
||||
|
||||
More translations are most welcome! I'm very open for pull requests that
|
||||
translate the starting position into additional languages. However, please
|
||||
do **not** open 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!
|
||||
|
||||
# Translating this code
|
||||
|
||||
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, i.e. 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.
|
||||
|
||||
# Recommended project structure
|
||||
|
||||
Programming languages have a variety of conventions but the starting points try
|
||||
to maintain order among languages. Ideally, the 'update_quality' and
|
||||
Item definitions should be in a file named `gilded_rose` with your language's
|
||||
conventional casing (e.g. snake case) and location (e.g. `src/`). The "fixme" !
|
||||
= "foo" test should go in a file `gilded_rose_test` in your language's
|
||||
conventional location (e.g. `test/`). The TextTest fixture and command-line
|
||||
program, that simulates update_quality over a number of days, should go in
|
||||
`program` or `texttest_fixture`. If you can define a default for the number of
|
||||
days in the simulation please choose two days.
|
||||
31
README.md
31
README.md
@ -17,9 +17,6 @@ Alternatively, use the Approval tests provided in this repository. (Read more ab
|
||||
|
||||
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
|
||||
|
||||
- [English](GildedRoseRequirements.md)
|
||||
@ -49,28 +46,8 @@ As Bobby Johnson points out in his article ["Why Most Solutions to Gilded Rose M
|
||||
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
|
||||
## Contributing
|
||||
|
||||
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.
|
||||
|
||||
### Recommended project structure
|
||||
|
||||
Programming languages have a variety of conventions but the project tries
|
||||
to maintain some order among the examples. Ideally, the 'update_quality' and
|
||||
Item definitions should be in a file named `gilded_rose` with your language's
|
||||
conventional casing (e.g. snake case) and location (e.g. `src/`). The "fixme" !
|
||||
= "foo" test should go in a file `gilded_rose_test` in your language's
|
||||
conventional location (e.g. `test/`). The TextTest fixture and command-line
|
||||
program that simulates update_quality over a number of days should go in
|
||||
`program` or `texttest_fixture`. If you can define a default for the number of
|
||||
days in the simulation please choose two days.
|
||||
Contributions are encouraged! You could add a translations of the specification
|
||||
in another language or a new starting point for your favorite programming
|
||||
language. Please see [CONTRIBUTING.md](./CONTRIBUTING.md) for more details.
|
||||
|
||||
Loading…
Reference in New Issue
Block a user