trackler 2.2.1.56 → 2.2.1.57

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/TOPICS.txt +2 -2
  4. data/problem-specifications/exercises/zipper/description.md +1 -1
  5. data/tracks/dart/test/exercises_test.dart +9 -9
  6. data/tracks/delphi/exercises/circular-buffer/uCircularBufferExample.pas +3 -3
  7. data/tracks/delphi/exercises/circular-buffer/uCircularBufferTests.pas +160 -86
  8. data/tracks/delphi/exercises/phone-number/README.md +1 -1
  9. data/tracks/erlang/config.json +10 -0
  10. data/tracks/erlang/exercises/isogram/README.md +65 -0
  11. data/tracks/erlang/exercises/isogram/include/exercism.hrl +11 -0
  12. data/tracks/erlang/exercises/isogram/rebar.config +30 -0
  13. data/tracks/erlang/exercises/isogram/src/example.erl +16 -0
  14. data/tracks/erlang/exercises/isogram/src/isogram.app.src +9 -0
  15. data/tracks/erlang/exercises/isogram/src/isogram.erl +9 -0
  16. data/tracks/erlang/exercises/isogram/test/isogram_tests.erl +32 -0
  17. data/tracks/fsharp/exercises/binary-search/BinarySearch.fs +1 -1
  18. data/tracks/fsharp/exercises/binary-search/BinarySearchTest.fs +58 -30
  19. data/tracks/fsharp/exercises/binary-search/Example.fs +1 -1
  20. data/tracks/fsharp/exercises/poker/Example.fs +23 -20
  21. data/tracks/fsharp/exercises/poker/PokerTest.fs +135 -76
  22. data/tracks/fsharp/generators/Generators.fs +21 -0
  23. data/tracks/go/README.md +0 -15
  24. data/tracks/go/bin/run-generators +11 -0
  25. data/tracks/go/config.json +389 -277
  26. data/tracks/go/config/maintainers.json +2 -2
  27. data/tracks/go/docs/TESTS.md +0 -15
  28. data/tracks/go/exercises/accumulate/accumulate_test.go +0 -8
  29. data/tracks/go/exercises/accumulate/example.go +0 -2
  30. data/tracks/go/exercises/acronym/acronym.go +14 -2
  31. data/tracks/go/exercises/acronym/acronym_test.go +0 -8
  32. data/tracks/go/exercises/acronym/cases_test.go +2 -2
  33. data/tracks/go/exercises/acronym/example.go +0 -2
  34. data/tracks/go/exercises/all-your-base/all_your_base_test.go +0 -8
  35. data/tracks/go/exercises/all-your-base/example.go +0 -2
  36. data/tracks/go/exercises/allergies/allergies_test.go +0 -8
  37. data/tracks/go/exercises/allergies/example.go +0 -2
  38. data/tracks/go/exercises/anagram/.meta/gen.go +55 -0
  39. data/tracks/go/exercises/anagram/anagram_test.go +0 -130
  40. data/tracks/go/exercises/anagram/cases_test.go +164 -0
  41. data/tracks/go/exercises/anagram/example.go +0 -2
  42. data/tracks/go/exercises/atbash-cipher/atbash_cipher_test.go +0 -8
  43. data/tracks/go/exercises/atbash-cipher/cases_test.go +2 -2
  44. data/tracks/go/exercises/atbash-cipher/example.go +0 -2
  45. data/tracks/go/exercises/bank-account/bank_account_test.go +0 -8
  46. data/tracks/go/exercises/bank-account/example.go +0 -2
  47. data/tracks/go/exercises/beer-song/beer_test.go +0 -8
  48. data/tracks/go/exercises/beer-song/example.go +0 -2
  49. data/tracks/go/exercises/binary-search-tree/binary_search_tree_test.go +0 -8
  50. data/tracks/go/exercises/binary-search-tree/example.go +0 -2
  51. data/tracks/go/exercises/binary-search/binary_search_test.go +0 -8
  52. data/tracks/go/exercises/binary-search/example.go +0 -2
  53. data/tracks/go/exercises/binary/binary_test.go +0 -11
  54. data/tracks/go/exercises/binary/example.go +0 -2
  55. data/tracks/go/exercises/bob/bob.go +14 -0
  56. data/tracks/go/exercises/bob/bob_test.go +2 -10
  57. data/tracks/go/exercises/bob/cases_test.go +2 -2
  58. data/tracks/go/exercises/bob/example.go +12 -13
  59. data/tracks/go/exercises/book-store/README.md +92 -0
  60. data/tracks/go/exercises/book-store/book_store_test.go +91 -0
  61. data/tracks/go/exercises/book-store/example.go +52 -0
  62. data/tracks/go/exercises/bowling/bowling_test.go +0 -8
  63. data/tracks/go/exercises/bowling/cases_test.go +2 -2
  64. data/tracks/go/exercises/bowling/example.go +0 -2
  65. data/tracks/go/exercises/bracket-push/bracket_push_test.go +0 -8
  66. data/tracks/go/exercises/bracket-push/cases_test.go +2 -2
  67. data/tracks/go/exercises/bracket-push/example.go +0 -3
  68. data/tracks/go/exercises/change/cases_test.go +10 -3
  69. data/tracks/go/exercises/change/change_test.go +1 -9
  70. data/tracks/go/exercises/change/example.go +0 -2
  71. data/tracks/go/exercises/circular-buffer/circular_buffer_test.go +0 -8
  72. data/tracks/go/exercises/circular-buffer/example.go +0 -2
  73. data/tracks/go/exercises/clock/cases_test.go +2 -2
  74. data/tracks/go/exercises/clock/clock_test.go +2 -9
  75. data/tracks/go/exercises/clock/example.go +0 -2
  76. data/tracks/go/exercises/collatz-conjecture/README.md +51 -0
  77. data/tracks/go/exercises/collatz-conjecture/collatz_conjecture_test.go +77 -0
  78. data/tracks/go/exercises/collatz-conjecture/example.go +24 -0
  79. data/tracks/go/exercises/connect/cases_test.go +2 -2
  80. data/tracks/go/exercises/connect/connect_test.go +0 -8
  81. data/tracks/go/exercises/connect/example.go +0 -2
  82. data/tracks/go/exercises/crypto-square/crypto_square_test.go +0 -8
  83. data/tracks/go/exercises/crypto-square/example.go +0 -2
  84. data/tracks/go/exercises/custom-set/cases_test.go +2 -2
  85. data/tracks/go/exercises/custom-set/custom_set_test.go +0 -8
  86. data/tracks/go/exercises/custom-set/example.go +0 -2
  87. data/tracks/go/exercises/custom-set/example_slice.go +0 -2
  88. data/tracks/go/exercises/diamond/diamond_test.go +0 -8
  89. data/tracks/go/exercises/diamond/example.go +0 -2
  90. data/tracks/go/exercises/difference-of-squares/difference_of_squares_test.go +0 -8
  91. data/tracks/go/exercises/difference-of-squares/example.go +0 -2
  92. data/tracks/go/exercises/diffie-hellman/diffie_hellman_test.go +0 -8
  93. data/tracks/go/exercises/diffie-hellman/example.go +0 -2
  94. data/tracks/go/exercises/error-handling/error_handling_test.go +0 -7
  95. data/tracks/go/exercises/error-handling/example.go +0 -2
  96. data/tracks/go/exercises/etl/etl_test.go +0 -8
  97. data/tracks/go/exercises/etl/example.go +0 -2
  98. data/tracks/go/exercises/flatten-array/.meta/gen.go +52 -0
  99. data/tracks/go/exercises/flatten-array/README.md +35 -0
  100. data/tracks/go/exercises/flatten-array/cases_test.go +42 -0
  101. data/tracks/go/exercises/flatten-array/example.go +25 -0
  102. data/tracks/go/exercises/flatten-array/flatten_test.go +23 -0
  103. data/tracks/go/exercises/food-chain/example.go +0 -2
  104. data/tracks/go/exercises/food-chain/food_chain_test.go +0 -8
  105. data/tracks/go/exercises/forth/cases_test.go +2 -2
  106. data/tracks/go/exercises/forth/example.go +0 -2
  107. data/tracks/go/exercises/forth/forth_test.go +0 -8
  108. data/tracks/go/exercises/gigasecond/cases_test.go +2 -2
  109. data/tracks/go/exercises/gigasecond/example.go +0 -2
  110. data/tracks/go/exercises/gigasecond/gigasecond.go +13 -3
  111. data/tracks/go/exercises/gigasecond/gigasecond_test.go +0 -8
  112. data/tracks/go/exercises/grade-school/example.go +0 -2
  113. data/tracks/go/exercises/grade-school/grade_school_test.go +0 -8
  114. data/tracks/go/exercises/grains/example.go +0 -2
  115. data/tracks/go/exercises/grains/grains_test.go +0 -8
  116. data/tracks/go/exercises/hamming/.meta/hints.md +4 -0
  117. data/tracks/go/exercises/hamming/README.md +6 -0
  118. data/tracks/go/exercises/hamming/example.go +0 -2
  119. data/tracks/go/exercises/hamming/hamming.go +0 -2
  120. data/tracks/go/exercises/hamming/hamming_test.go +0 -8
  121. data/tracks/go/exercises/hello-world/hello_world.go +9 -1
  122. data/tracks/go/exercises/hexadecimal/example.go +0 -2
  123. data/tracks/go/exercises/hexadecimal/hexadecimal_test.go +0 -8
  124. data/tracks/go/exercises/house/example.go +0 -2
  125. data/tracks/go/exercises/house/house_test.go +0 -8
  126. data/tracks/go/exercises/isbn-verifier/README.md +60 -0
  127. data/tracks/go/exercises/isbn-verifier/example.go +57 -0
  128. data/tracks/go/exercises/isbn-verifier/isbn_verifier_test.go +35 -0
  129. data/tracks/go/exercises/isogram/example.go +0 -2
  130. data/tracks/go/exercises/isogram/isogram_test.go +0 -8
  131. data/tracks/go/exercises/kindergarten-garden/example.go +0 -2
  132. data/tracks/go/exercises/kindergarten-garden/kindergarten_garden_test.go +0 -8
  133. data/tracks/go/exercises/largest-series-product/cases_test.go +2 -2
  134. data/tracks/go/exercises/largest-series-product/example.go +0 -2
  135. data/tracks/go/exercises/largest-series-product/largest_series_product_test.go +0 -8
  136. data/tracks/go/exercises/leap/.meta/hints.md +14 -0
  137. data/tracks/go/exercises/leap/README.md +16 -0
  138. data/tracks/go/exercises/leap/cases_test.go +4 -4
  139. data/tracks/go/exercises/leap/example.go +0 -2
  140. data/tracks/go/exercises/leap/leap.go +11 -2
  141. data/tracks/go/exercises/leap/leap_test.go +0 -15
  142. data/tracks/go/exercises/ledger/example.go +0 -2
  143. data/tracks/go/exercises/ledger/ledger.go +0 -2
  144. data/tracks/go/exercises/ledger/ledger_test.go +0 -8
  145. data/tracks/go/exercises/luhn/cases_test.go +2 -2
  146. data/tracks/go/exercises/luhn/example.go +0 -2
  147. data/tracks/go/exercises/luhn/luhn_test.go +0 -8
  148. data/tracks/go/exercises/matrix/example.go +0 -2
  149. data/tracks/go/exercises/matrix/matrix_test.go +0 -8
  150. data/tracks/go/exercises/meetup/cases_test.go +2 -2
  151. data/tracks/go/exercises/meetup/example.go +0 -2
  152. data/tracks/go/exercises/meetup/meetup_test.go +0 -8
  153. data/tracks/go/exercises/minesweeper/example.go +0 -2
  154. data/tracks/go/exercises/minesweeper/minesweeper_test.go +0 -8
  155. data/tracks/go/exercises/nth-prime/example.go +0 -2
  156. data/tracks/go/exercises/nth-prime/nth_prime_test.go +0 -8
  157. data/tracks/go/exercises/nucleotide-count/example.go +0 -2
  158. data/tracks/go/exercises/nucleotide-count/nucleotide_count.go +26 -0
  159. data/tracks/go/exercises/nucleotide-count/nucleotide_count_test.go +0 -8
  160. data/tracks/go/exercises/ocr-numbers/example.go +0 -2
  161. data/tracks/go/exercises/ocr-numbers/ocr_numbers_test.go +0 -8
  162. data/tracks/go/exercises/octal/example.go +0 -2
  163. data/tracks/go/exercises/octal/octal_test.go +0 -8
  164. data/tracks/go/exercises/paasio/example.go +0 -2
  165. data/tracks/go/exercises/paasio/paasio_test.go +0 -8
  166. data/tracks/go/exercises/palindrome-products/example.go +0 -2
  167. data/tracks/go/exercises/palindrome-products/palindrome_products_test.go +0 -8
  168. data/tracks/go/exercises/pangram/example.go +0 -2
  169. data/tracks/go/exercises/pangram/pangram_test.go +2 -8
  170. data/tracks/go/exercises/parallel-letter-frequency/example.go +0 -2
  171. data/tracks/go/exercises/parallel-letter-frequency/parallel_letter_frequency_test.go +0 -8
  172. data/tracks/go/exercises/pascals-triangle/example.go +0 -2
  173. data/tracks/go/exercises/pascals-triangle/pascals_triangle_test.go +0 -8
  174. data/tracks/go/exercises/perfect-numbers/example.go +0 -2
  175. data/tracks/go/exercises/perfect-numbers/perfect_numbers_test.go +0 -8
  176. data/tracks/go/exercises/phone-number/cases_test.go +2 -2
  177. data/tracks/go/exercises/phone-number/example.go +0 -2
  178. data/tracks/go/exercises/phone-number/phone_number_test.go +0 -8
  179. data/tracks/go/exercises/pig-latin/example.go +0 -2
  180. data/tracks/go/exercises/pig-latin/pig_latin_test.go +0 -8
  181. data/tracks/go/exercises/poker/.meta/hints.md +7 -0
  182. data/tracks/go/exercises/poker/README.md +9 -0
  183. data/tracks/go/exercises/poker/cases_test.go +2 -2
  184. data/tracks/go/exercises/poker/example.go +0 -2
  185. data/tracks/go/exercises/poker/poker_test.go +0 -11
  186. data/tracks/go/exercises/pov/example.go +0 -2
  187. data/tracks/go/exercises/pov/pov_test.go +1 -9
  188. data/tracks/go/exercises/prime-factors/example.go +0 -2
  189. data/tracks/go/exercises/prime-factors/prime_factors_test.go +1 -9
  190. data/tracks/go/exercises/protein-translation/example.go +0 -2
  191. data/tracks/go/exercises/protein-translation/protein_translation_test.go +0 -8
  192. data/tracks/go/exercises/pythagorean-triplet/example.go +0 -2
  193. data/tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go +0 -8
  194. data/tracks/go/exercises/queen-attack/example.go +0 -2
  195. data/tracks/go/exercises/queen-attack/queen_attack_test.go +0 -8
  196. data/tracks/go/exercises/raindrops/.meta/hints.md +7 -0
  197. data/tracks/go/exercises/raindrops/cases_test.go +2 -2
  198. data/tracks/go/exercises/raindrops/example.go +0 -2
  199. data/tracks/go/exercises/raindrops/raindrops_test.go +0 -8
  200. data/tracks/go/exercises/react/example.go +0 -2
  201. data/tracks/go/exercises/react/react_test.go +0 -11
  202. data/tracks/go/exercises/rna-transcription/cases_test.go +2 -2
  203. data/tracks/go/exercises/rna-transcription/example.go +0 -2
  204. data/tracks/go/exercises/rna-transcription/rna_transcription.go +6 -0
  205. data/tracks/go/exercises/rna-transcription/rna_transcription_test.go +0 -8
  206. data/tracks/go/exercises/robot-name/example.go +0 -2
  207. data/tracks/go/exercises/robot-name/robot_name_test.go +0 -8
  208. data/tracks/go/exercises/robot-simulator/example.go +0 -1
  209. data/tracks/go/exercises/robot-simulator/robot_simulator_test.go +0 -8
  210. data/tracks/go/exercises/roman-numerals/cases_test.go +2 -2
  211. data/tracks/go/exercises/roman-numerals/example.go +0 -2
  212. data/tracks/go/exercises/roman-numerals/roman_numerals_test.go +0 -8
  213. data/tracks/go/exercises/rotational-cipher/README.md +56 -0
  214. data/tracks/go/exercises/rotational-cipher/example.go +20 -0
  215. data/tracks/go/exercises/rotational-cipher/rotational_cipher_test.go +86 -0
  216. data/tracks/go/exercises/run-length-encoding/README.md +31 -0
  217. data/tracks/go/exercises/run-length-encoding/example.go +53 -0
  218. data/tracks/go/exercises/run-length-encoding/run_length_encoding_test.go +59 -0
  219. data/tracks/go/exercises/saddle-points/example.go +0 -2
  220. data/tracks/go/exercises/saddle-points/saddle_points_test.go +0 -8
  221. data/tracks/go/exercises/say/.meta/gen.go +70 -0
  222. data/tracks/go/exercises/say/cases_test.go +88 -0
  223. data/tracks/go/exercises/say/example.go +12 -6
  224. data/tracks/go/exercises/say/say_test.go +17 -43
  225. data/tracks/go/exercises/scrabble-score/cases_test.go +2 -2
  226. data/tracks/go/exercises/scrabble-score/example.go +0 -3
  227. data/tracks/go/exercises/scrabble-score/scrabble_score_test.go +0 -8
  228. data/tracks/go/exercises/secret-handshake/cases_test.go +2 -2
  229. data/tracks/go/exercises/secret-handshake/example.go +0 -2
  230. data/tracks/go/exercises/secret-handshake/secret_handshake_test.go +0 -8
  231. data/tracks/go/exercises/series/example.go +0 -2
  232. data/tracks/go/exercises/series/series_test.go +0 -8
  233. data/tracks/go/exercises/sieve/example.go +0 -2
  234. data/tracks/go/exercises/sieve/sieve_test.go +0 -8
  235. data/tracks/go/exercises/simple-cipher/example.go +0 -2
  236. data/tracks/go/exercises/simple-cipher/simple_cipher_test.go +0 -8
  237. data/tracks/go/exercises/space-age/.meta/gen.go +56 -0
  238. data/tracks/go/exercises/space-age/README.md +42 -0
  239. data/tracks/go/exercises/space-age/cases_test.go +61 -0
  240. data/tracks/go/exercises/space-age/example.go +36 -0
  241. data/tracks/go/exercises/space-age/space_age_test.go +22 -0
  242. data/tracks/go/exercises/spiral-matrix/README.md +48 -0
  243. data/tracks/go/exercises/spiral-matrix/example.go +93 -0
  244. data/tracks/go/exercises/spiral-matrix/spiral_matrix_test.go +71 -0
  245. data/tracks/go/exercises/strain/example.go +0 -2
  246. data/tracks/go/exercises/strain/strain_test.go +0 -8
  247. data/tracks/go/exercises/sublist/.meta/gen.go +56 -0
  248. data/tracks/go/exercises/sublist/README.md +39 -0
  249. data/tracks/go/exercises/sublist/cases_test.go +115 -0
  250. data/tracks/go/exercises/sublist/example.go +49 -0
  251. data/tracks/go/exercises/sublist/sublist_test.go +22 -0
  252. data/tracks/go/exercises/sum-of-multiples/cases_test.go +4 -3
  253. data/tracks/go/exercises/sum-of-multiples/example.go +0 -2
  254. data/tracks/go/exercises/sum-of-multiples/sum_of_multiples_test.go +0 -8
  255. data/tracks/go/exercises/tournament/example.go +0 -2
  256. data/tracks/go/exercises/tournament/tournament_test.go +0 -11
  257. data/tracks/go/exercises/transpose/cases_test.go +2 -2
  258. data/tracks/go/exercises/transpose/example.go +0 -2
  259. data/tracks/go/exercises/transpose/transpose_test.go +0 -8
  260. data/tracks/go/exercises/tree-building/example.go +0 -2
  261. data/tracks/go/exercises/tree-building/tree_building.go +0 -2
  262. data/tracks/go/exercises/tree-building/tree_test.go +0 -11
  263. data/tracks/go/exercises/triangle/.meta/hints.md +10 -0
  264. data/tracks/go/exercises/triangle/example.go +0 -2
  265. data/tracks/go/exercises/triangle/triangle.go +21 -9
  266. data/tracks/go/exercises/triangle/triangle_test.go +0 -8
  267. data/tracks/go/exercises/trinary/example.go +0 -2
  268. data/tracks/go/exercises/trinary/trinary_test.go +0 -8
  269. data/tracks/go/exercises/twelve-days/example.go +0 -2
  270. data/tracks/go/exercises/twelve-days/twelve_days_test.go +0 -8
  271. data/tracks/go/exercises/two-fer/two_fer.go +2 -2
  272. data/tracks/go/exercises/variable-length-quantity/cases_test.go +2 -2
  273. data/tracks/go/exercises/variable-length-quantity/example.go +0 -2
  274. data/tracks/go/exercises/variable-length-quantity/variable_length_quantity_test.go +0 -8
  275. data/tracks/go/exercises/word-count/cases_test.go +2 -2
  276. data/tracks/go/exercises/word-count/example.go +0 -2
  277. data/tracks/go/exercises/word-count/word_count_test.go +4 -7
  278. data/tracks/go/exercises/word-search/.meta/gen.go +96 -0
  279. data/tracks/go/exercises/word-search/cases_test.go +154 -0
  280. data/tracks/go/exercises/word-search/example.go +0 -2
  281. data/tracks/go/exercises/word-search/word_search_test.go +16 -52
  282. data/tracks/go/exercises/wordy/example.go +0 -2
  283. data/tracks/go/exercises/wordy/wordy_test.go +0 -8
  284. data/tracks/go/gen/gen.go +4 -1
  285. data/tracks/java/exercises/phone-number/README.md +1 -1
  286. data/tracks/kotlin/exercises/phone-number/README.md +1 -1
  287. data/tracks/perl6/config.json +50 -0
  288. data/tracks/perl6/exercises/etl/ETL.pm6 +6 -0
  289. data/tracks/perl6/exercises/etl/Example.pm6 +7 -0
  290. data/tracks/perl6/exercises/etl/README.md +72 -0
  291. data/tracks/perl6/exercises/etl/etl.t +139 -0
  292. data/tracks/perl6/exercises/etl/example.yaml +35 -0
  293. data/tracks/perl6/exercises/hamming/Example.pm6 +6 -0
  294. data/tracks/perl6/exercises/hamming/Hamming.pm6 +4 -0
  295. data/tracks/perl6/exercises/hamming/README.md +61 -0
  296. data/tracks/perl6/exercises/hamming/example.yaml +22 -0
  297. data/tracks/perl6/exercises/hamming/hamming.t +175 -0
  298. data/tracks/perl6/exercises/meetup/Example.pm6 +37 -0
  299. data/tracks/perl6/exercises/meetup/Meetup.pm6 +4 -0
  300. data/tracks/perl6/exercises/meetup/README.md +48 -0
  301. data/tracks/perl6/exercises/meetup/example.yaml +48 -0
  302. data/tracks/perl6/exercises/meetup/meetup.t +907 -0
  303. data/tracks/perl6/exercises/pangram/Example.pm6 +5 -0
  304. data/tracks/perl6/exercises/pangram/Pangram.pm6 +4 -0
  305. data/tracks/perl6/exercises/pangram/README.md +34 -0
  306. data/tracks/perl6/exercises/pangram/example.yaml +17 -0
  307. data/tracks/perl6/exercises/pangram/pangram.t +125 -0
  308. data/tracks/perl6/exercises/phone-number/README.md +1 -1
  309. data/tracks/perl6/exercises/two-fer/Example.pm6 +14 -0
  310. data/tracks/perl6/exercises/two-fer/README.md +38 -0
  311. data/tracks/perl6/exercises/two-fer/TwoFer.pm6 +15 -0
  312. data/tracks/perl6/exercises/two-fer/example.yaml +43 -0
  313. data/tracks/perl6/exercises/two-fer/two-fer.t +82 -0
  314. data/tracks/php/config.json +13 -0
  315. data/tracks/php/exercises/rail-fence-cipher/README.md +80 -0
  316. data/tracks/php/exercises/rail-fence-cipher/example.php +61 -0
  317. data/tracks/php/exercises/rail-fence-cipher/rail-fence-cipher_test.php +76 -0
  318. data/tracks/purescript/.travis.yml +1 -1
  319. data/tracks/python/config.json +13 -0
  320. data/tracks/python/exercises/alphametics/example.py +42 -29
  321. data/tracks/python/exercises/crypto-square/crypto_square_test.py +20 -13
  322. data/tracks/python/exercises/crypto-square/example.py +1 -1
  323. data/tracks/python/exercises/kindergarten-garden/kindergarten_garden_test.py +15 -2
  324. data/tracks/python/exercises/phone-number/README.md +2 -1
  325. data/tracks/python/exercises/pov/README.md +53 -0
  326. data/tracks/python/exercises/pov/example.py +70 -0
  327. data/tracks/python/exercises/pov/pov.py +25 -0
  328. data/tracks/python/exercises/pov/pov_test.py +200 -0
  329. data/tracks/python/test/check-exercises.py +11 -1
  330. data/tracks/ruby/exercises/meetup/.meta/.version +1 -0
  331. data/tracks/ruby/exercises/meetup/.meta/generator/meetup_case.rb +11 -0
  332. data/tracks/ruby/exercises/meetup/.meta/solutions/meetup.rb +5 -0
  333. data/tracks/ruby/exercises/meetup/meetup_test.rb +48 -4
  334. metadata +90 -8
  335. data/tracks/go/exercises/accumulate/accumulate.go +0 -5
  336. data/tracks/go/exercises/clock/clock.go +0 -19
  337. data/tracks/go/exercises/pangram/pangram.go +0 -5
  338. data/tracks/go/exercises/raindrops/raindrops.go +0 -8
  339. data/tracks/go/exercises/twelve-days/HINTS.md +0 -2
  340. data/tracks/go/exercises/word-count/word_count.go +0 -9
@@ -5,8 +5,6 @@ import (
5
5
  "strings"
6
6
  )
7
7
 
8
- const testVersion = 2
9
-
10
8
  func Detect(subject string, candidates []string) []string {
11
9
  subject = strings.ToLower(subject)
12
10
  var matches []string
@@ -2,14 +2,6 @@ package atbash
2
2
 
3
3
  import "testing"
4
4
 
5
- const targetTestVersion = 2
6
-
7
- func TestTestVersion(t *testing.T) {
8
- if testVersion != targetTestVersion {
9
- t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
10
- }
11
- }
12
-
13
5
  func TestAtbash(t *testing.T) {
14
6
  for _, test := range tests {
15
7
  actual := Atbash(test.s)
@@ -1,8 +1,8 @@
1
1
  package atbash
2
2
 
3
- // Source: exercism/x-common
3
+ // Source: exercism/problem-specifications
4
4
  // Commit: bb4f220 atbash-cipher: Fix canonical-data.json formatting
5
- // x-common version: 1.0.0
5
+ // Problem Specifications Version: 1.0.0
6
6
 
7
7
  type atbashTest struct {
8
8
  s string
@@ -5,8 +5,6 @@ import (
5
5
  "strings"
6
6
  )
7
7
 
8
- const testVersion = 2
9
-
10
8
  var alphabet = "abcdefghijklmnopqrstuvwxyz"
11
9
 
12
10
  func Atbash(s string) string {
@@ -34,14 +34,6 @@ import (
34
34
  "time"
35
35
  )
36
36
 
37
- const targetTestVersion = 1
38
-
39
- func TestTestVersion(t *testing.T) {
40
- if testVersion != targetTestVersion {
41
- t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
42
- }
43
- }
44
-
45
37
  func TestSeqOpenBalanceClose(t *testing.T) {
46
38
  // open account
47
39
  const amt = 10
@@ -2,8 +2,6 @@ package account
2
2
 
3
3
  import "sync"
4
4
 
5
- const testVersion = 1
6
-
7
5
  type Account struct {
8
6
  sync.RWMutex
9
7
  open bool
@@ -4,8 +4,6 @@ import (
4
4
  "testing"
5
5
  )
6
6
 
7
- const targetTestVersion = 1
8
-
9
7
  const verse8 = "8 bottles of beer on the wall, 8 bottles of beer.\nTake one down and pass it around, 7 bottles of beer on the wall.\n"
10
8
  const verse3 = "3 bottles of beer on the wall, 3 bottles of beer.\nTake one down and pass it around, 2 bottles of beer on the wall.\n"
11
9
  const verse2 = "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"
@@ -48,12 +46,6 @@ var verseTestCases = []struct {
48
46
  {"invalid verse", 104, "", true},
49
47
  }
50
48
 
51
- func TestTestVersion(t *testing.T) {
52
- if testVersion != targetTestVersion {
53
- t.Fatalf("Found testVersion = %v, want %v.", testVersion, targetTestVersion)
54
- }
55
- }
56
-
57
49
  func TestBottlesVerse(t *testing.T) {
58
50
  for _, tt := range verseTestCases {
59
51
  actualVerse, err := Verse(tt.verse)
@@ -5,8 +5,6 @@ import (
5
5
  "fmt"
6
6
  )
7
7
 
8
- const testVersion = 1
9
-
10
8
  // Song returns the full lyrics for 99 bottles of beer
11
9
  func Song() (result string) {
12
10
  result, _ = Verses(99, 0)
@@ -19,14 +19,6 @@ import (
19
19
  "testing"
20
20
  )
21
21
 
22
- const targetTestVersion = 1
23
-
24
- func TestTestVersion(t *testing.T) {
25
- if testVersion != targetTestVersion {
26
- t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
27
- }
28
- }
29
-
30
22
  func TestDataIsRetained(t *testing.T) {
31
23
  actual := Bst(4).data
32
24
  expected := 4
@@ -1,7 +1,5 @@
1
1
  package binarysearchtree
2
2
 
3
- const testVersion = 1
4
-
5
3
  type SearchTreeData struct {
6
4
  left *SearchTreeData
7
5
  data int
@@ -25,8 +25,6 @@ import (
25
25
  "testing"
26
26
  )
27
27
 
28
- const targetTestVersion = 1
29
-
30
28
  var testData = []struct {
31
29
  ref string
32
30
  slice []int
@@ -86,12 +84,6 @@ var testData = []struct {
86
84
  nil, 0, 0},
87
85
  }
88
86
 
89
- func TestTestVersion(t *testing.T) {
90
- if testVersion != targetTestVersion {
91
- t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
92
- }
93
- }
94
-
95
87
  func TestSearchInts(t *testing.T) {
96
88
  for _, test := range testData {
97
89
  if !sort.IntsAreSorted(test.slice) {
@@ -2,8 +2,6 @@ package binarysearch
2
2
 
3
3
  import "fmt"
4
4
 
5
- const testVersion = 1
6
-
7
5
  func SearchInts(s []int, k int) (i int) {
8
6
  for j := len(s); i < j; {
9
7
  if h := (i + j) / 2; s[h] < k {
@@ -13,11 +13,6 @@ import (
13
13
  // For invalid inputs, return an error that signals to the user why the error happened.
14
14
  // The test cases can only check that you return *some* error,
15
15
  // but it's still good practice to return useful errors.
16
- //
17
- // Also define a testVersion with a value that matches
18
- // the targetTestVersion here.
19
-
20
- const targetTestVersion = 2
21
16
 
22
17
  var testCases = []struct {
23
18
  binary string
@@ -38,12 +33,6 @@ var testCases = []struct {
38
33
  {"22", 0, false},
39
34
  }
40
35
 
41
- func TestTestVersion(t *testing.T) {
42
- if testVersion != targetTestVersion {
43
- t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
44
- }
45
- }
46
-
47
36
  func TestParseBinary(t *testing.T) {
48
37
  for _, tt := range testCases {
49
38
  actual, err := ParseBinary(tt.binary)
@@ -4,8 +4,6 @@ import (
4
4
  "fmt"
5
5
  )
6
6
 
7
- const testVersion = 2
8
-
9
7
  // ParseBinary converts a binary string to an integer value
10
8
  func ParseBinary(bin string) (int, error) {
11
9
  val := 0
@@ -1,3 +1,17 @@
1
+ // This is a "stub" file. It's a little start on your solution.
2
+ // It's not a complete solution though; you have to write some code.
3
+
4
+ // Package bob should have a package comment that summarizes what it's about.
5
+ // https://golang.org/doc/effective_go.html#commentary
1
6
  package bob
2
7
 
3
8
  const testVersion = 3
9
+
10
+ // Hey should have a comment documenting it.
11
+ func Hey(remark string) string {
12
+ // Write some code here to pass the test suite.
13
+ // Then remove all the stock comments.
14
+ // They're here to help you get started but they only clutter a finished solution.
15
+ // If you leave them in, reviewers may protest!
16
+ return ""
17
+ }
@@ -2,15 +2,7 @@ package bob
2
2
 
3
3
  import "testing"
4
4
 
5
- const targetTestVersion = 3
6
-
7
- func TestTestVersion(t *testing.T) {
8
- if testVersion != targetTestVersion {
9
- t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
10
- }
11
- }
12
-
13
- func TestHeyBob(t *testing.T) {
5
+ func TestHey(t *testing.T) {
14
6
  for _, tt := range testCases {
15
7
  actual := Hey(tt.input)
16
8
  if actual != tt.expected {
@@ -24,7 +16,7 @@ func TestHeyBob(t *testing.T) {
24
16
  }
25
17
  }
26
18
 
27
- func BenchmarkBob(b *testing.B) {
19
+ func BenchmarkHey(b *testing.B) {
28
20
  for _, tt := range testCases {
29
21
  for i := 0; i < b.N; i++ {
30
22
  Hey(tt.input)
@@ -1,8 +1,8 @@
1
1
  package bob
2
2
 
3
- // Source: exercism/x-common
3
+ // Source: exercism/problem-specifications
4
4
  // Commit: 65756b1 bob: Fix canonical-data.json formatting
5
- // x-common version: 1.0.0
5
+ // Problem Specifications Version: 1.0.0
6
6
 
7
7
  var testCases = []struct {
8
8
  description string
@@ -2,29 +2,28 @@ package bob
2
2
 
3
3
  import "strings"
4
4
 
5
- const testVersion = 3
6
-
7
- func Hey(drivel string) string {
8
- switch drivel = strings.TrimSpace(drivel); {
9
- case silent(drivel):
5
+ // Hey returns Bob's responses to a given remark.
6
+ func Hey(remark string) string {
7
+ switch remark = strings.TrimSpace(remark); {
8
+ case silent(remark):
10
9
  return "Fine. Be that way!"
11
- case yelling(drivel):
10
+ case yelling(remark):
12
11
  return "Whoa, chill out!"
13
- case asking(drivel):
12
+ case asking(remark):
14
13
  return "Sure."
15
14
  default:
16
15
  return "Whatever."
17
16
  }
18
17
  }
19
18
 
20
- func yelling(drivel string) bool {
21
- return strings.ToUpper(drivel) == drivel && strings.ToLower(drivel) != strings.ToUpper(drivel)
19
+ func yelling(remark string) bool {
20
+ return strings.ToUpper(remark) == remark && strings.ToLower(remark) != strings.ToUpper(remark)
22
21
  }
23
22
 
24
- func asking(drivel string) bool {
25
- return strings.HasSuffix(drivel, "?")
23
+ func asking(remark string) bool {
24
+ return strings.HasSuffix(remark, "?")
26
25
  }
27
26
 
28
- func silent(drivel string) bool {
29
- return drivel == ""
27
+ func silent(remark string) bool {
28
+ return remark == ""
30
29
  }
@@ -0,0 +1,92 @@
1
+ # Book Store
2
+
3
+ To try and encourage more sales of different books from a popular 5 book
4
+ series, a bookshop has decided to offer discounts on multiple book purchases.
5
+
6
+ One copy of any of the five books costs $8.
7
+
8
+ If, however, you buy two different books, you get a 5%
9
+ discount on those two books.
10
+
11
+ If you buy 3 different books, you get a 10% discount.
12
+
13
+ If you buy 4 different books, you get a 20% discount.
14
+
15
+ If you buy all 5, you get a 25% discount.
16
+
17
+ Note: that if you buy four books, of which 3 are
18
+ different titles, you get a 10% discount on the 3 that
19
+ form part of a set, but the fourth book still costs $8.
20
+
21
+ Your mission is to write a piece of code to calculate the
22
+ price of any conceivable shopping basket (containing only
23
+ books of the same series), giving as big a discount as
24
+ possible.
25
+
26
+ For example, how much does this basket of books cost?
27
+
28
+ - 2 copies of the first book
29
+ - 2 copies of the second book
30
+ - 2 copies of the third book
31
+ - 1 copy of the fourth book
32
+ - 1 copy of the fifth book
33
+
34
+ One way of grouping these 8 books is:
35
+
36
+ - 1 group of 5 --> 25% discount (1st,2nd,3rd,4th,5th)
37
+ - +1 group of 3 --> 10% discount (1st,2nd,3rd)
38
+
39
+ This would give a total of:
40
+
41
+ - 5 books at a 25% discount
42
+ - +3 books at a 10% discount
43
+
44
+ Resulting in:
45
+
46
+ - 5 x (8 - 2.00) == 5 x 6.00 == $30.00
47
+ - +3 x (8 - 0.80) == 3 x 7.20 == $21.60
48
+
49
+ For a total of $51.60
50
+
51
+ However, a different way to group these 8 books is:
52
+
53
+ - 1 group of 4 books --> 20% discount (1st,2nd,3rd,4th)
54
+ - +1 group of 4 books --> 20% discount (1st,2nd,3rd,5th)
55
+
56
+ This would give a total of:
57
+
58
+ - 4 books at a 20% discount
59
+ - +4 books at a 20% discount
60
+
61
+ Resulting in:
62
+
63
+ - 4 x (8 - 1.60) == 4 x 6.40 == $25.60
64
+ - +4 x (8 - 1.60) == 4 x 6.40 == $25.60
65
+
66
+ For a total of $51.20
67
+
68
+ And $51.20 is the price with the biggest discount.
69
+
70
+ ## Running the tests
71
+
72
+ To run the tests run the command `go test` from within the exercise directory.
73
+
74
+ If the test suite contains benchmarks, you can run these with the `-bench`
75
+ flag:
76
+
77
+ go test -bench .
78
+
79
+ Keep in mind that each reviewer will run benchmarks on a different machine, with
80
+ different specs, so the results from these benchmark tests may vary.
81
+
82
+ ## Further information
83
+
84
+ For more detailed information about the Go track, including how to get help if
85
+ you're having trouble, please visit the exercism.io [Go language page](http://exercism.io/languages/go/about).
86
+
87
+ ## Source
88
+
89
+ [Inspired by the harry potter kata from Cyber-Dojo](http://cyber-dojo.org).
90
+
91
+ ## Submitting Incomplete Solutions
92
+ It's possible to submit an incomplete solution so you can see how others have completed the exercise.
@@ -0,0 +1,91 @@
1
+ package bookstore
2
+
3
+ import (
4
+ "testing"
5
+ )
6
+
7
+ var testCases = []struct {
8
+ description string
9
+ basket []int
10
+ expected float64
11
+ }{
12
+ {
13
+ description: "only a single book",
14
+ basket: []int{1},
15
+ expected: 8.00,
16
+ },
17
+ {
18
+ description: "two of the same book",
19
+ basket: []int{2, 2},
20
+ expected: 16.00,
21
+ },
22
+ {
23
+ description: "empty basket",
24
+ basket: []int{},
25
+ expected: 0.00,
26
+ },
27
+ {
28
+ description: "two different books",
29
+ basket: []int{1, 2},
30
+ expected: 15.20,
31
+ },
32
+ {
33
+ description: "four different books",
34
+ basket: []int{1, 2, 3, 4},
35
+ expected: 25.60,
36
+ },
37
+ {
38
+ description: "five different books",
39
+ basket: []int{1, 2, 3, 4, 5},
40
+ expected: 30.00,
41
+ },
42
+ {
43
+ description: "two groups of four is cheaper than group of five plus group of three",
44
+ basket: []int{1, 1, 2, 2, 3, 3, 4, 5},
45
+ expected: 51.20,
46
+ },
47
+ {
48
+ description: "groups of four plus group of two is is cheaper than two groups of three",
49
+ basket: []int{1, 1, 2, 2, 3, 4},
50
+ expected: 40.80,
51
+ },
52
+ {
53
+ description: "two each of first 4 books and 1 copy of each of rest",
54
+ basket: []int{1, 1, 2, 2, 3, 3, 4, 4, 5},
55
+ expected: 55.60,
56
+ },
57
+ {
58
+ description: "two copies of each book",
59
+ basket: []int{1, 1, 2, 2, 3, 3, 4, 4, 5, 5},
60
+ expected: 60.00,
61
+ },
62
+ {
63
+ description: "three copies of first book and 2 each fo remaining",
64
+ basket: []int{1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 1},
65
+ expected: 68.00,
66
+ },
67
+ {
68
+ description: "three each of first 2 books and 2 each of remaining books",
69
+ basket: []int{1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 1, 2},
70
+ expected: 75.20,
71
+ },
72
+ }
73
+
74
+ func TestCost(t *testing.T) {
75
+ for _, testCase := range testCases {
76
+ cost := Cost(testCase.basket)
77
+ if testCase.expected != cost {
78
+ t.Fatalf("FAIL: %s\n\tCost(%v) expected %v, got %v",
79
+ testCase.description, testCase.basket, testCase.expected, cost)
80
+ }
81
+ t.Logf("PASS: %s", testCase.description)
82
+ }
83
+ }
84
+
85
+ func BenchmarkCost(b *testing.B) {
86
+ for i := 0; i < b.N; i++ {
87
+ for _, testCase := range testCases {
88
+ Cost(testCase.basket)
89
+ }
90
+ }
91
+ }