trackler 2.2.1.151 → 2.2.1.152

Sign up to get free protection for your applications and to get access to all the features.
Files changed (340) hide show
  1. checksums.yaml +4 -4
  2. data/lib/trackler/version.rb +1 -1
  3. data/problem-specifications/exercises/hamming/description.md +4 -3
  4. data/problem-specifications/exercises/isbn-verifier/canonical-data.json +9 -1
  5. data/tracks/clojure/exercises/bob/README.md +2 -0
  6. data/tracks/clojure/exercises/bob/src/example.clj +4 -0
  7. data/tracks/clojure/exercises/bob/test/bob_test.clj +1 -1
  8. data/tracks/clojure/exercises/say/README.md +2 -1
  9. data/tracks/csharp/exercises/acronym/AcronymTest.cs +3 -9
  10. data/tracks/csharp/exercises/all-your-base/AllYourBaseTest.cs +43 -43
  11. data/tracks/csharp/exercises/allergies/AllergiesTest.cs +1 -1
  12. data/tracks/csharp/exercises/alphametics/AlphameticsTest.cs +21 -1
  13. data/tracks/csharp/exercises/anagram/AnagramTest.cs +1 -35
  14. data/tracks/csharp/exercises/atbash-cipher/AtbashCipherTest.cs +1 -1
  15. data/tracks/csharp/exercises/beer-song/BeerSong.cs +1 -6
  16. data/tracks/csharp/exercises/beer-song/BeerSongTest.cs +20 -28
  17. data/tracks/csharp/exercises/beer-song/Example.cs +6 -6
  18. data/tracks/csharp/exercises/binary-search/BinarySearchTest.cs +1 -1
  19. data/tracks/csharp/exercises/bob/BobTest.cs +1 -1
  20. data/tracks/csharp/exercises/book-store/BookStoreTest.cs +1 -1
  21. data/tracks/csharp/exercises/bowling/BowlingTest.cs +47 -29
  22. data/tracks/csharp/exercises/bracket-push/BracketPushTest.cs +36 -29
  23. data/tracks/csharp/exercises/change/Change.cs +1 -1
  24. data/tracks/csharp/exercises/change/ChangeTest.cs +48 -21
  25. data/tracks/csharp/exercises/change/Example.cs +31 -18
  26. data/tracks/csharp/exercises/circular-buffer/CircularBuffer.cs +2 -2
  27. data/tracks/csharp/exercises/circular-buffer/CircularBufferTest.cs +88 -111
  28. data/tracks/csharp/exercises/circular-buffer/Example.cs +7 -7
  29. data/tracks/csharp/exercises/clock/ClockTest.cs +37 -37
  30. data/tracks/csharp/exercises/collatz-conjecture/CollatzConjectureTest.cs +1 -1
  31. data/tracks/csharp/exercises/complex-numbers/ComplexNumbersTest.cs +19 -10
  32. data/tracks/csharp/exercises/connect/ConnectTest.cs +1 -1
  33. data/tracks/csharp/exercises/crypto-square/CryptoSquareTest.cs +1 -1
  34. data/tracks/csharp/exercises/custom-set/.meta/hints.md +3 -3
  35. data/tracks/csharp/exercises/custom-set/CustomSet.cs +10 -49
  36. data/tracks/csharp/exercises/custom-set/CustomSetTest.cs +153 -157
  37. data/tracks/csharp/exercises/custom-set/Example.cs +26 -54
  38. data/tracks/csharp/exercises/difference-of-squares/DifferenceOfSquaresTest.cs +1 -1
  39. data/tracks/csharp/exercises/dominoes/DominoesTest.cs +25 -25
  40. data/tracks/csharp/exercises/etl/Etl.cs +1 -1
  41. data/tracks/csharp/exercises/etl/EtlTest.cs +4 -4
  42. data/tracks/csharp/exercises/etl/Example.cs +1 -1
  43. data/tracks/csharp/exercises/flatten-array/FlattenArrayTest.cs +13 -13
  44. data/tracks/csharp/exercises/food-chain/Example.cs +5 -0
  45. data/tracks/csharp/exercises/food-chain/FoodChain.cs +5 -0
  46. data/tracks/csharp/exercises/food-chain/FoodChainTest.cs +9 -9
  47. data/tracks/csharp/exercises/forth/Example.cs +28 -33
  48. data/tracks/csharp/exercises/forth/Forth.cs +1 -19
  49. data/tracks/csharp/exercises/forth/ForthTest.cs +215 -52
  50. data/tracks/csharp/exercises/gigasecond/GigasecondTest.cs +1 -1
  51. data/tracks/csharp/exercises/grains/GrainsTest.cs +1 -1
  52. data/tracks/csharp/exercises/grep/Example.cs +1 -1
  53. data/tracks/csharp/exercises/grep/Grep.cs +1 -1
  54. data/tracks/csharp/exercises/grep/GrepTest.cs +268 -237
  55. data/tracks/csharp/exercises/hamming/HammingTest.cs +1 -1
  56. data/tracks/csharp/exercises/hello-world/HelloWorldTest.cs +1 -1
  57. data/tracks/csharp/exercises/house/Example.cs +7 -2
  58. data/tracks/csharp/exercises/house/House.cs +5 -0
  59. data/tracks/csharp/exercises/house/HouseTest.cs +40 -223
  60. data/tracks/csharp/exercises/isbn-verifier/IsbnVerifierTest.cs +14 -2
  61. data/tracks/csharp/exercises/isogram/IsogramTest.cs +1 -1
  62. data/tracks/csharp/exercises/kindergarten-garden/KindergartenGardenTest.cs +1 -1
  63. data/tracks/csharp/exercises/largest-series-product/LargestSeriesProductTest.cs +1 -1
  64. data/tracks/csharp/exercises/leap/LeapTest.cs +1 -1
  65. data/tracks/csharp/exercises/luhn/LuhnTest.cs +1 -1
  66. data/tracks/csharp/exercises/markdown/MarkdownTest.cs +34 -27
  67. data/tracks/csharp/exercises/minesweeper/MinesweeperTest.cs +29 -34
  68. data/tracks/csharp/exercises/nth-prime/NthPrimeTest.cs +1 -1
  69. data/tracks/csharp/exercises/nucleotide-count/NucleotideCountTest.cs +1 -1
  70. data/tracks/csharp/exercises/ocr-numbers/OcrNumbersTest.cs +35 -35
  71. data/tracks/csharp/exercises/pangram/PangramTest.cs +1 -1
  72. data/tracks/csharp/exercises/pascals-triangle/PascalsTriangleTest.cs +1 -1
  73. data/tracks/csharp/exercises/perfect-numbers/PerfectNumbersTest.cs +1 -1
  74. data/tracks/csharp/exercises/phone-number/PhoneNumberTest.cs +17 -3
  75. data/tracks/csharp/exercises/pig-latin/PigLatinTest.cs +1 -1
  76. data/tracks/csharp/exercises/poker/PokerTest.cs +1 -1
  77. data/tracks/csharp/exercises/prime-factors/PrimeFactorsTest.cs +1 -1
  78. data/tracks/csharp/exercises/protein-translation/Example.cs +4 -4
  79. data/tracks/csharp/exercises/protein-translation/ProteinTranslation.cs +1 -1
  80. data/tracks/csharp/exercises/protein-translation/ProteinTranslationTest.cs +104 -45
  81. data/tracks/csharp/exercises/proverb/ProverbTest.cs +38 -6
  82. data/tracks/csharp/exercises/queen-attack/QueenAttackTest.cs +1 -1
  83. data/tracks/csharp/exercises/rail-fence-cipher/RailFenceCipherTest.cs +1 -1
  84. data/tracks/csharp/exercises/raindrops/RaindropsTest.cs +1 -1
  85. data/tracks/csharp/exercises/rectangles/RectanglesTest.cs +63 -21
  86. data/tracks/csharp/exercises/reverse-string/ReverseStringTest.cs +1 -1
  87. data/tracks/csharp/exercises/rna-transcription/RnaTranscriptionTest.cs +1 -1
  88. data/tracks/csharp/exercises/roman-numerals/RomanNumeralsTest.cs +7 -1
  89. data/tracks/csharp/exercises/rotational-cipher/RotationalCipherTest.cs +1 -1
  90. data/tracks/csharp/exercises/run-length-encoding/RunLengthEncodingTest.cs +1 -1
  91. data/tracks/csharp/exercises/saddle-points/SaddlePointsTest.cs +11 -11
  92. data/tracks/csharp/exercises/say/SayTest.cs +1 -1
  93. data/tracks/csharp/exercises/scale-generator/Example.cs +5 -0
  94. data/tracks/csharp/exercises/scale-generator/ScaleGenerator.cs +5 -0
  95. data/tracks/csharp/exercises/scale-generator/ScaleGeneratorTest.cs +56 -47
  96. data/tracks/csharp/exercises/scrabble-score/ScrabbleScoreTest.cs +1 -1
  97. data/tracks/csharp/exercises/secret-handshake/SecretHandshakeTest.cs +1 -1
  98. data/tracks/csharp/exercises/sieve/SieveTest.cs +1 -1
  99. data/tracks/csharp/exercises/space-age/SpaceAgeTest.cs +1 -1
  100. data/tracks/csharp/exercises/spiral-matrix/SpiralMatrixTest.cs +28 -34
  101. data/tracks/csharp/exercises/sum-of-multiples/SumOfMultiplesTest.cs +1 -1
  102. data/tracks/csharp/exercises/tournament/Example.cs +15 -7
  103. data/tracks/csharp/exercises/tournament/TournamentTest.cs +97 -99
  104. data/tracks/csharp/exercises/transpose/TransposeTest.cs +50 -96
  105. data/tracks/csharp/exercises/triangle/TriangleTest.cs +1 -1
  106. data/tracks/csharp/exercises/twelve-days/TwelveDays.cs +1 -1
  107. data/tracks/csharp/exercises/two-bucket/TwoBucketTest.cs +1 -1
  108. data/tracks/csharp/exercises/two-fer/TwoFerTest.cs +1 -1
  109. data/tracks/csharp/exercises/variable-length-quantity/Example.cs +3 -3
  110. data/tracks/csharp/exercises/variable-length-quantity/VariableLengthQuantity.cs +2 -2
  111. data/tracks/csharp/exercises/variable-length-quantity/VariableLengthQuantityTest.cs +165 -40
  112. data/tracks/csharp/exercises/word-count/Example.cs +1 -1
  113. data/tracks/csharp/exercises/word-count/WordCount.cs +1 -1
  114. data/tracks/csharp/exercises/word-count/WordCountTest.cs +12 -12
  115. data/tracks/csharp/exercises/wordy/WordyTest.cs +1 -1
  116. data/tracks/csharp/exercises/yacht/Example.cs +2 -5
  117. data/tracks/csharp/exercises/yacht/YachtTest.cs +7 -1
  118. data/tracks/csharp/exercises/zebra-puzzle/Example.cs +4 -4
  119. data/tracks/csharp/exercises/zebra-puzzle/ZebraPuzzle.cs +2 -2
  120. data/tracks/csharp/exercises/zebra-puzzle/ZebraPuzzleTest.cs +7 -5
  121. data/tracks/csharp/generators/Exercises/AllYourBase.cs +1 -0
  122. data/tracks/csharp/generators/Exercises/Alphametics.cs +5 -2
  123. data/tracks/csharp/generators/Exercises/BeerSong.cs +3 -0
  124. data/tracks/csharp/generators/Exercises/BinarySearch.cs +1 -0
  125. data/tracks/csharp/generators/Exercises/BookStore.cs +2 -0
  126. data/tracks/csharp/generators/Exercises/Bowling.cs +20 -15
  127. data/tracks/csharp/generators/Exercises/BracketPush.cs +1 -1
  128. data/tracks/csharp/generators/Exercises/Change.cs +20 -0
  129. data/tracks/csharp/generators/Exercises/CircularBuffer.cs +74 -0
  130. data/tracks/csharp/generators/Exercises/Clock.cs +7 -8
  131. data/tracks/csharp/generators/Exercises/ComplexNumbers.cs +9 -16
  132. data/tracks/csharp/generators/Exercises/Connect.cs +6 -6
  133. data/tracks/csharp/generators/Exercises/CustomSet.cs +56 -0
  134. data/tracks/csharp/generators/Exercises/Dominoes.cs +2 -2
  135. data/tracks/csharp/generators/Exercises/Etl.cs +7 -35
  136. data/tracks/csharp/generators/Exercises/FlattenArray.cs +9 -13
  137. data/tracks/csharp/generators/Exercises/FoodChain.cs +5 -0
  138. data/tracks/csharp/generators/Exercises/Forth.cs +25 -0
  139. data/tracks/csharp/generators/Exercises/Gigasecond.cs +4 -4
  140. data/tracks/csharp/generators/Exercises/Grains.cs +1 -1
  141. data/tracks/csharp/generators/Exercises/Grep.cs +106 -0
  142. data/tracks/csharp/generators/Exercises/Hamming.cs +1 -1
  143. data/tracks/csharp/generators/Exercises/House.cs +5 -0
  144. data/tracks/csharp/generators/Exercises/KindergartenGarden.cs +3 -3
  145. data/tracks/csharp/generators/Exercises/Markdown.cs +25 -0
  146. data/tracks/csharp/generators/Exercises/Meetup.cs +6 -6
  147. data/tracks/csharp/generators/Exercises/Minesweeper.cs +14 -4
  148. data/tracks/csharp/generators/Exercises/OcrNumbers.cs +12 -3
  149. data/tracks/csharp/generators/Exercises/PascalsTriangle.cs +0 -7
  150. data/tracks/csharp/generators/Exercises/ProteinTranslation.cs +8 -0
  151. data/tracks/csharp/generators/Exercises/Proverb.cs +7 -5
  152. data/tracks/csharp/generators/Exercises/QueenAttack.cs +3 -3
  153. data/tracks/csharp/generators/Exercises/Rectangles.cs +17 -0
  154. data/tracks/csharp/generators/Exercises/RobotSimulator.cs +6 -6
  155. data/tracks/csharp/generators/Exercises/SaddlePoints.cs +2 -2
  156. data/tracks/csharp/generators/Exercises/Say.cs +1 -1
  157. data/tracks/csharp/generators/Exercises/ScaleGenerator.cs +15 -0
  158. data/tracks/csharp/generators/Exercises/SpiralMatrix.cs +45 -0
  159. data/tracks/csharp/generators/Exercises/Sublist.cs +4 -5
  160. data/tracks/csharp/generators/Exercises/SumOfMultiples.cs +10 -1
  161. data/tracks/csharp/generators/Exercises/Tournament.cs +11 -19
  162. data/tracks/csharp/generators/Exercises/Transpose.cs +2 -2
  163. data/tracks/csharp/generators/Exercises/Triangle.cs +1 -3
  164. data/tracks/csharp/generators/Exercises/TwelveDays.cs +3 -4
  165. data/tracks/csharp/generators/Exercises/TwoBucket.cs +5 -5
  166. data/tracks/csharp/generators/Exercises/TwoFer.cs +11 -2
  167. data/tracks/csharp/generators/Exercises/VariableLengthQuantity.cs +44 -0
  168. data/tracks/csharp/generators/Exercises/Yacht.cs +11 -10
  169. data/tracks/csharp/generators/Exercises/ZebraPuzzle.cs +19 -0
  170. data/tracks/csharp/generators/GeneratorExercise.cs +6 -6
  171. data/tracks/csharp/generators/Input/CanonicalData.cs +6 -9
  172. data/tracks/csharp/generators/Input/CanonicalDataCase.cs +13 -46
  173. data/tracks/csharp/generators/Input/CanonicalDataCaseParser.cs +170 -0
  174. data/tracks/csharp/generators/Input/CanonicalDataFile.cs +1 -2
  175. data/tracks/csharp/generators/Input/CanonicalDataParser.cs +16 -12
  176. data/tracks/csharp/generators/Input/ConfigFile.cs +0 -5
  177. data/tracks/csharp/generators/Input/ConvertHelper.cs +20 -0
  178. data/tracks/csharp/generators/Output/Templates/_TestClassDisposable.liquid +14 -0
  179. data/tracks/csharp/generators/Output/TestMethodBodyData.cs +11 -14
  180. data/tracks/csharp/generators/Output/ValueFormatter.cs +20 -7
  181. data/tracks/delphi/config.json +22 -0
  182. data/tracks/delphi/exercises/grade-school/GradeSchool.dpr +60 -0
  183. data/tracks/delphi/exercises/grade-school/README.md +62 -0
  184. data/tracks/delphi/exercises/grade-school/uGradeSchoolExample.pas +134 -0
  185. data/tracks/delphi/exercises/grade-school/uGradeSchoolTest.pas +150 -0
  186. data/tracks/delphi/exercises/hamming/README.md +4 -3
  187. data/tracks/delphi/exercises/proverb/Proverb.dpr +60 -0
  188. data/tracks/delphi/exercises/proverb/README.md +44 -0
  189. data/tracks/delphi/exercises/proverb/uProverbExample.pas +60 -0
  190. data/tracks/delphi/exercises/proverb/uProverbTests.pas +124 -0
  191. data/tracks/go/exercises/bracket-push/README.md +3 -2
  192. data/tracks/go/exercises/bracket-push/cases_test.go +7 -2
  193. data/tracks/go/exercises/isbn-verifier/cases_test.go +4 -3
  194. data/tracks/go/exercises/yacht/cases_test.go +8 -2
  195. data/tracks/java/exercises/armstrong-numbers/README.md +1 -1
  196. data/tracks/java/exercises/binary-search-tree/src/test/java/BinarySearchTreeTest.java +22 -22
  197. data/tracks/java/exercises/bracket-push/README.md +3 -2
  198. data/tracks/java/exercises/crypto-square/README.md +23 -19
  199. data/tracks/java/exercises/grade-school/src/test/java/SchoolTest.java +1 -1
  200. data/tracks/java/exercises/poker/.meta/{version.txt → version} +0 -0
  201. data/tracks/java/exercises/queen-attack/src/test/java/QueenAttackCalculatorTest.java +7 -7
  202. data/tracks/java/exercises/rail-fence-cipher/.meta/version +1 -0
  203. data/tracks/java/exercises/robot-simulator/src/test/java/RobotTest.java +45 -45
  204. data/tracks/nim/config.json +24 -0
  205. data/tracks/nim/exercises/armstrong-numbers/README.md +18 -0
  206. data/tracks/nim/exercises/armstrong-numbers/armstrong_number_test.nim +29 -0
  207. data/tracks/nim/exercises/armstrong-numbers/example.nim +11 -0
  208. data/tracks/nim/exercises/leap/leap_test.nim +12 -10
  209. data/tracks/nim/exercises/two-fer/README.md +19 -0
  210. data/tracks/nim/exercises/two-fer/example.nim +3 -0
  211. data/tracks/nim/exercises/two-fer/two_fer_test.nim +16 -0
  212. data/tracks/python/.travis.yml +0 -1
  213. data/tracks/python/README.md +1 -1
  214. data/tracks/python/config/exercise_readme.go.tmpl +1 -1
  215. data/tracks/python/docs/INSTALLATION.md +1 -1
  216. data/tracks/python/exercises/accumulate/README.md +1 -1
  217. data/tracks/python/exercises/acronym/README.md +1 -1
  218. data/tracks/python/exercises/all-your-base/README.md +1 -1
  219. data/tracks/python/exercises/allergies/README.md +1 -1
  220. data/tracks/python/exercises/alphametics/README.md +1 -1
  221. data/tracks/python/exercises/anagram/README.md +1 -1
  222. data/tracks/python/exercises/armstrong-numbers/README.md +2 -2
  223. data/tracks/python/exercises/atbash-cipher/README.md +1 -1
  224. data/tracks/python/exercises/bank-account/README.md +1 -1
  225. data/tracks/python/exercises/beer-song/README.md +1 -1
  226. data/tracks/python/exercises/binary-search-tree/README.md +1 -1
  227. data/tracks/python/exercises/binary-search/README.md +1 -1
  228. data/tracks/python/exercises/binary/README.md +1 -1
  229. data/tracks/python/exercises/bob/README.md +1 -1
  230. data/tracks/python/exercises/book-store/README.md +1 -1
  231. data/tracks/python/exercises/bowling/README.md +1 -1
  232. data/tracks/python/exercises/bracket-push/README.md +4 -3
  233. data/tracks/python/exercises/change/README.md +1 -1
  234. data/tracks/python/exercises/circular-buffer/README.md +1 -1
  235. data/tracks/python/exercises/clock/README.md +1 -1
  236. data/tracks/python/exercises/collatz-conjecture/README.md +1 -1
  237. data/tracks/python/exercises/complex-numbers/README.md +1 -1
  238. data/tracks/python/exercises/connect/README.md +1 -1
  239. data/tracks/python/exercises/crypto-square/README.md +1 -1
  240. data/tracks/python/exercises/custom-set/README.md +1 -1
  241. data/tracks/python/exercises/diamond/README.md +1 -1
  242. data/tracks/python/exercises/difference-of-squares/README.md +1 -1
  243. data/tracks/python/exercises/diffie-hellman/README.md +1 -1
  244. data/tracks/python/exercises/dominoes/README.md +1 -1
  245. data/tracks/python/exercises/dot-dsl/README.md +1 -1
  246. data/tracks/python/exercises/error-handling/README.md +1 -1
  247. data/tracks/python/exercises/etl/README.md +1 -1
  248. data/tracks/python/exercises/flatten-array/README.md +1 -1
  249. data/tracks/python/exercises/food-chain/README.md +1 -1
  250. data/tracks/python/exercises/forth/README.md +1 -1
  251. data/tracks/python/exercises/gigasecond/README.md +1 -1
  252. data/tracks/python/exercises/go-counting/README.md +1 -1
  253. data/tracks/python/exercises/grade-school/README.md +1 -1
  254. data/tracks/python/exercises/grains/README.md +1 -1
  255. data/tracks/python/exercises/grep/README.md +1 -1
  256. data/tracks/python/exercises/hamming/README.md +1 -1
  257. data/tracks/python/exercises/hello-world/README.md +1 -1
  258. data/tracks/python/exercises/hexadecimal/README.md +1 -1
  259. data/tracks/python/exercises/house/README.md +1 -1
  260. data/tracks/python/exercises/isbn-verifier/README.md +1 -1
  261. data/tracks/python/exercises/isogram/README.md +1 -1
  262. data/tracks/python/exercises/kindergarten-garden/README.md +1 -1
  263. data/tracks/python/exercises/largest-series-product/README.md +1 -1
  264. data/tracks/python/exercises/leap/README.md +1 -1
  265. data/tracks/python/exercises/linked-list/README.md +1 -1
  266. data/tracks/python/exercises/list-ops/README.md +1 -1
  267. data/tracks/python/exercises/luhn/README.md +1 -1
  268. data/tracks/python/exercises/markdown/README.md +1 -1
  269. data/tracks/python/exercises/matrix/README.md +1 -1
  270. data/tracks/python/exercises/meetup/README.md +1 -1
  271. data/tracks/python/exercises/minesweeper/README.md +1 -1
  272. data/tracks/python/exercises/nth-prime/README.md +1 -1
  273. data/tracks/python/exercises/nucleotide-count/README.md +1 -1
  274. data/tracks/python/exercises/ocr-numbers/README.md +1 -1
  275. data/tracks/python/exercises/octal/README.md +1 -1
  276. data/tracks/python/exercises/palindrome-products/README.md +1 -1
  277. data/tracks/python/exercises/pangram/README.md +1 -1
  278. data/tracks/python/exercises/parallel-letter-frequency/README.md +1 -1
  279. data/tracks/python/exercises/pascals-triangle/README.md +1 -1
  280. data/tracks/python/exercises/perfect-numbers/README.md +1 -1
  281. data/tracks/python/exercises/phone-number/README.md +1 -1
  282. data/tracks/python/exercises/pig-latin/README.md +1 -1
  283. data/tracks/python/exercises/point-mutations/README.md +1 -1
  284. data/tracks/python/exercises/poker/README.md +1 -1
  285. data/tracks/python/exercises/pov/README.md +1 -1
  286. data/tracks/python/exercises/prime-factors/README.md +1 -1
  287. data/tracks/python/exercises/protein-translation/README.md +1 -1
  288. data/tracks/python/exercises/proverb/README.md +1 -1
  289. data/tracks/python/exercises/pythagorean-triplet/README.md +1 -1
  290. data/tracks/python/exercises/queen-attack/README.md +1 -1
  291. data/tracks/python/exercises/rail-fence-cipher/README.md +1 -1
  292. data/tracks/python/exercises/raindrops/README.md +1 -1
  293. data/tracks/python/exercises/rational-numbers/README.md +1 -1
  294. data/tracks/python/exercises/react/README.md +1 -1
  295. data/tracks/python/exercises/rectangles/README.md +1 -1
  296. data/tracks/python/exercises/reverse-string/README.md +1 -1
  297. data/tracks/python/exercises/rna-transcription/README.md +1 -1
  298. data/tracks/python/exercises/robot-name/README.md +1 -1
  299. data/tracks/python/exercises/robot-simulator/README.md +1 -1
  300. data/tracks/python/exercises/roman-numerals/README.md +1 -1
  301. data/tracks/python/exercises/rotational-cipher/README.md +1 -1
  302. data/tracks/python/exercises/run-length-encoding/README.md +1 -1
  303. data/tracks/python/exercises/saddle-points/README.md +1 -1
  304. data/tracks/python/exercises/say/README.md +1 -1
  305. data/tracks/python/exercises/scale-generator/README.md +1 -1
  306. data/tracks/python/exercises/scrabble-score/README.md +1 -1
  307. data/tracks/python/exercises/secret-handshake/README.md +1 -1
  308. data/tracks/python/exercises/series/README.md +1 -1
  309. data/tracks/python/exercises/sgf-parsing/README.md +1 -1
  310. data/tracks/python/exercises/sieve/README.md +1 -1
  311. data/tracks/python/exercises/simple-cipher/README.md +1 -1
  312. data/tracks/python/exercises/simple-linked-list/README.md +1 -1
  313. data/tracks/python/exercises/space-age/README.md +1 -1
  314. data/tracks/python/exercises/spiral-matrix/README.md +1 -1
  315. data/tracks/python/exercises/strain/README.md +1 -1
  316. data/tracks/python/exercises/sublist/README.md +1 -1
  317. data/tracks/python/exercises/sum-of-multiples/README.md +1 -1
  318. data/tracks/python/exercises/tournament/README.md +1 -1
  319. data/tracks/python/exercises/transpose/README.md +1 -1
  320. data/tracks/python/exercises/tree-building/README.md +1 -1
  321. data/tracks/python/exercises/triangle/README.md +1 -1
  322. data/tracks/python/exercises/trinary/README.md +1 -1
  323. data/tracks/python/exercises/twelve-days/README.md +1 -1
  324. data/tracks/python/exercises/two-bucket/README.md +1 -1
  325. data/tracks/python/exercises/two-fer/README.md +1 -1
  326. data/tracks/python/exercises/variable-length-quantity/README.md +1 -1
  327. data/tracks/python/exercises/word-count/README.md +1 -1
  328. data/tracks/python/exercises/word-search/README.md +1 -1
  329. data/tracks/python/exercises/wordy/README.md +1 -1
  330. data/tracks/python/exercises/yacht/README.md +1 -1
  331. data/tracks/python/exercises/zebra-puzzle/README.md +1 -1
  332. data/tracks/python/exercises/zipper/README.md +1 -1
  333. data/tracks/python/requirements-travis.txt +1 -1
  334. data/tracks/swift/exercises/scale-generator/Tests/ScaleGeneratorTests/ScaleGeneratorTests.swift +1 -1
  335. metadata +32 -8
  336. data/tracks/csharp/generators/Input/CanonicalDataCaseJson.cs +0 -73
  337. data/tracks/csharp/generators/Input/CanonicalDataCaseJsonConverter.cs +0 -49
  338. data/tracks/csharp/generators/Input/CanonicalDataCasesJson.cs +0 -58
  339. data/tracks/csharp/generators/Input/CanonicalDataCasesJsonConverter.cs +0 -17
  340. data/tracks/java/exercises/go-counting/src/main/java/.keep +0 -0
@@ -1,4 +1,4 @@
1
- // This file was auto-generated based on version 1.0.0 of the canonical data.
1
+ // This file was auto-generated based on version 1.1.0 of the canonical data.
2
2
 
3
3
  using Xunit;
4
4
 
@@ -2,12 +2,7 @@
2
2
 
3
3
  public static class BeerSong
4
4
  {
5
- public static string Verse(int number)
6
- {
7
- throw new NotImplementedException("You need to implement this function.");
8
- }
9
-
10
- public static string Verses(int begin, int end)
5
+ public static string Recite(int startBottles, int takeDown)
11
6
  {
12
7
  throw new NotImplementedException("You need to implement this function.");
13
8
  }
@@ -1,4 +1,4 @@
1
- // This file was auto-generated based on version 1.0.0 of the canonical data.
1
+ // This file was auto-generated based on version 2.1.0 of the canonical data.
2
2
 
3
3
  using Xunit;
4
4
 
@@ -9,9 +9,8 @@ public void First_generic_verse()
9
9
  {
10
10
  var expected =
11
11
  "99 bottles of beer on the wall, 99 bottles of beer.\n" +
12
- "Take one down and pass it around, 98 bottles of beer on the wall.\n" +
13
- "";
14
- Assert.Equal(expected, BeerSong.Verse(99));
12
+ "Take one down and pass it around, 98 bottles of beer on the wall.";
13
+ Assert.Equal(expected, BeerSong.Recite(99, 1));
15
14
  }
16
15
 
17
16
  [Fact(Skip = "Remove to run test")]
@@ -19,39 +18,35 @@ public void Last_generic_verse()
19
18
  {
20
19
  var expected =
21
20
  "3 bottles of beer on the wall, 3 bottles of beer.\n" +
22
- "Take one down and pass it around, 2 bottles of beer on the wall.\n" +
23
- "";
24
- Assert.Equal(expected, BeerSong.Verse(3));
21
+ "Take one down and pass it around, 2 bottles of beer on the wall.";
22
+ Assert.Equal(expected, BeerSong.Recite(3, 1));
25
23
  }
26
24
 
27
25
  [Fact(Skip = "Remove to run test")]
28
- public void Verse_2()
26
+ public void Verse_with_2_bottles()
29
27
  {
30
28
  var expected =
31
29
  "2 bottles of beer on the wall, 2 bottles of beer.\n" +
32
- "Take one down and pass it around, 1 bottle of beer on the wall.\n" +
33
- "";
34
- Assert.Equal(expected, BeerSong.Verse(2));
30
+ "Take one down and pass it around, 1 bottle of beer on the wall.";
31
+ Assert.Equal(expected, BeerSong.Recite(2, 1));
35
32
  }
36
33
 
37
34
  [Fact(Skip = "Remove to run test")]
38
- public void Verse_1()
35
+ public void Verse_with_1_bottle()
39
36
  {
40
37
  var expected =
41
38
  "1 bottle of beer on the wall, 1 bottle of beer.\n" +
42
- "Take it down and pass it around, no more bottles of beer on the wall.\n" +
43
- "";
44
- Assert.Equal(expected, BeerSong.Verse(1));
39
+ "Take it down and pass it around, no more bottles of beer on the wall.";
40
+ Assert.Equal(expected, BeerSong.Recite(1, 1));
45
41
  }
46
42
 
47
43
  [Fact(Skip = "Remove to run test")]
48
- public void Verse_0()
44
+ public void Verse_with_0_bottles()
49
45
  {
50
46
  var expected =
51
47
  "No more bottles of beer on the wall, no more bottles of beer.\n" +
52
- "Go to the store and buy some more, 99 bottles of beer on the wall.\n" +
53
- "";
54
- Assert.Equal(expected, BeerSong.Verse(0));
48
+ "Go to the store and buy some more, 99 bottles of beer on the wall.";
49
+ Assert.Equal(expected, BeerSong.Recite(0, 1));
55
50
  }
56
51
 
57
52
  [Fact(Skip = "Remove to run test")]
@@ -62,9 +57,8 @@ public void First_two_verses()
62
57
  "Take one down and pass it around, 98 bottles of beer on the wall.\n" +
63
58
  "\n" +
64
59
  "98 bottles of beer on the wall, 98 bottles of beer.\n" +
65
- "Take one down and pass it around, 97 bottles of beer on the wall.\n" +
66
- "";
67
- Assert.Equal(expected, BeerSong.Verses(99, 98));
60
+ "Take one down and pass it around, 97 bottles of beer on the wall.";
61
+ Assert.Equal(expected, BeerSong.Recite(99, 2));
68
62
  }
69
63
 
70
64
  [Fact(Skip = "Remove to run test")]
@@ -78,9 +72,8 @@ public void Last_three_verses()
78
72
  "Take it down and pass it around, no more bottles of beer on the wall.\n" +
79
73
  "\n" +
80
74
  "No more bottles of beer on the wall, no more bottles of beer.\n" +
81
- "Go to the store and buy some more, 99 bottles of beer on the wall.\n" +
82
- "";
83
- Assert.Equal(expected, BeerSong.Verses(2, 0));
75
+ "Go to the store and buy some more, 99 bottles of beer on the wall.";
76
+ Assert.Equal(expected, BeerSong.Recite(2, 3));
84
77
  }
85
78
 
86
79
  [Fact(Skip = "Remove to run test")]
@@ -385,8 +378,7 @@ public void All_verses()
385
378
  "Take it down and pass it around, no more bottles of beer on the wall.\n" +
386
379
  "\n" +
387
380
  "No more bottles of beer on the wall, no more bottles of beer.\n" +
388
- "Go to the store and buy some more, 99 bottles of beer on the wall.\n" +
389
- "";
390
- Assert.Equal(expected, BeerSong.Verses(99, 0));
381
+ "Go to the store and buy some more, 99 bottles of beer on the wall.";
382
+ Assert.Equal(expected, BeerSong.Recite(99, 100));
391
383
  }
392
384
  }
@@ -7,16 +7,16 @@ public static string Verse(int number)
7
7
  switch (number)
8
8
  {
9
9
  case 0:
10
- return "No more bottles of beer on the wall, no more bottles of beer.\nGo to the store and buy some more, 99 bottles of beer on the wall.\n";
10
+ return "No more bottles of beer on the wall, no more bottles of beer.\nGo to the store and buy some more, 99 bottles of beer on the wall.";
11
11
  case 1:
12
- return "1 bottle of beer on the wall, 1 bottle of beer.\nTake it down and pass it around, no more bottles of beer on the wall.\n";
12
+ return "1 bottle of beer on the wall, 1 bottle of beer.\nTake it down and pass it around, no more bottles of beer on the wall.";
13
13
  case 2:
14
- return "2 bottles of beer on the wall, 2 bottles of beer.\nTake one down and pass it around, 1 bottle of beer on the wall.\n";
14
+ return "2 bottles of beer on the wall, 2 bottles of beer.\nTake one down and pass it around, 1 bottle of beer on the wall.";
15
15
  default:
16
- return string.Format("{0} bottles of beer on the wall, {0} bottles of beer.\nTake one down and pass it around, {1} bottles of beer on the wall.\n", number, number - 1);
16
+ return string.Format("{0} bottles of beer on the wall, {0} bottles of beer.\nTake one down and pass it around, {1} bottles of beer on the wall.", number, number - 1);
17
17
  }
18
18
  }
19
19
 
20
- public static string Verses(int begin, int end)
21
- => string.Join("\n", Enumerable.Range(end, begin - end + 1).Reverse().Select(Verse));
20
+ public static string Recite(int startBottles, int takeDown)
21
+ => string.Join("\n\n", Enumerable.Range(startBottles - takeDown + 1, takeDown).Reverse().Select(Verse));
22
22
  }
@@ -1,4 +1,4 @@
1
- // This file was auto-generated based on version 1.0.0 of the canonical data.
1
+ // This file was auto-generated based on version 1.1.0 of the canonical data.
2
2
 
3
3
  using Xunit;
4
4
 
@@ -1,4 +1,4 @@
1
- // This file was auto-generated based on version 1.1.0 of the canonical data.
1
+ // This file was auto-generated based on version 1.2.0 of the canonical data.
2
2
 
3
3
  using Xunit;
4
4
 
@@ -1,4 +1,4 @@
1
- // This file was auto-generated based on version 1.1.0 of the canonical data.
1
+ // This file was auto-generated based on version 1.3.0 of the canonical data.
2
2
 
3
3
  using Xunit;
4
4
 
@@ -1,4 +1,4 @@
1
- // This file was auto-generated based on version 1.0.1 of the canonical data.
1
+ // This file was auto-generated based on version 1.2.0 of the canonical data.
2
2
 
3
3
  using Xunit;
4
4
  using System;
@@ -10,7 +10,7 @@ public class BowlingTest
10
10
  public void Should_be_able_to_score_a_game_with_all_zeros()
11
11
  {
12
12
  var sut = new BowlingGame();
13
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
13
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
14
14
  DoRoll(previousRolls, sut);
15
15
  var actual = sut.Score();
16
16
  Assert.Equal(0, actual);
@@ -20,7 +20,7 @@ public void Should_be_able_to_score_a_game_with_all_zeros()
20
20
  public void Should_be_able_to_score_a_game_with_no_strikes_or_spares()
21
21
  {
22
22
  var sut = new BowlingGame();
23
- var previousRolls = new int[] {3, 6, 3, 6, 3, 6, 3, 6, 3, 6, 3, 6, 3, 6, 3, 6, 3, 6, 3, 6};
23
+ var previousRolls = new [] { 3, 6, 3, 6, 3, 6, 3, 6, 3, 6, 3, 6, 3, 6, 3, 6, 3, 6, 3, 6 };
24
24
  DoRoll(previousRolls, sut);
25
25
  var actual = sut.Score();
26
26
  Assert.Equal(90, actual);
@@ -30,7 +30,7 @@ public void Should_be_able_to_score_a_game_with_no_strikes_or_spares()
30
30
  public void A_spare_followed_by_zeros_is_worth_ten_points()
31
31
  {
32
32
  var sut = new BowlingGame();
33
- var previousRolls = new int[] {6, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
33
+ var previousRolls = new [] { 6, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
34
34
  DoRoll(previousRolls, sut);
35
35
  var actual = sut.Score();
36
36
  Assert.Equal(10, actual);
@@ -40,7 +40,7 @@ public void A_spare_followed_by_zeros_is_worth_ten_points()
40
40
  public void Points_scored_in_the_roll_after_a_spare_are_counted_twice()
41
41
  {
42
42
  var sut = new BowlingGame();
43
- var previousRolls = new int[] {6, 4, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
43
+ var previousRolls = new [] { 6, 4, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
44
44
  DoRoll(previousRolls, sut);
45
45
  var actual = sut.Score();
46
46
  Assert.Equal(16, actual);
@@ -50,7 +50,7 @@ public void Points_scored_in_the_roll_after_a_spare_are_counted_twice()
50
50
  public void Consecutive_spares_each_get_a_one_roll_bonus()
51
51
  {
52
52
  var sut = new BowlingGame();
53
- var previousRolls = new int[] {5, 5, 3, 7, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
53
+ var previousRolls = new [] { 5, 5, 3, 7, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
54
54
  DoRoll(previousRolls, sut);
55
55
  var actual = sut.Score();
56
56
  Assert.Equal(31, actual);
@@ -60,7 +60,7 @@ public void Consecutive_spares_each_get_a_one_roll_bonus()
60
60
  public void A_spare_in_the_last_frame_gets_a_one_roll_bonus_that_is_counted_once()
61
61
  {
62
62
  var sut = new BowlingGame();
63
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 3, 7};
63
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 3, 7 };
64
64
  DoRoll(previousRolls, sut);
65
65
  var actual = sut.Score();
66
66
  Assert.Equal(17, actual);
@@ -70,7 +70,7 @@ public void A_spare_in_the_last_frame_gets_a_one_roll_bonus_that_is_counted_once
70
70
  public void A_strike_earns_ten_points_in_a_frame_with_a_single_roll()
71
71
  {
72
72
  var sut = new BowlingGame();
73
- var previousRolls = new int[] {10, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
73
+ var previousRolls = new [] { 10, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
74
74
  DoRoll(previousRolls, sut);
75
75
  var actual = sut.Score();
76
76
  Assert.Equal(10, actual);
@@ -80,7 +80,7 @@ public void A_strike_earns_ten_points_in_a_frame_with_a_single_roll()
80
80
  public void Points_scored_in_the_two_rolls_after_a_strike_are_counted_twice_as_a_bonus()
81
81
  {
82
82
  var sut = new BowlingGame();
83
- var previousRolls = new int[] {10, 5, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
83
+ var previousRolls = new [] { 10, 5, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
84
84
  DoRoll(previousRolls, sut);
85
85
  var actual = sut.Score();
86
86
  Assert.Equal(26, actual);
@@ -90,7 +90,7 @@ public void Points_scored_in_the_two_rolls_after_a_strike_are_counted_twice_as_a
90
90
  public void Consecutive_strikes_each_get_the_two_roll_bonus()
91
91
  {
92
92
  var sut = new BowlingGame();
93
- var previousRolls = new int[] {10, 10, 10, 5, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
93
+ var previousRolls = new [] { 10, 10, 10, 5, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
94
94
  DoRoll(previousRolls, sut);
95
95
  var actual = sut.Score();
96
96
  Assert.Equal(81, actual);
@@ -100,7 +100,7 @@ public void Consecutive_strikes_each_get_the_two_roll_bonus()
100
100
  public void A_strike_in_the_last_frame_gets_a_two_roll_bonus_that_is_counted_once()
101
101
  {
102
102
  var sut = new BowlingGame();
103
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 7, 1};
103
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 7, 1 };
104
104
  DoRoll(previousRolls, sut);
105
105
  var actual = sut.Score();
106
106
  Assert.Equal(18, actual);
@@ -110,7 +110,7 @@ public void A_strike_in_the_last_frame_gets_a_two_roll_bonus_that_is_counted_onc
110
110
  public void Rolling_a_spare_with_the_two_roll_bonus_does_not_get_a_bonus_roll()
111
111
  {
112
112
  var sut = new BowlingGame();
113
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 7, 3};
113
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 7, 3 };
114
114
  DoRoll(previousRolls, sut);
115
115
  var actual = sut.Score();
116
116
  Assert.Equal(20, actual);
@@ -120,7 +120,7 @@ public void Rolling_a_spare_with_the_two_roll_bonus_does_not_get_a_bonus_roll()
120
120
  public void Strikes_with_the_two_roll_bonus_do_not_get_bonus_rolls()
121
121
  {
122
122
  var sut = new BowlingGame();
123
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 10, 10};
123
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 10, 10 };
124
124
  DoRoll(previousRolls, sut);
125
125
  var actual = sut.Score();
126
126
  Assert.Equal(30, actual);
@@ -130,7 +130,7 @@ public void Strikes_with_the_two_roll_bonus_do_not_get_bonus_rolls()
130
130
  public void A_strike_with_the_one_roll_bonus_after_a_spare_in_the_last_frame_does_not_get_a_bonus()
131
131
  {
132
132
  var sut = new BowlingGame();
133
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 3, 10};
133
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 3, 10 };
134
134
  DoRoll(previousRolls, sut);
135
135
  var actual = sut.Score();
136
136
  Assert.Equal(20, actual);
@@ -140,7 +140,7 @@ public void A_strike_with_the_one_roll_bonus_after_a_spare_in_the_last_frame_doe
140
140
  public void All_strikes_is_a_perfect_game()
141
141
  {
142
142
  var sut = new BowlingGame();
143
- var previousRolls = new int[] {10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10};
143
+ var previousRolls = new [] { 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10 };
144
144
  DoRoll(previousRolls, sut);
145
145
  var actual = sut.Score();
146
146
  Assert.Equal(300, actual);
@@ -150,7 +150,7 @@ public void All_strikes_is_a_perfect_game()
150
150
  public void Rolls_cannot_score_negative_points()
151
151
  {
152
152
  var sut = new BowlingGame();
153
- var previousRolls = new int[] {};
153
+ var previousRolls = new int[0];
154
154
  DoRoll(previousRolls, sut);
155
155
  Assert.Throws<ArgumentException>(() => sut.Roll(-1));
156
156
  }
@@ -159,7 +159,7 @@ public void Rolls_cannot_score_negative_points()
159
159
  public void A_roll_cannot_score_more_than_10_points()
160
160
  {
161
161
  var sut = new BowlingGame();
162
- var previousRolls = new int[] {};
162
+ var previousRolls = new int[0];
163
163
  DoRoll(previousRolls, sut);
164
164
  Assert.Throws<ArgumentException>(() => sut.Roll(11));
165
165
  }
@@ -168,7 +168,7 @@ public void A_roll_cannot_score_more_than_10_points()
168
168
  public void Two_rolls_in_a_frame_cannot_score_more_than_10_points()
169
169
  {
170
170
  var sut = new BowlingGame();
171
- var previousRolls = new int[] {5};
171
+ var previousRolls = new [] { 5 };
172
172
  DoRoll(previousRolls, sut);
173
173
  Assert.Throws<ArgumentException>(() => sut.Roll(6));
174
174
  }
@@ -177,7 +177,7 @@ public void Two_rolls_in_a_frame_cannot_score_more_than_10_points()
177
177
  public void Bonus_roll_after_a_strike_in_the_last_frame_cannot_score_more_than_10_points()
178
178
  {
179
179
  var sut = new BowlingGame();
180
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10};
180
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10 };
181
181
  DoRoll(previousRolls, sut);
182
182
  Assert.Throws<ArgumentException>(() => sut.Roll(11));
183
183
  }
@@ -186,7 +186,7 @@ public void Bonus_roll_after_a_strike_in_the_last_frame_cannot_score_more_than_1
186
186
  public void Two_bonus_rolls_after_a_strike_in_the_last_frame_cannot_score_more_than_10_points()
187
187
  {
188
188
  var sut = new BowlingGame();
189
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 5};
189
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 5 };
190
190
  DoRoll(previousRolls, sut);
191
191
  Assert.Throws<ArgumentException>(() => sut.Roll(6));
192
192
  }
@@ -195,7 +195,7 @@ public void Two_bonus_rolls_after_a_strike_in_the_last_frame_cannot_score_more_t
195
195
  public void Two_bonus_rolls_after_a_strike_in_the_last_frame_can_score_more_than_10_points_if_one_is_a_strike()
196
196
  {
197
197
  var sut = new BowlingGame();
198
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 10, 6};
198
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 10, 6 };
199
199
  DoRoll(previousRolls, sut);
200
200
  var actual = sut.Score();
201
201
  Assert.Equal(26, actual);
@@ -205,7 +205,7 @@ public void Two_bonus_rolls_after_a_strike_in_the_last_frame_can_score_more_than
205
205
  public void The_second_bonus_rolls_after_a_strike_in_the_last_frame_cannot_be_a_strike_if_the_first_one_is_not_a_strike()
206
206
  {
207
207
  var sut = new BowlingGame();
208
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 6};
208
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 6 };
209
209
  DoRoll(previousRolls, sut);
210
210
  Assert.Throws<ArgumentException>(() => sut.Roll(10));
211
211
  }
@@ -214,7 +214,7 @@ public void The_second_bonus_rolls_after_a_strike_in_the_last_frame_cannot_be_a_
214
214
  public void Second_bonus_roll_after_a_strike_in_the_last_frame_cannot_score_more_than_10_points()
215
215
  {
216
216
  var sut = new BowlingGame();
217
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 10};
217
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 10 };
218
218
  DoRoll(previousRolls, sut);
219
219
  Assert.Throws<ArgumentException>(() => sut.Roll(11));
220
220
  }
@@ -223,7 +223,7 @@ public void Second_bonus_roll_after_a_strike_in_the_last_frame_cannot_score_more
223
223
  public void An_unstarted_game_cannot_be_scored()
224
224
  {
225
225
  var sut = new BowlingGame();
226
- var previousRolls = new int[] {};
226
+ var previousRolls = new int[0];
227
227
  DoRoll(previousRolls, sut);
228
228
  Assert.Throws<ArgumentException>(() => sut.Score());
229
229
  }
@@ -232,7 +232,7 @@ public void An_unstarted_game_cannot_be_scored()
232
232
  public void An_incomplete_game_cannot_be_scored()
233
233
  {
234
234
  var sut = new BowlingGame();
235
- var previousRolls = new int[] {0, 0};
235
+ var previousRolls = new [] { 0, 0 };
236
236
  DoRoll(previousRolls, sut);
237
237
  Assert.Throws<ArgumentException>(() => sut.Score());
238
238
  }
@@ -241,7 +241,7 @@ public void An_incomplete_game_cannot_be_scored()
241
241
  public void Cannot_roll_if_game_already_has_ten_frames()
242
242
  {
243
243
  var sut = new BowlingGame();
244
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
244
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
245
245
  DoRoll(previousRolls, sut);
246
246
  Assert.Throws<ArgumentException>(() => sut.Roll(0));
247
247
  }
@@ -250,7 +250,7 @@ public void Cannot_roll_if_game_already_has_ten_frames()
250
250
  public void Bonus_rolls_for_a_strike_in_the_last_frame_must_be_rolled_before_score_can_be_calculated()
251
251
  {
252
252
  var sut = new BowlingGame();
253
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10};
253
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10 };
254
254
  DoRoll(previousRolls, sut);
255
255
  Assert.Throws<ArgumentException>(() => sut.Score());
256
256
  }
@@ -259,7 +259,7 @@ public void Bonus_rolls_for_a_strike_in_the_last_frame_must_be_rolled_before_sco
259
259
  public void Both_bonus_rolls_for_a_strike_in_the_last_frame_must_be_rolled_before_score_can_be_calculated()
260
260
  {
261
261
  var sut = new BowlingGame();
262
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 10};
262
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 10 };
263
263
  DoRoll(previousRolls, sut);
264
264
  Assert.Throws<ArgumentException>(() => sut.Score());
265
265
  }
@@ -268,11 +268,29 @@ public void Both_bonus_rolls_for_a_strike_in_the_last_frame_must_be_rolled_befor
268
268
  public void Bonus_roll_for_a_spare_in_the_last_frame_must_be_rolled_before_score_can_be_calculated()
269
269
  {
270
270
  var sut = new BowlingGame();
271
- var previousRolls = new int[] {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 3};
271
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 3 };
272
272
  DoRoll(previousRolls, sut);
273
273
  Assert.Throws<ArgumentException>(() => sut.Score());
274
274
  }
275
275
 
276
+ [Fact(Skip = "Remove to run test")]
277
+ public void Cannot_roll_after_bonus_roll_for_spare()
278
+ {
279
+ var sut = new BowlingGame();
280
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 7, 3, 2 };
281
+ DoRoll(previousRolls, sut);
282
+ Assert.Throws<ArgumentException>(() => sut.Roll(2));
283
+ }
284
+
285
+ [Fact(Skip = "Remove to run test")]
286
+ public void Cannot_roll_after_bonus_rolls_for_strike()
287
+ {
288
+ var sut = new BowlingGame();
289
+ var previousRolls = new [] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 3, 2 };
290
+ DoRoll(previousRolls, sut);
291
+ Assert.Throws<ArgumentException>(() => sut.Roll(2));
292
+ }
293
+
276
294
  public void DoRoll(ICollection<int> rolls, BowlingGame sut)
277
295
  {
278
296
  foreach (var roll in rolls)
@@ -1,4 +1,4 @@
1
- // This file was auto-generated based on version 1.1.0 of the canonical data.
1
+ // This file was auto-generated based on version 1.3.0 of the canonical data.
2
2
 
3
3
  using Xunit;
4
4
 
@@ -7,98 +7,105 @@ public class BracketPushTest
7
7
  [Fact]
8
8
  public void Paired_square_brackets()
9
9
  {
10
- var input = "[]";
11
- Assert.True(BracketPush.IsPaired(input));
10
+ var value = "[]";
11
+ Assert.True(BracketPush.IsPaired(value));
12
12
  }
13
13
 
14
14
  [Fact(Skip = "Remove to run test")]
15
15
  public void Empty_string()
16
16
  {
17
- var input = "";
18
- Assert.True(BracketPush.IsPaired(input));
17
+ var value = "";
18
+ Assert.True(BracketPush.IsPaired(value));
19
19
  }
20
20
 
21
21
  [Fact(Skip = "Remove to run test")]
22
22
  public void Unpaired_brackets()
23
23
  {
24
- var input = "[[";
25
- Assert.False(BracketPush.IsPaired(input));
24
+ var value = "[[";
25
+ Assert.False(BracketPush.IsPaired(value));
26
26
  }
27
27
 
28
28
  [Fact(Skip = "Remove to run test")]
29
29
  public void Wrong_ordered_brackets()
30
30
  {
31
- var input = "}{";
32
- Assert.False(BracketPush.IsPaired(input));
31
+ var value = "}{";
32
+ Assert.False(BracketPush.IsPaired(value));
33
33
  }
34
34
 
35
35
  [Fact(Skip = "Remove to run test")]
36
36
  public void Wrong_closing_bracket()
37
37
  {
38
- var input = "{]";
39
- Assert.False(BracketPush.IsPaired(input));
38
+ var value = "{]";
39
+ Assert.False(BracketPush.IsPaired(value));
40
40
  }
41
41
 
42
42
  [Fact(Skip = "Remove to run test")]
43
43
  public void Paired_with_whitespace()
44
44
  {
45
- var input = "{ }";
46
- Assert.True(BracketPush.IsPaired(input));
45
+ var value = "{ }";
46
+ Assert.True(BracketPush.IsPaired(value));
47
+ }
48
+
49
+ [Fact(Skip = "Remove to run test")]
50
+ public void Partially_paired_brackets()
51
+ {
52
+ var value = "{[])";
53
+ Assert.False(BracketPush.IsPaired(value));
47
54
  }
48
55
 
49
56
  [Fact(Skip = "Remove to run test")]
50
57
  public void Simple_nested_brackets()
51
58
  {
52
- var input = "{[]}";
53
- Assert.True(BracketPush.IsPaired(input));
59
+ var value = "{[]}";
60
+ Assert.True(BracketPush.IsPaired(value));
54
61
  }
55
62
 
56
63
  [Fact(Skip = "Remove to run test")]
57
64
  public void Several_paired_brackets()
58
65
  {
59
- var input = "{}[]";
60
- Assert.True(BracketPush.IsPaired(input));
66
+ var value = "{}[]";
67
+ Assert.True(BracketPush.IsPaired(value));
61
68
  }
62
69
 
63
70
  [Fact(Skip = "Remove to run test")]
64
71
  public void Paired_and_nested_brackets()
65
72
  {
66
- var input = "([{}({}[])])";
67
- Assert.True(BracketPush.IsPaired(input));
73
+ var value = "([{}({}[])])";
74
+ Assert.True(BracketPush.IsPaired(value));
68
75
  }
69
76
 
70
77
  [Fact(Skip = "Remove to run test")]
71
78
  public void Unopened_closing_brackets()
72
79
  {
73
- var input = "{[)][]}";
74
- Assert.False(BracketPush.IsPaired(input));
80
+ var value = "{[)][]}";
81
+ Assert.False(BracketPush.IsPaired(value));
75
82
  }
76
83
 
77
84
  [Fact(Skip = "Remove to run test")]
78
85
  public void Unpaired_and_nested_brackets()
79
86
  {
80
- var input = "([{])";
81
- Assert.False(BracketPush.IsPaired(input));
87
+ var value = "([{])";
88
+ Assert.False(BracketPush.IsPaired(value));
82
89
  }
83
90
 
84
91
  [Fact(Skip = "Remove to run test")]
85
92
  public void Paired_and_wrong_nested_brackets()
86
93
  {
87
- var input = "[({]})";
88
- Assert.False(BracketPush.IsPaired(input));
94
+ var value = "[({]})";
95
+ Assert.False(BracketPush.IsPaired(value));
89
96
  }
90
97
 
91
98
  [Fact(Skip = "Remove to run test")]
92
99
  public void Math_expression()
93
100
  {
94
- var input = "(((185 + 223.85) * 15) - 543)/2";
95
- Assert.True(BracketPush.IsPaired(input));
101
+ var value = "(((185 + 223.85) * 15) - 543)/2";
102
+ Assert.True(BracketPush.IsPaired(value));
96
103
  }
97
104
 
98
105
  [Fact(Skip = "Remove to run test")]
99
106
  public void Complex_latex_expression()
100
107
  {
101
- var input = "\\left(\\begin{array}{cc} \\frac{1}{3} & x\\\\ \\mathrm{e}^{x} &... x^2 \\end{array}\\right)";
102
- Assert.True(BracketPush.IsPaired(input));
108
+ var value = "\\left(\\begin{array}{cc} \\frac{1}{3} & x\\\\ \\mathrm{e}^{x} &... x^2 \\end{array}\\right)";
109
+ Assert.True(BracketPush.IsPaired(value));
103
110
  }
104
111
  }