Skip to content

Latest commit

 

History

History
47 lines (34 loc) · 2.2 KB

README.md

File metadata and controls

47 lines (34 loc) · 2.2 KB

String Calculator - TDD

The following is a TDD Kata- an exercise in coding, refactoring and test-first

How does it work?

You can look here at osherove or see the steps described here.

This code is written step by step. You can check code at each commit. Only main points are covered here.

  1. Create a simple String calculator with a method signature: int Add(string numbers)
  2. The method can take up to two numbers, separated by commas, and will return their sum. (for an empty string it will return 0)
    1. For example “” or “1” or “1,2” as inputs.
  3. Add method can also handle an unknown amount of numbers
  4. Add method handles new lines between numbers.
    1. the following input is ok: “1\n2,3” (will equal 6)
    2. the following input is NOT ok: “1,\n” (not need to prove it - just clarifying)
  5. Support for different delimiters
    1. to change a delimiter, the beginning of the string will contain a separate line that looks like this: “//[delimiter]\n[numbers…]” for example “//;\n1;2” should return three where the default delimiter is ‘;’
    2. the first line is optional. all existing scenarios should still be supported
  6. Calling Add with a negative number will throw an exception "negatives not allowed" - and the negative that was passed.
  7. if there are multiple negatives, show all of them in the exception message.
  8. Numbers bigger than 1000 should be ignored, so adding 2 + 1001 = 2
  9. Delimiters can be of any length with the following format: “//[delimiter]\n”
    1. for example: “//[***]\n1***2***3” should return 6
  10. Allow multiple delimiters like this: “//[delim1][delim2]\n” for example “//[*][%]\n1*2%3” should return 6.
  11. Make sure to handle multiple delimiters with length longer than one char

How to Run?

  • Clone the repository

  • Run the test file which is in following directory:

tdd-string-calculator/src/com/ajinz/test/

You should get following output:

Tree

Version and Library Used

Java Version: java 16.0.2

Testing Library: TestNG