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.
- checksums.yaml +4 -4
- data/lib/trackler/version.rb +1 -1
- data/problem-specifications/exercises/pig-latin/description.md +4 -4
- data/tracks/c/config.json +42 -0
- data/tracks/c/exercises/bracket-push/README.md +3 -0
- data/tracks/c/exercises/bracket-push/makefile +25 -0
- data/tracks/c/exercises/bracket-push/src/example.c +52 -0
- data/tracks/c/exercises/bracket-push/src/example.h +7 -0
- data/tracks/c/exercises/bracket-push/test/test_bracket_push.c +132 -0
- data/tracks/c/exercises/bracket-push/test/vendor/unity.c +1300 -0
- data/tracks/c/exercises/bracket-push/test/vendor/unity.h +274 -0
- data/tracks/c/exercises/bracket-push/test/vendor/unity_internals.h +701 -0
- data/tracks/c/exercises/etl/README.md +46 -0
- data/tracks/c/exercises/etl/makefile +25 -0
- data/tracks/c/exercises/etl/src/example.c +44 -0
- data/tracks/c/exercises/etl/src/example.h +18 -0
- data/tracks/c/exercises/etl/test/test_etl.c +120 -0
- data/tracks/c/exercises/etl/test/vendor/unity.c +1300 -0
- data/tracks/c/exercises/etl/test/vendor/unity.h +274 -0
- data/tracks/c/exercises/etl/test/vendor/unity_internals.h +701 -0
- data/tracks/c/exercises/luhn/README.md +64 -0
- data/tracks/c/exercises/luhn/makefile +25 -0
- data/tracks/c/exercises/luhn/src/example.c +38 -0
- data/tracks/c/exercises/luhn/src/example.h +7 -0
- data/tracks/c/exercises/luhn/test/test_luhn.c +109 -0
- data/tracks/c/exercises/luhn/test/vendor/unity.c +1300 -0
- data/tracks/c/exercises/luhn/test/vendor/unity.h +274 -0
- data/tracks/c/exercises/luhn/test/vendor/unity_internals.h +701 -0
- data/tracks/c/exercises/prime-factors/README.md +29 -0
- data/tracks/c/exercises/prime-factors/makefile +25 -0
- data/tracks/c/exercises/prime-factors/src/example.c +28 -0
- data/tracks/c/exercises/prime-factors/src/example.h +11 -0
- data/tracks/c/exercises/prime-factors/test/test_prime_factors.c +96 -0
- data/tracks/c/exercises/prime-factors/test/vendor/unity.c +1300 -0
- data/tracks/c/exercises/prime-factors/test/vendor/unity.h +274 -0
- data/tracks/c/exercises/prime-factors/test/vendor/unity_internals.h +701 -0
- data/tracks/clojure/exercises/hello-world/src/example.clj +2 -3
- data/tracks/clojure/exercises/hello-world/test/hello_world_test.clj +0 -6
- data/tracks/common-lisp/README.md +3 -8
- data/tracks/common-lisp/config/exercise_readme.go.tmpl +1 -1
- data/tracks/common-lisp/exercises/acronym/README.md +1 -1
- data/tracks/common-lisp/exercises/acronym/acronym-test.lisp +0 -5
- data/tracks/common-lisp/exercises/allergies/README.md +1 -1
- data/tracks/common-lisp/exercises/anagram/README.md +1 -1
- data/tracks/common-lisp/exercises/atbash-cipher/README.md +1 -1
- data/tracks/common-lisp/exercises/beer-song/README.md +1 -1
- data/tracks/common-lisp/exercises/binary/README.md +1 -1
- data/tracks/common-lisp/exercises/bob/README.md +1 -1
- data/tracks/common-lisp/exercises/collatz-conjecture/README.md +1 -1
- data/tracks/common-lisp/exercises/crypto-square/README.md +1 -1
- data/tracks/common-lisp/exercises/difference-of-squares/README.md +1 -1
- data/tracks/common-lisp/exercises/etl/README.md +1 -1
- data/tracks/common-lisp/exercises/gigasecond/README.md +1 -1
- data/tracks/common-lisp/exercises/grade-school/README.md +1 -1
- data/tracks/common-lisp/exercises/grains/README.md +1 -1
- data/tracks/common-lisp/exercises/hamming/README.md +1 -1
- data/tracks/common-lisp/exercises/hello-world/README.md +1 -1
- data/tracks/common-lisp/exercises/isogram/README.md +1 -1
- data/tracks/common-lisp/exercises/leap/README.md +1 -1
- data/tracks/common-lisp/exercises/meetup/README.md +1 -1
- data/tracks/common-lisp/exercises/nucleotide-count/README.md +1 -1
- data/tracks/common-lisp/exercises/pascals-triangle/README.md +1 -1
- data/tracks/common-lisp/exercises/perfect-numbers/README.md +1 -1
- data/tracks/common-lisp/exercises/phone-number/README.md +1 -1
- data/tracks/common-lisp/exercises/prime-factors/README.md +1 -1
- data/tracks/common-lisp/exercises/raindrops/README.md +1 -1
- data/tracks/common-lisp/exercises/rna-transcription/README.md +1 -1
- data/tracks/common-lisp/exercises/robot-name/README.md +1 -1
- data/tracks/common-lisp/exercises/roman-numerals/README.md +1 -1
- data/tracks/common-lisp/exercises/scrabble-score/README.md +1 -1
- data/tracks/common-lisp/exercises/sieve/README.md +1 -1
- data/tracks/common-lisp/exercises/space-age/README.md +1 -1
- data/tracks/common-lisp/exercises/strain/README.md +1 -1
- data/tracks/common-lisp/exercises/sublist/README.md +1 -1
- data/tracks/common-lisp/exercises/triangle/README.md +1 -1
- data/tracks/common-lisp/exercises/trinary/README.md +1 -1
- data/tracks/common-lisp/exercises/word-count/README.md +1 -1
- data/tracks/csharp/exercises/meetup/MeetupTest.cs +177 -177
- data/tracks/csharp/exercises/robot-simulator/Example.cs +27 -27
- data/tracks/csharp/exercises/robot-simulator/RobotSimulator.cs +3 -3
- data/tracks/csharp/exercises/robot-simulator/RobotSimulatorTest.cs +152 -31
- data/tracks/csharp/generators/Exercises/Meetup.cs +8 -9
- data/tracks/csharp/generators/Exercises/RobotSimulator.cs +116 -0
- data/tracks/delphi/exercises/allergies/uAllergyTests.pas +28 -0
- data/tracks/delphi/exercises/binary-search/uBinarySearchExample.pas +6 -0
- data/tracks/delphi/exercises/binary-search/uBinarySearchTest.pas +53 -37
- data/tracks/delphi/exercises/collatz-conjecture/uCollatzconjectureTest.pas +3 -0
- data/tracks/delphi/exercises/etl/uETLtests.pas +13 -10
- data/tracks/delphi/exercises/grains/uGrainsTests.pas +5 -2
- data/tracks/delphi/exercises/hamming/uHammingTests.pas +3 -0
- data/tracks/delphi/exercises/hello-world/uTestHelloWorld.pas +3 -0
- data/tracks/delphi/exercises/leap/uLeapTests.pas +3 -0
- data/tracks/delphi/exercises/minesweeper/uMineSweeperTest.pas +3 -0
- data/tracks/delphi/exercises/nucleotide-count/uNucleotideCountTest.pas +5 -17
- data/tracks/delphi/exercises/perfect-numbers/uPerfectNumbersExample.pas +6 -0
- data/tracks/delphi/exercises/perfect-numbers/uPerfectNumbersTest.pas +77 -26
- data/tracks/delphi/exercises/pig-latin/README.md +4 -4
- data/tracks/delphi/exercises/pig-latin/uTestPigLatin.pas +12 -9
- data/tracks/delphi/exercises/poker/uPokerExample.pas +81 -26
- data/tracks/delphi/exercises/poker/uPokerTest.pas +343 -121
- data/tracks/delphi/exercises/raindrops/uRaindropsTest.pas +3 -0
- data/tracks/delphi/exercises/saddle-points/uSaddlePointsExample.pas +4 -3
- data/tracks/delphi/exercises/saddle-points/uSaddlePointsTests.pas +25 -47
- data/tracks/delphi/exercises/triangle/uTestTriangle.pas +4 -2
- data/tracks/delphi/exercises/two-fer/utwoferTest.pas +3 -0
- data/tracks/delphi/exercises/wordy/uWordyTests.pas +3 -0
- data/tracks/ecmascript/.travis.yml +2 -1
- data/tracks/ecmascript/config.json +14 -0
- data/tracks/ecmascript/exercises/accumulate/package.json +1 -2
- data/tracks/ecmascript/exercises/acronym/package.json +1 -2
- data/tracks/ecmascript/exercises/all-your-base/package.json +1 -2
- data/tracks/ecmascript/exercises/allergies/package.json +1 -2
- data/tracks/ecmascript/exercises/alphametics/package.json +1 -2
- data/tracks/ecmascript/exercises/anagram/package.json +1 -2
- data/tracks/ecmascript/exercises/atbash-cipher/package.json +1 -2
- data/tracks/ecmascript/exercises/beer-song/package.json +1 -2
- data/tracks/ecmascript/exercises/binary-search-tree/package.json +1 -2
- data/tracks/ecmascript/exercises/binary-search/package.json +1 -2
- data/tracks/ecmascript/exercises/binary/package.json +1 -2
- data/tracks/ecmascript/exercises/bob/README.md +2 -0
- data/tracks/ecmascript/exercises/bob/bob.spec.js +5 -5
- data/tracks/ecmascript/exercises/bob/example.js +7 -2
- data/tracks/ecmascript/exercises/bob/package.json +1 -2
- data/tracks/ecmascript/exercises/bowling/package.json +1 -2
- data/tracks/ecmascript/exercises/bracket-push/package.json +1 -2
- data/tracks/ecmascript/exercises/change/package.json +1 -2
- data/tracks/ecmascript/exercises/circular-buffer/package.json +1 -2
- data/tracks/ecmascript/exercises/clock/package.json +1 -2
- data/tracks/ecmascript/exercises/collatz-conjecture/package.json +1 -2
- data/tracks/ecmascript/exercises/complex-numbers/package.json +1 -2
- data/tracks/ecmascript/exercises/connect/package.json +1 -2
- data/tracks/ecmascript/exercises/crypto-square/package.json +1 -2
- data/tracks/ecmascript/exercises/custom-set/package.json +1 -2
- data/tracks/ecmascript/exercises/diamond/package.json +1 -2
- data/tracks/ecmascript/exercises/difference-of-squares/package.json +1 -2
- data/tracks/ecmascript/exercises/diffie-hellman/package.json +1 -2
- data/tracks/ecmascript/exercises/etl/package.json +1 -2
- data/tracks/ecmascript/exercises/flatten-array/package.json +1 -2
- data/tracks/ecmascript/exercises/food-chain/package.json +1 -2
- data/tracks/ecmascript/exercises/gigasecond/package.json +1 -2
- data/tracks/ecmascript/exercises/grade-school/package.json +1 -2
- data/tracks/ecmascript/exercises/grains/package.json +1 -2
- data/tracks/ecmascript/exercises/hamming/package.json +1 -2
- data/tracks/ecmascript/exercises/hello-world/package.json +1 -2
- data/tracks/ecmascript/exercises/hexadecimal/package.json +1 -2
- data/tracks/ecmascript/exercises/house/package.json +1 -2
- data/tracks/ecmascript/exercises/isbn-verifier/package.json +1 -2
- data/tracks/ecmascript/exercises/isogram/package.json +1 -2
- data/tracks/ecmascript/exercises/kindergarten-garden/package.json +1 -2
- data/tracks/ecmascript/exercises/largest-series-product/package.json +1 -2
- data/tracks/ecmascript/exercises/leap/package.json +1 -2
- data/tracks/ecmascript/exercises/linked-list/package.json +1 -2
- data/tracks/ecmascript/exercises/list-ops/package.json +1 -2
- data/tracks/ecmascript/exercises/luhn/package.json +1 -2
- data/tracks/ecmascript/exercises/matrix/package.json +1 -2
- data/tracks/ecmascript/exercises/meetup/package.json +1 -2
- data/tracks/ecmascript/exercises/minesweeper/package.json +1 -2
- data/tracks/ecmascript/exercises/nth-prime/package.json +1 -2
- data/tracks/ecmascript/exercises/nucleotide-count/README.md +60 -0
- data/tracks/ecmascript/exercises/nucleotide-count/example.js +13 -0
- data/tracks/ecmascript/exercises/nucleotide-count/nucleotide-count.spec.js +23 -0
- data/tracks/ecmascript/exercises/nucleotide-count/package.json +70 -0
- data/tracks/ecmascript/exercises/ocr-numbers/package.json +1 -2
- data/tracks/ecmascript/exercises/octal/package.json +1 -2
- data/tracks/ecmascript/exercises/palindrome-products/package.json +1 -2
- data/tracks/ecmascript/exercises/pangram/package.json +1 -2
- data/tracks/ecmascript/exercises/pascals-triangle/package.json +1 -2
- data/tracks/ecmascript/exercises/perfect-numbers/package.json +1 -2
- data/tracks/ecmascript/exercises/phone-number/package.json +1 -2
- data/tracks/ecmascript/exercises/pig-latin/package.json +1 -2
- data/tracks/ecmascript/exercises/prime-factors/package.json +1 -2
- data/tracks/ecmascript/exercises/protein-translation/package.json +1 -2
- data/tracks/ecmascript/exercises/proverb/package.json +1 -2
- data/tracks/ecmascript/exercises/pythagorean-triplet/package.json +1 -2
- data/tracks/ecmascript/exercises/queen-attack/package.json +1 -2
- data/tracks/ecmascript/exercises/raindrops/package.json +1 -2
- data/tracks/ecmascript/exercises/react/package.json +1 -2
- data/tracks/ecmascript/exercises/rectangles/package.json +1 -2
- data/tracks/ecmascript/exercises/rna-transcription/package.json +1 -2
- data/tracks/ecmascript/exercises/robot-name/package.json +1 -2
- data/tracks/ecmascript/exercises/robot-simulator/package.json +1 -2
- data/tracks/ecmascript/exercises/roman-numerals/package.json +1 -2
- data/tracks/ecmascript/exercises/rotational-cipher/package.json +1 -2
- data/tracks/ecmascript/exercises/run-length-encoding/package.json +1 -2
- data/tracks/ecmascript/exercises/saddle-points/package.json +1 -2
- data/tracks/ecmascript/exercises/say/package.json +1 -2
- data/tracks/ecmascript/exercises/scrabble-score/package.json +1 -2
- data/tracks/ecmascript/exercises/secret-handshake/package.json +1 -2
- data/tracks/ecmascript/exercises/series/package.json +1 -2
- data/tracks/ecmascript/exercises/sieve/package.json +1 -2
- data/tracks/ecmascript/exercises/simple-cipher/package.json +1 -2
- data/tracks/ecmascript/exercises/simple-linked-list/package.json +1 -2
- data/tracks/ecmascript/exercises/space-age/package.json +1 -2
- data/tracks/ecmascript/exercises/spiral-matrix/package.json +1 -2
- data/tracks/ecmascript/exercises/strain/package.json +1 -2
- data/tracks/ecmascript/exercises/sublist/package.json +1 -2
- data/tracks/ecmascript/exercises/sum-of-multiples/package.json +1 -2
- data/tracks/ecmascript/exercises/transpose/package.json +1 -2
- data/tracks/ecmascript/exercises/triangle/package.json +1 -2
- data/tracks/ecmascript/exercises/trinary/package.json +1 -2
- data/tracks/ecmascript/exercises/twelve-days/package.json +1 -2
- data/tracks/ecmascript/exercises/two-bucket/package.json +1 -2
- data/tracks/ecmascript/exercises/two-fer/package.json +1 -2
- data/tracks/ecmascript/exercises/word-count/package.json +1 -2
- data/tracks/ecmascript/exercises/word-search/package.json +1 -2
- data/tracks/ecmascript/exercises/wordy/package.json +1 -2
- data/tracks/ecmascript/package.json +1 -2
- data/tracks/elm/config.json +13 -1
- data/tracks/elm/exercises/binary-search/BinarySearch.elm +9 -0
- data/tracks/elm/exercises/binary-search/BinarySearch.example.elm +36 -0
- data/tracks/elm/exercises/binary-search/README.md +71 -0
- data/tracks/elm/exercises/binary-search/elm-package.json +15 -0
- data/tracks/elm/exercises/binary-search/tests/Tests.elm +66 -0
- data/tracks/elm/exercises/binary-search/tests/elm-package.json +17 -0
- data/tracks/elm/exercises/hamming/Hamming.example.elm +3 -3
- data/tracks/elm/exercises/hamming/tests/Tests.elm +14 -14
- data/tracks/go/exercises/word-search/.meta/gen.go +9 -7
- data/tracks/go/exercises/word-search/cases_test.go +2 -2
- data/tracks/groovy/config.json +12 -0
- data/tracks/groovy/exercises/bank-account/BankAccount.groovy +30 -0
- data/tracks/groovy/exercises/bank-account/BankAccountSpec.groovy +200 -0
- data/tracks/groovy/exercises/bank-account/Example.groovy +47 -0
- data/tracks/groovy/exercises/bank-account/README.md +75 -0
- data/tracks/groovy/exercises/phone-number/Example.groovy +10 -14
- data/tracks/groovy/exercises/phone-number/PhoneNumber.groovy +2 -14
- data/tracks/groovy/exercises/phone-number/PhoneNumberSpec.groovy +39 -26
- data/tracks/groovy/exercises/phone-number/README.md +1 -1
- data/tracks/java/config.json +13 -0
- data/tracks/java/exercises/forth/README.md +10 -0
- data/tracks/java/exercises/rna-transcription/.meta/version +1 -1
- data/tracks/java/exercises/settings.gradle +1 -0
- data/tracks/java/exercises/sieve/.meta/version +1 -1
- data/tracks/java/exercises/spiral-matrix/.meta/version +1 -1
- data/tracks/java/exercises/triangle/.meta/version +1 -1
- data/tracks/java/exercises/two-bucket/README.md +1 -1
- data/tracks/java/exercises/zipper/.meta/src/reference/java/Zipper.java +199 -0
- data/tracks/java/exercises/zipper/.meta/version +1 -0
- data/tracks/java/exercises/zipper/README.md +42 -0
- data/tracks/java/exercises/zipper/build.gradle +18 -0
- data/tracks/java/exercises/zipper/src/main/java/.keep +0 -0
- data/tracks/java/exercises/zipper/src/test/java/ZipperTest.java +204 -0
- data/tracks/javascript/package.json +10 -0
- data/tracks/ocaml/.travis-ci.sh +1 -1
- data/tracks/ocaml/.travis.yml +1 -1
- data/tracks/ocaml/README.md +1 -1
- data/tracks/ocaml/config/exercise_readme.go.tmpl +2 -0
- data/tracks/python/config.json +13 -0
- data/tracks/python/exercises/all-your-base/all_your_base.py +1 -1
- data/tracks/python/exercises/all-your-base/all_your_base_test.py +8 -8
- data/tracks/python/exercises/alphametics/alphametics_test.py +49 -9
- data/tracks/python/exercises/binary-search-tree/binary_search_tree.py +11 -5
- data/tracks/python/exercises/binary-search-tree/binary_search_tree_test.py +89 -48
- data/tracks/python/exercises/binary-search-tree/example.py +42 -52
- data/tracks/python/exercises/binary-search/binary_search_test.py +1 -1
- data/tracks/python/exercises/book-store/book_store_test.py +18 -39
- data/tracks/python/exercises/book-store/example.py +1 -1
- data/tracks/python/exercises/bowling/bowling.py +0 -2
- data/tracks/python/exercises/bowling/bowling_test.py +49 -13
- data/tracks/python/exercises/bowling/example.py +85 -135
- data/tracks/python/exercises/bracket-push/bracket_push.py +1 -1
- data/tracks/python/exercises/bracket-push/bracket_push_test.py +16 -16
- data/tracks/python/exercises/bracket-push/example.py +2 -2
- data/tracks/python/exercises/change/change_test.py +17 -4
- data/tracks/python/exercises/change/example.py +2 -2
- data/tracks/python/exercises/circular-buffer/circular_buffer.py +12 -0
- data/tracks/python/exercises/circular-buffer/circular_buffer_test.py +4 -11
- data/tracks/python/exercises/clock/clock.py +10 -1
- data/tracks/python/exercises/clock/clock_test.py +9 -9
- data/tracks/python/exercises/clock/example.py +4 -1
- data/tracks/python/exercises/collatz-conjecture/collatz_conjecture_test.py +15 -5
- data/tracks/python/exercises/collatz-conjecture/example.py +1 -1
- data/tracks/python/exercises/complex-numbers/complex_numbers_test.py +37 -26
- data/tracks/python/exercises/custom-set/custom_set_test.py +1 -1
- data/tracks/python/exercises/diamond/diamond_test.py +1 -1
- data/tracks/python/exercises/dominoes/dominoes_test.py +1 -1
- data/tracks/python/exercises/forth/forth_test.py +1 -1
- data/tracks/python/exercises/house/example.py +11 -3
- data/tracks/python/exercises/house/house.py +1 -5
- data/tracks/python/exercises/house/house_test.py +269 -116
- data/tracks/python/exercises/list-ops/list_ops_test.py +1 -1
- data/tracks/python/exercises/luhn/luhn.py +3 -0
- data/tracks/python/exercises/luhn/luhn_test.py +1 -1
- data/tracks/python/exercises/markdown/markdown_test.py +2 -3
- data/tracks/python/exercises/minesweeper/minesweeper_test.py +1 -1
- data/tracks/python/exercises/nth-prime/nth_prime_test.py +1 -1
- data/tracks/python/exercises/ocr-numbers/ocr_numbers_test.py +1 -1
- data/tracks/python/exercises/palindrome-products/palindrome_products_test.py +14 -6
- data/tracks/python/exercises/perfect-numbers/perfect_numbers_test.py +1 -24
- data/tracks/python/exercises/phone-number/phone_number_test.py +11 -3
- data/tracks/python/exercises/poker/example.py +4 -3
- data/tracks/python/exercises/poker/poker.py +1 -1
- data/tracks/python/exercises/poker/poker_test.py +196 -119
- data/tracks/python/exercises/pov/example.py +3 -3
- data/tracks/python/exercises/pov/pov.py +2 -2
- data/tracks/python/exercises/pov/pov_test.py +19 -18
- data/tracks/python/exercises/protein-translation/protein_translation_test.py +14 -24
- data/tracks/python/exercises/rail-fence-cipher/rail_fence_cipher_test.py +1 -1
- data/tracks/python/exercises/rational-numbers/README.md +59 -0
- data/tracks/python/exercises/rational-numbers/example.py +58 -0
- data/tracks/python/exercises/rational-numbers/rational_numbers.py +34 -0
- data/tracks/python/exercises/rational-numbers/rational_numbers_test.py +132 -0
- data/tracks/python/exercises/rectangles/rectangles_test.py +1 -1
- data/tracks/python/exercises/roman-numerals/roman_numerals_test.py +2 -1
- data/tracks/python/exercises/run-length-encoding/run_length_encoding_test.py +2 -2
- data/tracks/python/exercises/saddle-points/saddle_points_test.py +18 -18
- data/tracks/python/exercises/scale-generator/example.py +4 -5
- data/tracks/python/exercises/scale-generator/scale_generator.py +2 -2
- data/tracks/python/exercises/scale-generator/scale_generator_test.py +38 -73
- data/tracks/python/exercises/secret-handshake/secret_handshake_test.py +1 -1
- data/tracks/python/exercises/tournament/tournament_test.py +1 -1
- data/tracks/python/exercises/twelve-days/example.py +3 -8
- data/tracks/python/exercises/twelve-days/twelve_days.py +1 -9
- data/tracks/python/exercises/twelve-days/twelve_days_test.py +51 -50
- data/tracks/python/exercises/two-bucket/example.py +3 -4
- data/tracks/python/exercises/two-bucket/two_bucket.py +1 -1
- data/tracks/python/exercises/two-bucket/two_bucket_test.py +8 -13
- data/tracks/python/exercises/two-fer/two_fer_test.py +8 -9
- data/tracks/python/exercises/variable-length-quantity/variable_length_quantity_test.py +1 -1
- data/tracks/python/exercises/word-count/word_count_test.py +8 -14
- data/tracks/python/exercises/word-search/word_search.py +3 -15
- data/tracks/python/exercises/word-search/word_search_test.py +1 -1
- data/tracks/python/exercises/wordy/wordy_test.py +1 -1
- data/tracks/python/exercises/zebra-puzzle/example.py +11 -2
- data/tracks/python/exercises/zebra-puzzle/zebra_puzzle.py +5 -1
- data/tracks/python/exercises/zebra-puzzle/zebra_puzzle_test.py +8 -5
- data/tracks/python/exercises/zipper/zipper_test.py +24 -30
- data/tracks/scala/exercises/dominoes/src/test/scala/DominoesTest.scala +2 -2
- data/tracks/scala/exercises/flatten-array/src/test/scala/FlattenArrayTest.scala +1 -1
- data/tracks/scala/exercises/food-chain/example.scala +3 -3
- data/tracks/scala/exercises/food-chain/src/test/scala/FoodChainTest.scala +12 -12
- data/tracks/scala/exercises/forth/src/test/scala/ForthTest.scala +35 -10
- data/tracks/scala/exercises/gigasecond/src/test/scala/GigasecondTest.scala +2 -2
- data/tracks/scala/exercises/hamming/src/test/scala/HammingTest.scala +4 -4
- data/tracks/scala/exercises/hello-world/src/test/scala/HelloWorldTest.scala +2 -3
- data/tracks/scala/exercises/house/example.scala +4 -5
- data/tracks/scala/exercises/house/src/test/scala/HouseTest.scala +16 -17
- data/tracks/scala/exercises/isogram/src/test/scala/IsogramTest.scala +3 -3
- data/tracks/scala/exercises/kindergarten-garden/src/test/scala/GardenTest.scala +1 -29
- data/tracks/scala/exercises/largest-series-product/src/test/scala/SeriesTest.scala +20 -17
- data/tracks/scala/exercises/leap/src/test/scala/LeapTest.scala +3 -3
- data/tracks/scala/exercises/luhn/src/test/scala/LuhnTest.scala +3 -3
- data/tracks/scala/exercises/matrix/example.scala +5 -1
- data/tracks/scala/exercises/matrix/src/test/scala/MatrixTest.scala +48 -12
- data/tracks/scala/exercises/meetup/src/test/scala/MeetupTest.scala +2 -1
- data/tracks/scala/exercises/minesweeper/src/test/scala/MinesweeperTest.scala +9 -9
- data/tracks/scala/testgen/src/main/scala/DominoesTestGenerator.scala +6 -6
- data/tracks/scala/testgen/src/main/scala/FlattenArrayTestGenerator.scala +6 -6
- data/tracks/scala/testgen/src/main/scala/FoodChainTestGenerator.scala +10 -12
- data/tracks/scala/testgen/src/main/scala/ForthTestGenerator.scala +6 -6
- data/tracks/scala/testgen/src/main/scala/GigasecondTestGenerator.scala +6 -4
- data/tracks/scala/testgen/src/main/scala/HammingTestGenerator.scala +3 -3
- data/tracks/scala/testgen/src/main/scala/HouseTestGenerator.scala +10 -16
- data/tracks/scala/testgen/src/main/scala/IsogramTestGenerator.scala +1 -1
- data/tracks/scala/testgen/src/main/scala/KindergartenGardenTestGenerator.scala +6 -5
- data/tracks/scala/testgen/src/main/scala/LeapTestGenerator.scala +3 -3
- data/tracks/scala/testgen/src/main/scala/LuhnTestGenerator.scala +1 -1
- data/tracks/scala/testgen/src/main/scala/MatrixTestGenerator.scala +35 -0
- data/tracks/scala/testgen/src/main/scala/MeetupTestGenerator.scala +14 -11
- data/tracks/scala/testgen/src/main/scala/MinesweeperTestGenerator.scala +1 -1
- data/tracks/scala/testgen/src/main/scala/SeriesTestGenerator.scala +3 -3
- data/tracks/typescript/config/exercise_readme.go.tmpl +25 -4
- data/tracks/typescript/exercises/acronym/README.md +7 -2
- data/tracks/typescript/exercises/atbash-cipher/README.md +2 -1
- data/tracks/typescript/exercises/beer-song/README.md +2 -2
- data/tracks/typescript/exercises/binary-search-tree/README.md +2 -0
- data/tracks/typescript/exercises/circular-buffer/README.md +16 -7
- data/tracks/typescript/exercises/clock/README.md +6 -0
- data/tracks/typescript/exercises/diamond/README.md +8 -7
- data/tracks/typescript/exercises/etl/README.md +3 -1
- data/tracks/typescript/exercises/food-chain/README.md +1 -1
- data/tracks/typescript/exercises/grade-school/README.md +0 -1
- data/tracks/typescript/exercises/hello-world/.meta/hints.md +378 -0
- data/tracks/typescript/exercises/hello-world/README.md +37 -11
- data/tracks/typescript/exercises/largest-series-product/README.md +1 -6
- data/tracks/typescript/exercises/leap/README.md +1 -1
- data/tracks/typescript/exercises/linked-list/README.md +20 -15
- data/tracks/typescript/exercises/nth-prime/README.md +7 -2
- data/tracks/typescript/exercises/ocr-numbers/README.md +7 -6
- data/tracks/typescript/exercises/pangram/README.md +1 -1
- data/tracks/typescript/exercises/pascals-triangle/README.md +1 -1
- data/tracks/typescript/exercises/phone-number/README.md +4 -3
- data/tracks/typescript/exercises/prime-factors/README.md +1 -12
- data/tracks/typescript/exercises/pythagorean-triplet/README.md +3 -7
- data/tracks/typescript/exercises/rna-transcription/README.md +2 -2
- data/tracks/typescript/exercises/robot-simulator/README.md +3 -1
- data/tracks/typescript/exercises/scrabble-score/README.md +3 -1
- data/tracks/typescript/exercises/series/README.md +0 -4
- data/tracks/typescript/exercises/space-age/README.md +1 -1
- data/tracks/typescript/exercises/strain/README.md +6 -0
- data/tracks/typescript/exercises/sum-of-multiples/README.md +4 -7
- data/tracks/typescript/exercises/two-bucket/README.md +15 -19
- data/tracks/typescript/exercises/word-count/README.md +1 -2
- data/tracks/typescript/exercises/wordy/README.md +0 -5
- metadata +61 -5
- data/tracks/common-lisp/exercises/bob/.meta/description.md +0 -10
- data/tracks/javascript/.eslintrc.json +0 -10
- data/tracks/typescript/docs/EXERCISE_README_INSERT.md +0 -24
@@ -1,14 +1,20 @@
|
|
1
1
|
class TreeNode(object):
|
2
|
-
def __init__(self,
|
3
|
-
self.
|
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
|
16
|
+
def data(self):
|
11
17
|
pass
|
12
18
|
|
13
|
-
def
|
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
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
self.
|
16
|
-
|
17
|
-
def
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
self.assertEqual(
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
self.
|
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,
|
6
|
-
self.
|
7
|
-
self.
|
8
|
-
self.
|
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
|
-
|
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
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
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
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
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.
|
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.
|
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.
|
11
|
-
places=2)
|
10
|
+
self.assertEqual(calculate_total([1]), 800)
|
12
11
|
|
13
12
|
def test_two_of_the_same_book(self):
|
14
|
-
self.
|
15
|
-
places=2)
|
13
|
+
self.assertEqual(calculate_total([2, 2]), 1600)
|
16
14
|
|
17
15
|
def test_empty_basket(self):
|
18
|
-
self.
|
19
|
-
places=2)
|
16
|
+
self.assertEqual(calculate_total([]), 0)
|
20
17
|
|
21
18
|
def test_two_different_books(self):
|
22
|
-
self.
|
23
|
-
places=2)
|
19
|
+
self.assertEqual(calculate_total([1, 2]), 1520)
|
24
20
|
|
25
21
|
def test_three_different_books(self):
|
26
|
-
self.
|
27
|
-
places=2)
|
22
|
+
self.assertEqual(calculate_total([1, 2, 3]), 2160)
|
28
23
|
|
29
24
|
def test_four_different_books(self):
|
30
|
-
self.
|
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.
|
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.
|
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.
|
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.
|
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.
|
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.
|
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.
|
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.
|
51
|
+
self.assertEqual(
|
72
52
|
calculate_total([1, 1, 2, 2, 3, 3, 4, 5, 1, 1, 2, 2, 3, 3, 4, 5]),
|
73
|
-
|
74
|
-
places=2)
|
53
|
+
10240)
|
75
54
|
|
76
55
|
|
77
56
|
if __name__ == '__main__':
|
@@ -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
|
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.
|
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.
|
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.
|
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.
|
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.
|
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.
|
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.
|
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.
|
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.
|
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.
|
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__':
|