trackler 2.2.1.107 → 2.2.1.108

Sign up to get free protection for your applications and to get access to all the features.
Files changed (397) hide show
  1. checksums.yaml +4 -4
  2. data/lib/trackler/version.rb +1 -1
  3. data/problem-specifications/exercises/pig-latin/description.md +4 -4
  4. data/tracks/c/config.json +42 -0
  5. data/tracks/c/exercises/bracket-push/README.md +3 -0
  6. data/tracks/c/exercises/bracket-push/makefile +25 -0
  7. data/tracks/c/exercises/bracket-push/src/example.c +52 -0
  8. data/tracks/c/exercises/bracket-push/src/example.h +7 -0
  9. data/tracks/c/exercises/bracket-push/test/test_bracket_push.c +132 -0
  10. data/tracks/c/exercises/bracket-push/test/vendor/unity.c +1300 -0
  11. data/tracks/c/exercises/bracket-push/test/vendor/unity.h +274 -0
  12. data/tracks/c/exercises/bracket-push/test/vendor/unity_internals.h +701 -0
  13. data/tracks/c/exercises/etl/README.md +46 -0
  14. data/tracks/c/exercises/etl/makefile +25 -0
  15. data/tracks/c/exercises/etl/src/example.c +44 -0
  16. data/tracks/c/exercises/etl/src/example.h +18 -0
  17. data/tracks/c/exercises/etl/test/test_etl.c +120 -0
  18. data/tracks/c/exercises/etl/test/vendor/unity.c +1300 -0
  19. data/tracks/c/exercises/etl/test/vendor/unity.h +274 -0
  20. data/tracks/c/exercises/etl/test/vendor/unity_internals.h +701 -0
  21. data/tracks/c/exercises/luhn/README.md +64 -0
  22. data/tracks/c/exercises/luhn/makefile +25 -0
  23. data/tracks/c/exercises/luhn/src/example.c +38 -0
  24. data/tracks/c/exercises/luhn/src/example.h +7 -0
  25. data/tracks/c/exercises/luhn/test/test_luhn.c +109 -0
  26. data/tracks/c/exercises/luhn/test/vendor/unity.c +1300 -0
  27. data/tracks/c/exercises/luhn/test/vendor/unity.h +274 -0
  28. data/tracks/c/exercises/luhn/test/vendor/unity_internals.h +701 -0
  29. data/tracks/c/exercises/prime-factors/README.md +29 -0
  30. data/tracks/c/exercises/prime-factors/makefile +25 -0
  31. data/tracks/c/exercises/prime-factors/src/example.c +28 -0
  32. data/tracks/c/exercises/prime-factors/src/example.h +11 -0
  33. data/tracks/c/exercises/prime-factors/test/test_prime_factors.c +96 -0
  34. data/tracks/c/exercises/prime-factors/test/vendor/unity.c +1300 -0
  35. data/tracks/c/exercises/prime-factors/test/vendor/unity.h +274 -0
  36. data/tracks/c/exercises/prime-factors/test/vendor/unity_internals.h +701 -0
  37. data/tracks/clojure/exercises/hello-world/src/example.clj +2 -3
  38. data/tracks/clojure/exercises/hello-world/test/hello_world_test.clj +0 -6
  39. data/tracks/common-lisp/README.md +3 -8
  40. data/tracks/common-lisp/config/exercise_readme.go.tmpl +1 -1
  41. data/tracks/common-lisp/exercises/acronym/README.md +1 -1
  42. data/tracks/common-lisp/exercises/acronym/acronym-test.lisp +0 -5
  43. data/tracks/common-lisp/exercises/allergies/README.md +1 -1
  44. data/tracks/common-lisp/exercises/anagram/README.md +1 -1
  45. data/tracks/common-lisp/exercises/atbash-cipher/README.md +1 -1
  46. data/tracks/common-lisp/exercises/beer-song/README.md +1 -1
  47. data/tracks/common-lisp/exercises/binary/README.md +1 -1
  48. data/tracks/common-lisp/exercises/bob/README.md +1 -1
  49. data/tracks/common-lisp/exercises/collatz-conjecture/README.md +1 -1
  50. data/tracks/common-lisp/exercises/crypto-square/README.md +1 -1
  51. data/tracks/common-lisp/exercises/difference-of-squares/README.md +1 -1
  52. data/tracks/common-lisp/exercises/etl/README.md +1 -1
  53. data/tracks/common-lisp/exercises/gigasecond/README.md +1 -1
  54. data/tracks/common-lisp/exercises/grade-school/README.md +1 -1
  55. data/tracks/common-lisp/exercises/grains/README.md +1 -1
  56. data/tracks/common-lisp/exercises/hamming/README.md +1 -1
  57. data/tracks/common-lisp/exercises/hello-world/README.md +1 -1
  58. data/tracks/common-lisp/exercises/isogram/README.md +1 -1
  59. data/tracks/common-lisp/exercises/leap/README.md +1 -1
  60. data/tracks/common-lisp/exercises/meetup/README.md +1 -1
  61. data/tracks/common-lisp/exercises/nucleotide-count/README.md +1 -1
  62. data/tracks/common-lisp/exercises/pascals-triangle/README.md +1 -1
  63. data/tracks/common-lisp/exercises/perfect-numbers/README.md +1 -1
  64. data/tracks/common-lisp/exercises/phone-number/README.md +1 -1
  65. data/tracks/common-lisp/exercises/prime-factors/README.md +1 -1
  66. data/tracks/common-lisp/exercises/raindrops/README.md +1 -1
  67. data/tracks/common-lisp/exercises/rna-transcription/README.md +1 -1
  68. data/tracks/common-lisp/exercises/robot-name/README.md +1 -1
  69. data/tracks/common-lisp/exercises/roman-numerals/README.md +1 -1
  70. data/tracks/common-lisp/exercises/scrabble-score/README.md +1 -1
  71. data/tracks/common-lisp/exercises/sieve/README.md +1 -1
  72. data/tracks/common-lisp/exercises/space-age/README.md +1 -1
  73. data/tracks/common-lisp/exercises/strain/README.md +1 -1
  74. data/tracks/common-lisp/exercises/sublist/README.md +1 -1
  75. data/tracks/common-lisp/exercises/triangle/README.md +1 -1
  76. data/tracks/common-lisp/exercises/trinary/README.md +1 -1
  77. data/tracks/common-lisp/exercises/word-count/README.md +1 -1
  78. data/tracks/csharp/exercises/meetup/MeetupTest.cs +177 -177
  79. data/tracks/csharp/exercises/robot-simulator/Example.cs +27 -27
  80. data/tracks/csharp/exercises/robot-simulator/RobotSimulator.cs +3 -3
  81. data/tracks/csharp/exercises/robot-simulator/RobotSimulatorTest.cs +152 -31
  82. data/tracks/csharp/generators/Exercises/Meetup.cs +8 -9
  83. data/tracks/csharp/generators/Exercises/RobotSimulator.cs +116 -0
  84. data/tracks/delphi/exercises/allergies/uAllergyTests.pas +28 -0
  85. data/tracks/delphi/exercises/binary-search/uBinarySearchExample.pas +6 -0
  86. data/tracks/delphi/exercises/binary-search/uBinarySearchTest.pas +53 -37
  87. data/tracks/delphi/exercises/collatz-conjecture/uCollatzconjectureTest.pas +3 -0
  88. data/tracks/delphi/exercises/etl/uETLtests.pas +13 -10
  89. data/tracks/delphi/exercises/grains/uGrainsTests.pas +5 -2
  90. data/tracks/delphi/exercises/hamming/uHammingTests.pas +3 -0
  91. data/tracks/delphi/exercises/hello-world/uTestHelloWorld.pas +3 -0
  92. data/tracks/delphi/exercises/leap/uLeapTests.pas +3 -0
  93. data/tracks/delphi/exercises/minesweeper/uMineSweeperTest.pas +3 -0
  94. data/tracks/delphi/exercises/nucleotide-count/uNucleotideCountTest.pas +5 -17
  95. data/tracks/delphi/exercises/perfect-numbers/uPerfectNumbersExample.pas +6 -0
  96. data/tracks/delphi/exercises/perfect-numbers/uPerfectNumbersTest.pas +77 -26
  97. data/tracks/delphi/exercises/pig-latin/README.md +4 -4
  98. data/tracks/delphi/exercises/pig-latin/uTestPigLatin.pas +12 -9
  99. data/tracks/delphi/exercises/poker/uPokerExample.pas +81 -26
  100. data/tracks/delphi/exercises/poker/uPokerTest.pas +343 -121
  101. data/tracks/delphi/exercises/raindrops/uRaindropsTest.pas +3 -0
  102. data/tracks/delphi/exercises/saddle-points/uSaddlePointsExample.pas +4 -3
  103. data/tracks/delphi/exercises/saddle-points/uSaddlePointsTests.pas +25 -47
  104. data/tracks/delphi/exercises/triangle/uTestTriangle.pas +4 -2
  105. data/tracks/delphi/exercises/two-fer/utwoferTest.pas +3 -0
  106. data/tracks/delphi/exercises/wordy/uWordyTests.pas +3 -0
  107. data/tracks/ecmascript/.travis.yml +2 -1
  108. data/tracks/ecmascript/config.json +14 -0
  109. data/tracks/ecmascript/exercises/accumulate/package.json +1 -2
  110. data/tracks/ecmascript/exercises/acronym/package.json +1 -2
  111. data/tracks/ecmascript/exercises/all-your-base/package.json +1 -2
  112. data/tracks/ecmascript/exercises/allergies/package.json +1 -2
  113. data/tracks/ecmascript/exercises/alphametics/package.json +1 -2
  114. data/tracks/ecmascript/exercises/anagram/package.json +1 -2
  115. data/tracks/ecmascript/exercises/atbash-cipher/package.json +1 -2
  116. data/tracks/ecmascript/exercises/beer-song/package.json +1 -2
  117. data/tracks/ecmascript/exercises/binary-search-tree/package.json +1 -2
  118. data/tracks/ecmascript/exercises/binary-search/package.json +1 -2
  119. data/tracks/ecmascript/exercises/binary/package.json +1 -2
  120. data/tracks/ecmascript/exercises/bob/README.md +2 -0
  121. data/tracks/ecmascript/exercises/bob/bob.spec.js +5 -5
  122. data/tracks/ecmascript/exercises/bob/example.js +7 -2
  123. data/tracks/ecmascript/exercises/bob/package.json +1 -2
  124. data/tracks/ecmascript/exercises/bowling/package.json +1 -2
  125. data/tracks/ecmascript/exercises/bracket-push/package.json +1 -2
  126. data/tracks/ecmascript/exercises/change/package.json +1 -2
  127. data/tracks/ecmascript/exercises/circular-buffer/package.json +1 -2
  128. data/tracks/ecmascript/exercises/clock/package.json +1 -2
  129. data/tracks/ecmascript/exercises/collatz-conjecture/package.json +1 -2
  130. data/tracks/ecmascript/exercises/complex-numbers/package.json +1 -2
  131. data/tracks/ecmascript/exercises/connect/package.json +1 -2
  132. data/tracks/ecmascript/exercises/crypto-square/package.json +1 -2
  133. data/tracks/ecmascript/exercises/custom-set/package.json +1 -2
  134. data/tracks/ecmascript/exercises/diamond/package.json +1 -2
  135. data/tracks/ecmascript/exercises/difference-of-squares/package.json +1 -2
  136. data/tracks/ecmascript/exercises/diffie-hellman/package.json +1 -2
  137. data/tracks/ecmascript/exercises/etl/package.json +1 -2
  138. data/tracks/ecmascript/exercises/flatten-array/package.json +1 -2
  139. data/tracks/ecmascript/exercises/food-chain/package.json +1 -2
  140. data/tracks/ecmascript/exercises/gigasecond/package.json +1 -2
  141. data/tracks/ecmascript/exercises/grade-school/package.json +1 -2
  142. data/tracks/ecmascript/exercises/grains/package.json +1 -2
  143. data/tracks/ecmascript/exercises/hamming/package.json +1 -2
  144. data/tracks/ecmascript/exercises/hello-world/package.json +1 -2
  145. data/tracks/ecmascript/exercises/hexadecimal/package.json +1 -2
  146. data/tracks/ecmascript/exercises/house/package.json +1 -2
  147. data/tracks/ecmascript/exercises/isbn-verifier/package.json +1 -2
  148. data/tracks/ecmascript/exercises/isogram/package.json +1 -2
  149. data/tracks/ecmascript/exercises/kindergarten-garden/package.json +1 -2
  150. data/tracks/ecmascript/exercises/largest-series-product/package.json +1 -2
  151. data/tracks/ecmascript/exercises/leap/package.json +1 -2
  152. data/tracks/ecmascript/exercises/linked-list/package.json +1 -2
  153. data/tracks/ecmascript/exercises/list-ops/package.json +1 -2
  154. data/tracks/ecmascript/exercises/luhn/package.json +1 -2
  155. data/tracks/ecmascript/exercises/matrix/package.json +1 -2
  156. data/tracks/ecmascript/exercises/meetup/package.json +1 -2
  157. data/tracks/ecmascript/exercises/minesweeper/package.json +1 -2
  158. data/tracks/ecmascript/exercises/nth-prime/package.json +1 -2
  159. data/tracks/ecmascript/exercises/nucleotide-count/README.md +60 -0
  160. data/tracks/ecmascript/exercises/nucleotide-count/example.js +13 -0
  161. data/tracks/ecmascript/exercises/nucleotide-count/nucleotide-count.spec.js +23 -0
  162. data/tracks/ecmascript/exercises/nucleotide-count/package.json +70 -0
  163. data/tracks/ecmascript/exercises/ocr-numbers/package.json +1 -2
  164. data/tracks/ecmascript/exercises/octal/package.json +1 -2
  165. data/tracks/ecmascript/exercises/palindrome-products/package.json +1 -2
  166. data/tracks/ecmascript/exercises/pangram/package.json +1 -2
  167. data/tracks/ecmascript/exercises/pascals-triangle/package.json +1 -2
  168. data/tracks/ecmascript/exercises/perfect-numbers/package.json +1 -2
  169. data/tracks/ecmascript/exercises/phone-number/package.json +1 -2
  170. data/tracks/ecmascript/exercises/pig-latin/package.json +1 -2
  171. data/tracks/ecmascript/exercises/prime-factors/package.json +1 -2
  172. data/tracks/ecmascript/exercises/protein-translation/package.json +1 -2
  173. data/tracks/ecmascript/exercises/proverb/package.json +1 -2
  174. data/tracks/ecmascript/exercises/pythagorean-triplet/package.json +1 -2
  175. data/tracks/ecmascript/exercises/queen-attack/package.json +1 -2
  176. data/tracks/ecmascript/exercises/raindrops/package.json +1 -2
  177. data/tracks/ecmascript/exercises/react/package.json +1 -2
  178. data/tracks/ecmascript/exercises/rectangles/package.json +1 -2
  179. data/tracks/ecmascript/exercises/rna-transcription/package.json +1 -2
  180. data/tracks/ecmascript/exercises/robot-name/package.json +1 -2
  181. data/tracks/ecmascript/exercises/robot-simulator/package.json +1 -2
  182. data/tracks/ecmascript/exercises/roman-numerals/package.json +1 -2
  183. data/tracks/ecmascript/exercises/rotational-cipher/package.json +1 -2
  184. data/tracks/ecmascript/exercises/run-length-encoding/package.json +1 -2
  185. data/tracks/ecmascript/exercises/saddle-points/package.json +1 -2
  186. data/tracks/ecmascript/exercises/say/package.json +1 -2
  187. data/tracks/ecmascript/exercises/scrabble-score/package.json +1 -2
  188. data/tracks/ecmascript/exercises/secret-handshake/package.json +1 -2
  189. data/tracks/ecmascript/exercises/series/package.json +1 -2
  190. data/tracks/ecmascript/exercises/sieve/package.json +1 -2
  191. data/tracks/ecmascript/exercises/simple-cipher/package.json +1 -2
  192. data/tracks/ecmascript/exercises/simple-linked-list/package.json +1 -2
  193. data/tracks/ecmascript/exercises/space-age/package.json +1 -2
  194. data/tracks/ecmascript/exercises/spiral-matrix/package.json +1 -2
  195. data/tracks/ecmascript/exercises/strain/package.json +1 -2
  196. data/tracks/ecmascript/exercises/sublist/package.json +1 -2
  197. data/tracks/ecmascript/exercises/sum-of-multiples/package.json +1 -2
  198. data/tracks/ecmascript/exercises/transpose/package.json +1 -2
  199. data/tracks/ecmascript/exercises/triangle/package.json +1 -2
  200. data/tracks/ecmascript/exercises/trinary/package.json +1 -2
  201. data/tracks/ecmascript/exercises/twelve-days/package.json +1 -2
  202. data/tracks/ecmascript/exercises/two-bucket/package.json +1 -2
  203. data/tracks/ecmascript/exercises/two-fer/package.json +1 -2
  204. data/tracks/ecmascript/exercises/word-count/package.json +1 -2
  205. data/tracks/ecmascript/exercises/word-search/package.json +1 -2
  206. data/tracks/ecmascript/exercises/wordy/package.json +1 -2
  207. data/tracks/ecmascript/package.json +1 -2
  208. data/tracks/elm/config.json +13 -1
  209. data/tracks/elm/exercises/binary-search/BinarySearch.elm +9 -0
  210. data/tracks/elm/exercises/binary-search/BinarySearch.example.elm +36 -0
  211. data/tracks/elm/exercises/binary-search/README.md +71 -0
  212. data/tracks/elm/exercises/binary-search/elm-package.json +15 -0
  213. data/tracks/elm/exercises/binary-search/tests/Tests.elm +66 -0
  214. data/tracks/elm/exercises/binary-search/tests/elm-package.json +17 -0
  215. data/tracks/elm/exercises/hamming/Hamming.example.elm +3 -3
  216. data/tracks/elm/exercises/hamming/tests/Tests.elm +14 -14
  217. data/tracks/go/exercises/word-search/.meta/gen.go +9 -7
  218. data/tracks/go/exercises/word-search/cases_test.go +2 -2
  219. data/tracks/groovy/config.json +12 -0
  220. data/tracks/groovy/exercises/bank-account/BankAccount.groovy +30 -0
  221. data/tracks/groovy/exercises/bank-account/BankAccountSpec.groovy +200 -0
  222. data/tracks/groovy/exercises/bank-account/Example.groovy +47 -0
  223. data/tracks/groovy/exercises/bank-account/README.md +75 -0
  224. data/tracks/groovy/exercises/phone-number/Example.groovy +10 -14
  225. data/tracks/groovy/exercises/phone-number/PhoneNumber.groovy +2 -14
  226. data/tracks/groovy/exercises/phone-number/PhoneNumberSpec.groovy +39 -26
  227. data/tracks/groovy/exercises/phone-number/README.md +1 -1
  228. data/tracks/java/config.json +13 -0
  229. data/tracks/java/exercises/forth/README.md +10 -0
  230. data/tracks/java/exercises/rna-transcription/.meta/version +1 -1
  231. data/tracks/java/exercises/settings.gradle +1 -0
  232. data/tracks/java/exercises/sieve/.meta/version +1 -1
  233. data/tracks/java/exercises/spiral-matrix/.meta/version +1 -1
  234. data/tracks/java/exercises/triangle/.meta/version +1 -1
  235. data/tracks/java/exercises/two-bucket/README.md +1 -1
  236. data/tracks/java/exercises/zipper/.meta/src/reference/java/Zipper.java +199 -0
  237. data/tracks/java/exercises/zipper/.meta/version +1 -0
  238. data/tracks/java/exercises/zipper/README.md +42 -0
  239. data/tracks/java/exercises/zipper/build.gradle +18 -0
  240. data/tracks/java/exercises/zipper/src/main/java/.keep +0 -0
  241. data/tracks/java/exercises/zipper/src/test/java/ZipperTest.java +204 -0
  242. data/tracks/javascript/package.json +10 -0
  243. data/tracks/ocaml/.travis-ci.sh +1 -1
  244. data/tracks/ocaml/.travis.yml +1 -1
  245. data/tracks/ocaml/README.md +1 -1
  246. data/tracks/ocaml/config/exercise_readme.go.tmpl +2 -0
  247. data/tracks/python/config.json +13 -0
  248. data/tracks/python/exercises/all-your-base/all_your_base.py +1 -1
  249. data/tracks/python/exercises/all-your-base/all_your_base_test.py +8 -8
  250. data/tracks/python/exercises/alphametics/alphametics_test.py +49 -9
  251. data/tracks/python/exercises/binary-search-tree/binary_search_tree.py +11 -5
  252. data/tracks/python/exercises/binary-search-tree/binary_search_tree_test.py +89 -48
  253. data/tracks/python/exercises/binary-search-tree/example.py +42 -52
  254. data/tracks/python/exercises/binary-search/binary_search_test.py +1 -1
  255. data/tracks/python/exercises/book-store/book_store_test.py +18 -39
  256. data/tracks/python/exercises/book-store/example.py +1 -1
  257. data/tracks/python/exercises/bowling/bowling.py +0 -2
  258. data/tracks/python/exercises/bowling/bowling_test.py +49 -13
  259. data/tracks/python/exercises/bowling/example.py +85 -135
  260. data/tracks/python/exercises/bracket-push/bracket_push.py +1 -1
  261. data/tracks/python/exercises/bracket-push/bracket_push_test.py +16 -16
  262. data/tracks/python/exercises/bracket-push/example.py +2 -2
  263. data/tracks/python/exercises/change/change_test.py +17 -4
  264. data/tracks/python/exercises/change/example.py +2 -2
  265. data/tracks/python/exercises/circular-buffer/circular_buffer.py +12 -0
  266. data/tracks/python/exercises/circular-buffer/circular_buffer_test.py +4 -11
  267. data/tracks/python/exercises/clock/clock.py +10 -1
  268. data/tracks/python/exercises/clock/clock_test.py +9 -9
  269. data/tracks/python/exercises/clock/example.py +4 -1
  270. data/tracks/python/exercises/collatz-conjecture/collatz_conjecture_test.py +15 -5
  271. data/tracks/python/exercises/collatz-conjecture/example.py +1 -1
  272. data/tracks/python/exercises/complex-numbers/complex_numbers_test.py +37 -26
  273. data/tracks/python/exercises/custom-set/custom_set_test.py +1 -1
  274. data/tracks/python/exercises/diamond/diamond_test.py +1 -1
  275. data/tracks/python/exercises/dominoes/dominoes_test.py +1 -1
  276. data/tracks/python/exercises/forth/forth_test.py +1 -1
  277. data/tracks/python/exercises/house/example.py +11 -3
  278. data/tracks/python/exercises/house/house.py +1 -5
  279. data/tracks/python/exercises/house/house_test.py +269 -116
  280. data/tracks/python/exercises/list-ops/list_ops_test.py +1 -1
  281. data/tracks/python/exercises/luhn/luhn.py +3 -0
  282. data/tracks/python/exercises/luhn/luhn_test.py +1 -1
  283. data/tracks/python/exercises/markdown/markdown_test.py +2 -3
  284. data/tracks/python/exercises/minesweeper/minesweeper_test.py +1 -1
  285. data/tracks/python/exercises/nth-prime/nth_prime_test.py +1 -1
  286. data/tracks/python/exercises/ocr-numbers/ocr_numbers_test.py +1 -1
  287. data/tracks/python/exercises/palindrome-products/palindrome_products_test.py +14 -6
  288. data/tracks/python/exercises/perfect-numbers/perfect_numbers_test.py +1 -24
  289. data/tracks/python/exercises/phone-number/phone_number_test.py +11 -3
  290. data/tracks/python/exercises/poker/example.py +4 -3
  291. data/tracks/python/exercises/poker/poker.py +1 -1
  292. data/tracks/python/exercises/poker/poker_test.py +196 -119
  293. data/tracks/python/exercises/pov/example.py +3 -3
  294. data/tracks/python/exercises/pov/pov.py +2 -2
  295. data/tracks/python/exercises/pov/pov_test.py +19 -18
  296. data/tracks/python/exercises/protein-translation/protein_translation_test.py +14 -24
  297. data/tracks/python/exercises/rail-fence-cipher/rail_fence_cipher_test.py +1 -1
  298. data/tracks/python/exercises/rational-numbers/README.md +59 -0
  299. data/tracks/python/exercises/rational-numbers/example.py +58 -0
  300. data/tracks/python/exercises/rational-numbers/rational_numbers.py +34 -0
  301. data/tracks/python/exercises/rational-numbers/rational_numbers_test.py +132 -0
  302. data/tracks/python/exercises/rectangles/rectangles_test.py +1 -1
  303. data/tracks/python/exercises/roman-numerals/roman_numerals_test.py +2 -1
  304. data/tracks/python/exercises/run-length-encoding/run_length_encoding_test.py +2 -2
  305. data/tracks/python/exercises/saddle-points/saddle_points_test.py +18 -18
  306. data/tracks/python/exercises/scale-generator/example.py +4 -5
  307. data/tracks/python/exercises/scale-generator/scale_generator.py +2 -2
  308. data/tracks/python/exercises/scale-generator/scale_generator_test.py +38 -73
  309. data/tracks/python/exercises/secret-handshake/secret_handshake_test.py +1 -1
  310. data/tracks/python/exercises/tournament/tournament_test.py +1 -1
  311. data/tracks/python/exercises/twelve-days/example.py +3 -8
  312. data/tracks/python/exercises/twelve-days/twelve_days.py +1 -9
  313. data/tracks/python/exercises/twelve-days/twelve_days_test.py +51 -50
  314. data/tracks/python/exercises/two-bucket/example.py +3 -4
  315. data/tracks/python/exercises/two-bucket/two_bucket.py +1 -1
  316. data/tracks/python/exercises/two-bucket/two_bucket_test.py +8 -13
  317. data/tracks/python/exercises/two-fer/two_fer_test.py +8 -9
  318. data/tracks/python/exercises/variable-length-quantity/variable_length_quantity_test.py +1 -1
  319. data/tracks/python/exercises/word-count/word_count_test.py +8 -14
  320. data/tracks/python/exercises/word-search/word_search.py +3 -15
  321. data/tracks/python/exercises/word-search/word_search_test.py +1 -1
  322. data/tracks/python/exercises/wordy/wordy_test.py +1 -1
  323. data/tracks/python/exercises/zebra-puzzle/example.py +11 -2
  324. data/tracks/python/exercises/zebra-puzzle/zebra_puzzle.py +5 -1
  325. data/tracks/python/exercises/zebra-puzzle/zebra_puzzle_test.py +8 -5
  326. data/tracks/python/exercises/zipper/zipper_test.py +24 -30
  327. data/tracks/scala/exercises/dominoes/src/test/scala/DominoesTest.scala +2 -2
  328. data/tracks/scala/exercises/flatten-array/src/test/scala/FlattenArrayTest.scala +1 -1
  329. data/tracks/scala/exercises/food-chain/example.scala +3 -3
  330. data/tracks/scala/exercises/food-chain/src/test/scala/FoodChainTest.scala +12 -12
  331. data/tracks/scala/exercises/forth/src/test/scala/ForthTest.scala +35 -10
  332. data/tracks/scala/exercises/gigasecond/src/test/scala/GigasecondTest.scala +2 -2
  333. data/tracks/scala/exercises/hamming/src/test/scala/HammingTest.scala +4 -4
  334. data/tracks/scala/exercises/hello-world/src/test/scala/HelloWorldTest.scala +2 -3
  335. data/tracks/scala/exercises/house/example.scala +4 -5
  336. data/tracks/scala/exercises/house/src/test/scala/HouseTest.scala +16 -17
  337. data/tracks/scala/exercises/isogram/src/test/scala/IsogramTest.scala +3 -3
  338. data/tracks/scala/exercises/kindergarten-garden/src/test/scala/GardenTest.scala +1 -29
  339. data/tracks/scala/exercises/largest-series-product/src/test/scala/SeriesTest.scala +20 -17
  340. data/tracks/scala/exercises/leap/src/test/scala/LeapTest.scala +3 -3
  341. data/tracks/scala/exercises/luhn/src/test/scala/LuhnTest.scala +3 -3
  342. data/tracks/scala/exercises/matrix/example.scala +5 -1
  343. data/tracks/scala/exercises/matrix/src/test/scala/MatrixTest.scala +48 -12
  344. data/tracks/scala/exercises/meetup/src/test/scala/MeetupTest.scala +2 -1
  345. data/tracks/scala/exercises/minesweeper/src/test/scala/MinesweeperTest.scala +9 -9
  346. data/tracks/scala/testgen/src/main/scala/DominoesTestGenerator.scala +6 -6
  347. data/tracks/scala/testgen/src/main/scala/FlattenArrayTestGenerator.scala +6 -6
  348. data/tracks/scala/testgen/src/main/scala/FoodChainTestGenerator.scala +10 -12
  349. data/tracks/scala/testgen/src/main/scala/ForthTestGenerator.scala +6 -6
  350. data/tracks/scala/testgen/src/main/scala/GigasecondTestGenerator.scala +6 -4
  351. data/tracks/scala/testgen/src/main/scala/HammingTestGenerator.scala +3 -3
  352. data/tracks/scala/testgen/src/main/scala/HouseTestGenerator.scala +10 -16
  353. data/tracks/scala/testgen/src/main/scala/IsogramTestGenerator.scala +1 -1
  354. data/tracks/scala/testgen/src/main/scala/KindergartenGardenTestGenerator.scala +6 -5
  355. data/tracks/scala/testgen/src/main/scala/LeapTestGenerator.scala +3 -3
  356. data/tracks/scala/testgen/src/main/scala/LuhnTestGenerator.scala +1 -1
  357. data/tracks/scala/testgen/src/main/scala/MatrixTestGenerator.scala +35 -0
  358. data/tracks/scala/testgen/src/main/scala/MeetupTestGenerator.scala +14 -11
  359. data/tracks/scala/testgen/src/main/scala/MinesweeperTestGenerator.scala +1 -1
  360. data/tracks/scala/testgen/src/main/scala/SeriesTestGenerator.scala +3 -3
  361. data/tracks/typescript/config/exercise_readme.go.tmpl +25 -4
  362. data/tracks/typescript/exercises/acronym/README.md +7 -2
  363. data/tracks/typescript/exercises/atbash-cipher/README.md +2 -1
  364. data/tracks/typescript/exercises/beer-song/README.md +2 -2
  365. data/tracks/typescript/exercises/binary-search-tree/README.md +2 -0
  366. data/tracks/typescript/exercises/circular-buffer/README.md +16 -7
  367. data/tracks/typescript/exercises/clock/README.md +6 -0
  368. data/tracks/typescript/exercises/diamond/README.md +8 -7
  369. data/tracks/typescript/exercises/etl/README.md +3 -1
  370. data/tracks/typescript/exercises/food-chain/README.md +1 -1
  371. data/tracks/typescript/exercises/grade-school/README.md +0 -1
  372. data/tracks/typescript/exercises/hello-world/.meta/hints.md +378 -0
  373. data/tracks/typescript/exercises/hello-world/README.md +37 -11
  374. data/tracks/typescript/exercises/largest-series-product/README.md +1 -6
  375. data/tracks/typescript/exercises/leap/README.md +1 -1
  376. data/tracks/typescript/exercises/linked-list/README.md +20 -15
  377. data/tracks/typescript/exercises/nth-prime/README.md +7 -2
  378. data/tracks/typescript/exercises/ocr-numbers/README.md +7 -6
  379. data/tracks/typescript/exercises/pangram/README.md +1 -1
  380. data/tracks/typescript/exercises/pascals-triangle/README.md +1 -1
  381. data/tracks/typescript/exercises/phone-number/README.md +4 -3
  382. data/tracks/typescript/exercises/prime-factors/README.md +1 -12
  383. data/tracks/typescript/exercises/pythagorean-triplet/README.md +3 -7
  384. data/tracks/typescript/exercises/rna-transcription/README.md +2 -2
  385. data/tracks/typescript/exercises/robot-simulator/README.md +3 -1
  386. data/tracks/typescript/exercises/scrabble-score/README.md +3 -1
  387. data/tracks/typescript/exercises/series/README.md +0 -4
  388. data/tracks/typescript/exercises/space-age/README.md +1 -1
  389. data/tracks/typescript/exercises/strain/README.md +6 -0
  390. data/tracks/typescript/exercises/sum-of-multiples/README.md +4 -7
  391. data/tracks/typescript/exercises/two-bucket/README.md +15 -19
  392. data/tracks/typescript/exercises/word-count/README.md +1 -2
  393. data/tracks/typescript/exercises/wordy/README.md +0 -5
  394. metadata +61 -5
  395. data/tracks/common-lisp/exercises/bob/.meta/description.md +0 -10
  396. data/tracks/javascript/.eslintrc.json +0 -10
  397. data/tracks/typescript/docs/EXERCISE_README_INSERT.md +0 -24
@@ -1,14 +1,20 @@
1
1
  class TreeNode(object):
2
- def __init__(self, value):
3
- self.value = value
2
+ def __init__(self, data, left, right):
3
+ self.data = None
4
+ self.left = None
5
+ self.right = None
6
+
7
+ def __str__(self):
8
+ fmt = 'TreeNode(data={}, left={}, right={})'
9
+ return fmt.format(self.data, self.left, self.right)
4
10
 
5
11
 
6
12
  class BinarySearchTree(object):
7
- def __init__(self):
13
+ def __init__(self, tree_data):
8
14
  pass
9
15
 
10
- def add(self, value):
16
+ def data(self):
11
17
  pass
12
18
 
13
- def search(self, value):
19
+ def sorted_data(self):
14
20
  pass
@@ -1,57 +1,98 @@
1
1
  import unittest
2
2
 
3
- from binary_search_tree import BinarySearchTree
3
+ from binary_search_tree import BinarySearchTree, TreeNode
4
4
 
5
5
 
6
+ # Tests adapted from `problem-specifications//canonical-data.json` @ v1.0.0
7
+
6
8
  class BinarySearchTreeTests(unittest.TestCase):
7
9
 
8
- def test_add_integer_numbers(self):
9
- bst = BinarySearchTree()
10
- bst.add(1)
11
- bst.add(8)
12
- bst.add(3)
13
- bst.add(5)
14
- bst.add(2)
15
- self.assertEqual(list(bst.list()), [1, 2, 3, 5, 8])
16
-
17
- def test_add_float_numbers(self):
18
- bst = BinarySearchTree()
19
- bst.add(7.5)
20
- bst.add(5.3)
21
- bst.add(5.5)
22
- bst.add(6.0)
23
- bst.add(7.7)
24
- self.assertEqual(list(bst.list()), [5.3, 5.5, 6.0, 7.5, 7.7])
25
-
26
- def test_add_mixed_numbers(self):
27
- bst = BinarySearchTree()
28
- bst.add(1)
29
- bst.add(8)
30
- bst.add(7.5)
31
- bst.add(5.3)
32
- self.assertEqual(list(bst.list()), [1, 5.3, 7.5, 8])
33
-
34
- def test_add_duplicated_numbers(self):
35
- bst = BinarySearchTree()
36
- bst.add(1)
37
- bst.add(1)
38
- bst.add(7.5)
39
- bst.add(5.3)
40
- self.assertEqual(list(bst.list()), [1, 1, 5.3, 7.5])
41
-
42
- def test_search_existent_numbers(self):
43
- bst = BinarySearchTree()
44
- bst.add(1)
45
- bst.add(7.5)
46
- self.assertEqual(bst.search(1).value, 1)
47
- self.assertEqual(bst.search(7.5).value, 7.5)
48
-
49
- def test_search_nonexistent_numbers(self):
50
- bst = BinarySearchTree()
51
- bst.add(1)
52
- bst.add(7.5)
53
- self.assertIs(bst.search(6), None)
54
- self.assertIs(bst.search(8.8), None)
10
+ def test_data_is_retained(self):
11
+ expected = TreeNode('4', None, None)
12
+ self.assertTreeEqual(BinarySearchTree(['4']).data(), expected)
13
+
14
+ # Test inserting data at proper node
15
+ def test_smaller_data_at_left_node(self):
16
+ expected = TreeNode('4', TreeNode('2', None, None), None)
17
+ self.assertTreeEqual(BinarySearchTree(['4', '2']).data(), expected)
18
+
19
+ def test_same_number_at_left_node(self):
20
+ expected = TreeNode('4', TreeNode('4', None, None), None)
21
+ self.assertTreeEqual(BinarySearchTree(['4', '4']).data(), expected)
22
+
23
+ def test_greater_number_at_right_node(self):
24
+ expected = TreeNode('4', None, TreeNode('5', None, None))
25
+ self.assertTreeEqual(BinarySearchTree(['4', '5']).data(), expected)
26
+
27
+ def test_can_create_complex_tree(self):
28
+ expected = TreeNode(
29
+ '4',
30
+ TreeNode(
31
+ '2',
32
+ TreeNode('1', None, None),
33
+ TreeNode('3', None, None)
34
+ ),
35
+ TreeNode(
36
+ '6',
37
+ TreeNode('5', None, None),
38
+ TreeNode('7', None, None)
39
+ )
40
+ )
41
+ self.assertTreeEqual(
42
+ BinarySearchTree(['4', '2', '6', '1', '3', '5', '7']).data(),
43
+ expected
44
+ )
45
+
46
+ # Test can sort data
47
+ def test_can_sort_single_number(self):
48
+ self.assertEqual(BinarySearchTree(['2']).sorted_data(), ['2'])
49
+
50
+ def test_can_sort_if_second_number_is_smaller_than_first(self):
51
+ self.assertEqual(
52
+ BinarySearchTree(['2', '1']).sorted_data(), ['1', '2']
53
+ )
54
+
55
+ def test_can_sort_if_second_number_is_same_as_first(self):
56
+ self.assertEqual(
57
+ BinarySearchTree(['2', '2']).sorted_data(), ['2', '2']
58
+ )
59
+
60
+ def test_can_sort_if_second_number_is_greater_than_first(self):
61
+ self.assertEqual(
62
+ BinarySearchTree(['2', '3']).sorted_data(), ['2', '3']
63
+ )
64
+
65
+ def test_can_sort_complex_tree(self):
66
+ self.assertEqual(
67
+ BinarySearchTree(['2', '1', '3', '6', '7', '5']).sorted_data(),
68
+ ['1', '2', '3', '5', '6', '7']
69
+ )
70
+
71
+ # Utilities
72
+ def assertTreeEqual(self, tree_one, tree_two):
73
+ try:
74
+ self.compare_tree(tree_one, tree_two)
75
+ except AssertionError:
76
+ raise AssertionError("{} != {}".format(tree_one, tree_two))
77
+
78
+ def compare_tree(self, tree_one, tree_two):
79
+ self.assertEqual(tree_one.data, tree_two.data)
80
+
81
+ # Compare left tree nodes
82
+ if tree_one.left and tree_two.left:
83
+ self.compare_tree(tree_one.left, tree_two.left)
84
+ elif tree_one.left is None and tree_two.left is None:
85
+ pass
86
+ else:
87
+ raise AssertionError
88
+
89
+ # Compare right tree nodes
90
+ if tree_one.right and tree_two.right:
91
+ self.compare_tree(tree_one.right, tree_two.right)
92
+ elif tree_one.right is None and tree_two.right is None:
93
+ pass
94
+ else:
95
+ raise AssertionError
55
96
 
56
97
 
57
98
  if __name__ == '__main__':
@@ -1,61 +1,51 @@
1
- from collections import deque
2
-
3
-
4
1
  class TreeNode(object):
5
- def __init__(self, value):
6
- self.value = value
7
- self.left_node = None
8
- self.right_node = None
2
+ def __init__(self, data, left, right):
3
+ self.data = data
4
+ self.left = left
5
+ self.right = right
9
6
 
10
7
  def __str__(self):
11
- return str(self.value)
8
+ fmt = 'TreeNode(data={}, left={}, right={})'
9
+ return fmt.format(self.data, self.left, self.right)
12
10
 
13
11
 
14
12
  class BinarySearchTree(object):
15
- def __init__(self):
13
+ def __init__(self, tree_data):
16
14
  self.root = None
17
-
18
- def add(self, value):
19
- if(self.root is None):
20
- self.root = TreeNode(value)
21
- else:
22
- inserted = False
23
- cur_node = self.root
24
-
25
- while not inserted:
26
- if(value <= cur_node.value):
27
- if(cur_node.left_node):
28
- cur_node = cur_node.left_node
29
- else:
30
- cur_node.left_node = TreeNode(value)
31
- inserted = True
32
- elif(value > cur_node.value):
33
- if(cur_node.right_node):
34
- cur_node = cur_node.right_node
35
- else:
36
- cur_node.right_node = TreeNode(value)
37
- inserted = True
38
-
39
- def search(self, value):
15
+ for data in tree_data:
16
+ self.add(data)
17
+
18
+ def add(self, data):
19
+ if self.root is None:
20
+ self.root = TreeNode(data, None, None)
21
+ return
22
+ inserted = False
40
23
  cur_node = self.root
41
- found = False
42
- while not found:
43
- if(cur_node is None):
44
- return None
45
- elif(value < cur_node.value):
46
- cur_node = cur_node.left_node
47
- elif(value > cur_node.value):
48
- cur_node = cur_node.right_node
49
- elif(value == cur_node.value):
50
- return cur_node
51
-
52
- def list(self):
53
- elements = deque()
54
- self.trav_inorder(self.root, elements)
55
- return elements
56
24
 
57
- def trav_inorder(self, node, elements):
58
- if(node is not None):
59
- self.trav_inorder(node.left_node, elements)
60
- elements.append(node.value)
61
- self.trav_inorder(node.right_node, elements)
25
+ while not inserted:
26
+ if data <= cur_node.data:
27
+ if cur_node.left:
28
+ cur_node = cur_node.left
29
+ else:
30
+ cur_node.left = TreeNode(data, None, None)
31
+ inserted = True
32
+ elif data > cur_node.data:
33
+ if cur_node.right:
34
+ cur_node = cur_node.right
35
+ else:
36
+ cur_node.right = TreeNode(data, None, None)
37
+ inserted = True
38
+
39
+ def _inorder_traverse(self, node, elements):
40
+ if node is not None:
41
+ self._inorder_traverse(node.left, elements)
42
+ elements.append(node.data)
43
+ self._inorder_traverse(node.right, elements)
44
+
45
+ def data(self):
46
+ return self.root
47
+
48
+ def sorted_data(self):
49
+ elements = []
50
+ self._inorder_traverse(self.root, elements)
51
+ return elements
@@ -3,7 +3,7 @@ import unittest
3
3
  from binary_search import binary_search
4
4
 
5
5
 
6
- # Tests adapted from `problem-specifications//canonical-data.json` @ v1.0.0
6
+ # Tests adapted from `problem-specifications//canonical-data.json` @ v1.1.0
7
7
 
8
8
  class BinarySearchTests(unittest.TestCase):
9
9
  def test_finds_value_in_array_with_one_element(self):
@@ -3,75 +3,54 @@ import unittest
3
3
  from book_store import calculate_total
4
4
 
5
5
 
6
- # Tests adapted from `problem-specifications//canonical-data.json` @ v1.1.0
6
+ # Tests adapted from `problem-specifications//canonical-data.json` @ v1.3.0
7
7
 
8
8
  class BookStoreTests(unittest.TestCase):
9
9
  def test_only_a_single_book(self):
10
- self.assertAlmostEqual(calculate_total([1]), 8.00,
11
- places=2)
10
+ self.assertEqual(calculate_total([1]), 800)
12
11
 
13
12
  def test_two_of_the_same_book(self):
14
- self.assertAlmostEqual(calculate_total([2, 2]), 16.00,
15
- places=2)
13
+ self.assertEqual(calculate_total([2, 2]), 1600)
16
14
 
17
15
  def test_empty_basket(self):
18
- self.assertAlmostEqual(calculate_total([]), 0.00,
19
- places=2)
16
+ self.assertEqual(calculate_total([]), 0)
20
17
 
21
18
  def test_two_different_books(self):
22
- self.assertAlmostEqual(calculate_total([1, 2]), 15.20,
23
- places=2)
19
+ self.assertEqual(calculate_total([1, 2]), 1520)
24
20
 
25
21
  def test_three_different_books(self):
26
- self.assertAlmostEqual(calculate_total([1, 2, 3]), 21.60,
27
- places=2)
22
+ self.assertEqual(calculate_total([1, 2, 3]), 2160)
28
23
 
29
24
  def test_four_different_books(self):
30
- self.assertAlmostEqual(calculate_total([1, 2, 3, 4]), 25.60,
31
- places=2)
25
+ self.assertEqual(calculate_total([1, 2, 3, 4]), 2560)
32
26
 
33
27
  def test_five_different_books(self):
34
- self.assertAlmostEqual(
35
- calculate_total([1, 2, 3, 4, 5]), 30.00,
36
- places=2)
28
+ self.assertEqual(calculate_total([1, 2, 3, 4, 5]), 3000)
37
29
 
38
30
  def test_two_groups_of_4_is_cheaper_than_group_of_5_plus_group_of_3(self):
39
- self.assertAlmostEqual(
40
- calculate_total([1, 1, 2, 2, 3, 3, 4, 5]), 51.20,
41
- places=2)
31
+ self.assertEqual(calculate_total([1, 1, 2, 2, 3, 3, 4, 5]), 5120)
42
32
 
43
33
  def test_group_of_4_plus_group_of_2_is_cheaper_than_2_groups_of_3(self):
44
- self.assertAlmostEqual(
45
- calculate_total([1, 1, 2, 2, 3, 4]), 40.80,
46
- places=2)
34
+ self.assertEqual(calculate_total([1, 1, 2, 2, 3, 4]), 4080)
47
35
 
48
36
  def test_two_each_of_first_4_books_and_1_copy_each_of_rest(self):
49
- self.assertAlmostEqual(
50
- calculate_total([1, 1, 2, 2, 3, 3, 4, 4, 5]), 55.60,
51
- places=2)
37
+ self.assertEqual(calculate_total([1, 1, 2, 2, 3, 3, 4, 4, 5]), 5560)
52
38
 
53
39
  def test_two_copies_of_each_book(self):
54
- self.assertAlmostEqual(
55
- calculate_total([1, 1, 2, 2, 3, 3, 4, 4, 5, 5]), 60.00,
56
- places=2)
40
+ self.assertEqual(calculate_total([1, 1, 2, 2, 3, 3, 4, 4, 5, 5]), 6000)
57
41
 
58
42
  def test_three_copies_of_first_book_and_2_each_of_remaining(self):
59
- self.assertAlmostEqual(
60
- calculate_total([1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 1]),
61
- 68.00,
62
- places=2)
43
+ self.assertEqual(
44
+ calculate_total([1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 1]), 6800)
63
45
 
64
46
  def test_three_each_of_first_2_books_and_2_each_of_remaining_books(self):
65
- self.assertAlmostEqual(
66
- calculate_total([1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 1, 2]),
67
- 75.20,
68
- places=2)
47
+ self.assertEqual(
48
+ calculate_total([1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 1, 2]), 7520)
69
49
 
70
50
  def test_four_groups_of_4_are_cheaper_than_2_groups_each_of_5_and_3(self):
71
- self.assertAlmostEqual(
51
+ self.assertEqual(
72
52
  calculate_total([1, 1, 2, 2, 3, 3, 4, 5, 1, 1, 2, 2, 3, 3, 4, 5]),
73
- 102.40,
74
- places=2)
53
+ 10240)
75
54
 
76
55
 
77
56
  if __name__ == '__main__':
@@ -1,4 +1,4 @@
1
- BOOK_PRICE = 8
1
+ BOOK_PRICE = 800
2
2
 
3
3
 
4
4
  def _group_price(size):
@@ -1,5 +1,3 @@
1
-
2
-
3
1
  class BowlingGame(object):
4
2
  def __init__(self):
5
3
  pass
@@ -3,11 +3,9 @@ import unittest
3
3
  from bowling import BowlingGame
4
4
 
5
5
 
6
- # Tests adapted from `problem-specifications//canonical-data.json` @ v1.0.1
6
+ # Tests adapted from `problem-specifications//canonical-data.json` @ v1.2.0
7
7
 
8
8
  class BowlingTests(unittest.TestCase):
9
- def setUp(self):
10
- self.game = BowlingGame()
11
9
 
12
10
  def roll(self, rolls):
13
11
  [self.game.roll(roll) for roll in rolls]
@@ -120,23 +118,27 @@ class BowlingTests(unittest.TestCase):
120
118
 
121
119
  def test_rolls_cannot_score_negative_points(self):
122
120
 
123
- self.assertRaises(ValueError, self.game.roll, -11)
121
+ with self.assertRaisesWithMessage(ValueError):
122
+ self.game.roll(11)
124
123
 
125
124
  def test_a_roll_cannot_score_more_than_10_points(self):
126
125
 
127
- self.assertRaises(ValueError, self.game.roll, 11)
126
+ with self.assertRaisesWithMessage(ValueError):
127
+ self.game.roll(11)
128
128
 
129
129
  def test_two_rolls_in_a_frame_cannot_score_more_than_10_points(self):
130
130
  self.game.roll(5)
131
131
 
132
- self.assertRaises(ValueError, self.game.roll, 6)
132
+ with self.assertRaisesWithMessage(ValueError):
133
+ self.game.roll(6)
133
134
 
134
135
  def test_bonus_after_strike_in_last_frame_cannot_score_more_than_10(self):
135
136
  rolls = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10]
136
137
 
137
138
  self.roll(rolls)
138
139
 
139
- self.assertRaises(ValueError, self.game.roll, 11)
140
+ with self.assertRaisesWithMessage(ValueError):
141
+ self.game.roll(11)
140
142
 
141
143
  def test_bonus_aft_last_frame_strk_can_be_more_than_10_if_1_is_strk(self):
142
144
  rolls = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10,
@@ -151,42 +153,76 @@ class BowlingTests(unittest.TestCase):
151
153
 
152
154
  self.roll(rolls)
153
155
 
154
- self.assertRaises(ValueError, self.game.roll, 10)
156
+ with self.assertRaisesWithMessage(ValueError):
157
+ self.game.roll(10)
155
158
 
156
159
  def test_an_incomplete_game_cannot_be_scored(self):
157
160
  rolls = [0, 0]
158
161
 
159
162
  self.roll(rolls)
160
163
 
161
- self.assertRaises(IndexError, self.game.score)
164
+ with self.assertRaisesWithMessage(IndexError):
165
+ self.game.score()
162
166
 
163
167
  def test_cannot_roll_if_there_are_already_ten_frames(self):
164
168
  rolls = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
165
169
 
166
170
  self.roll(rolls)
167
171
 
168
- self.assertRaises(IndexError, self.game.roll, 0)
172
+ with self.assertRaisesWithMessage(IndexError):
173
+ self.game.roll(0)
169
174
 
170
175
  def test_bonus_rolls_for_strike_must_be_rolled_before_score_is_calc(self):
171
176
  rolls = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10]
172
177
 
173
178
  self.roll(rolls)
174
179
 
175
- self.assertRaises(IndexError, self.game.score)
180
+ with self.assertRaisesWithMessage(IndexError):
181
+ self.game.score()
176
182
 
177
183
  def test_both_bonuses_for_strike_must_be_rolled_before_score(self):
178
184
  rolls = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 10]
179
185
 
180
186
  self.roll(rolls)
181
187
 
182
- self.assertRaises(IndexError, self.game.score)
188
+ with self.assertRaisesWithMessage(IndexError):
189
+ self.game.score()
183
190
 
184
191
  def test_bonus_rolls_for_spare_must_be_rolled_before_score_is_calc(self):
185
192
  rolls = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 3]
186
193
 
187
194
  self.roll(rolls)
188
195
 
189
- self.assertRaises(IndexError, self.game.score)
196
+ with self.assertRaisesWithMessage(IndexError):
197
+ self.game.score()
198
+
199
+ def test_cannot_roll_after_bonus_roll_for_spare(self):
200
+ rolls = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 3, 2]
201
+
202
+ self.roll(rolls)
203
+
204
+ with self.assertRaisesWithMessage(IndexError):
205
+ self.game.roll(2)
206
+
207
+ def test_cannot_roll_after_bonus_rolls_for_strike(self):
208
+ rolls = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10,
209
+ 3, 2]
210
+
211
+ self.roll(rolls)
212
+
213
+ with self.assertRaisesWithMessage(IndexError):
214
+ self.game.roll(2)
215
+
216
+ # Utility functions
217
+ def setUp(self):
218
+ self.game = BowlingGame()
219
+ try:
220
+ self.assertRaisesRegex
221
+ except AttributeError:
222
+ self.assertRaisesRegex = self.assertRaisesRegexp
223
+
224
+ def assertRaisesWithMessage(self, exception):
225
+ return self.assertRaisesRegex(exception, r".+")
190
226
 
191
227
 
192
228
  if __name__ == '__main__':