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,149 +1,99 @@
|
|
1
|
-
|
2
|
-
NUM_FRAMES = 10
|
1
|
+
MAX_FRAME = 10
|
3
2
|
|
4
3
|
|
5
|
-
class
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
self.rolls = []
|
10
|
-
self.totalScore = 0
|
11
|
-
self.currentFrame = Frame()
|
12
|
-
self.bonusRollsAccrued = 0
|
13
|
-
self.bonusRollsSeen = 0
|
14
|
-
|
15
|
-
def roll(self, pins):
|
16
|
-
if self.isBonusRoll():
|
17
|
-
self.bonusRollsSeen += 1
|
18
|
-
|
19
|
-
# is the second roll valid based off the first?
|
20
|
-
if (self.currentFrame.isOpen() and
|
21
|
-
self.currentFrame.getFrame()[0] is not None):
|
22
|
-
if self.currentFrame.getFrame()[0] + pins > MAX_PINS:
|
23
|
-
raise ValueError("This roll will cause the current frame "
|
24
|
-
"to be getter than the max number of pins")
|
25
|
-
|
26
|
-
# open a new frame if the last one has been closed
|
27
|
-
if not self.currentFrame.isOpen():
|
28
|
-
self.currentFrame = Frame()
|
29
|
-
|
30
|
-
# valid roll between 0-10
|
31
|
-
if pins in range(MAX_PINS + 1):
|
32
|
-
# raise an error if the game is over and they try to roll again
|
33
|
-
if ((len(self.rolls) == NUM_FRAMES) and
|
34
|
-
self.bonusRollsAccrued == 0):
|
35
|
-
raise IndexError("Max Frames have been reached. Too many "
|
36
|
-
"rolls")
|
37
|
-
else:
|
38
|
-
self.currentFrame.roll(pins,
|
39
|
-
self.isBonusRoll(),
|
40
|
-
self.bonusRollsAccrued,
|
41
|
-
self.bonusRollsSeen)
|
42
|
-
# if we closed it add it to our rolls
|
43
|
-
if not self.currentFrame.isOpen():
|
44
|
-
self.rolls.append(self.currentFrame)
|
45
|
-
# If this is the last frame did we earn any bonus rolls?
|
46
|
-
if len(self.rolls) == NUM_FRAMES:
|
47
|
-
self.bonusRollsEarned()
|
48
|
-
else:
|
49
|
-
raise ValueError("Amount of pins rolled is greater than the max "
|
50
|
-
"number of pins")
|
51
|
-
|
52
|
-
def score(self):
|
53
|
-
frame_index = 0
|
54
|
-
|
55
|
-
while (frame_index <= NUM_FRAMES-1):
|
56
|
-
frame = self.rolls[frame_index].getFrame()
|
4
|
+
class Frame(object):
|
5
|
+
def __init__(self, idx):
|
6
|
+
self.idx = idx
|
7
|
+
self.throws = []
|
57
8
|
|
58
|
-
|
59
|
-
|
9
|
+
@property
|
10
|
+
def total_pins(self):
|
11
|
+
"""Total pins knocked down in a frame."""
|
12
|
+
return sum(self.throws)
|
60
13
|
|
61
|
-
|
62
|
-
|
63
|
-
else:
|
64
|
-
if self.isSpare(roll1, roll2):
|
65
|
-
self.totalScore += roll1 + roll2 + \
|
66
|
-
self.spareBonus(frame_index)
|
67
|
-
else:
|
68
|
-
self.totalScore += roll1 + roll2
|
14
|
+
def is_strike(self):
|
15
|
+
return self.total_pins == 10 and len(self.throws) == 1
|
69
16
|
|
70
|
-
|
17
|
+
def is_spare(self):
|
18
|
+
return self.total_pins == 10 and len(self.throws) == 2
|
71
19
|
|
72
|
-
|
20
|
+
def is_open(self):
|
21
|
+
return self.total_pins < 10 and len(self.throws) == 2
|
73
22
|
|
74
|
-
def
|
75
|
-
|
23
|
+
def is_closed(self):
|
24
|
+
"""Return whether a frame is over."""
|
25
|
+
return self.total_pins == 10 or len(self.throws) == 2
|
76
26
|
|
77
|
-
def
|
78
|
-
|
27
|
+
def throw(self, pins):
|
28
|
+
if self.total_pins + pins > 10:
|
29
|
+
raise ValueError("a frame's rolls cannot exceed 10")
|
30
|
+
self.throws.append(pins)
|
79
31
|
|
80
|
-
def
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
bonusroll2 = self.rolls[frame_index+1].getFrame()[1]
|
88
|
-
# edge case - if the last roll is a stike the bonus rolls needs to be
|
89
|
-
# validated
|
90
|
-
if (not self.isStrike(bonusroll1) and
|
91
|
-
(bonusroll1 + bonusroll2 > MAX_PINS)):
|
92
|
-
raise ValueError("The bonus rolls total to greater than the max "
|
93
|
-
"number of pins")
|
94
|
-
else:
|
95
|
-
return bonusroll1 + bonusroll2
|
32
|
+
def score(self, next_throws):
|
33
|
+
result = self.total_pins
|
34
|
+
if self.is_strike():
|
35
|
+
result += sum(next_throws[:2])
|
36
|
+
elif self.is_spare():
|
37
|
+
result += sum(next_throws[:1])
|
38
|
+
return result
|
96
39
|
|
97
|
-
def spareBonus(self, frame_index):
|
98
|
-
return self.rolls[frame_index+1].getFrame()[0]
|
99
40
|
|
100
|
-
|
101
|
-
|
41
|
+
class BowlingGame(object):
|
42
|
+
def __init__(self):
|
43
|
+
self.current_frame_idx = 0
|
44
|
+
self.bonus_throws = []
|
45
|
+
self.frames = [Frame(idx) for idx in range(MAX_FRAME)]
|
46
|
+
|
47
|
+
@property
|
48
|
+
def current_frame(self):
|
49
|
+
return self.frames[self.current_frame_idx]
|
50
|
+
|
51
|
+
def next_throws(self, frame_idx):
|
52
|
+
"""Return a frame's next throws in the form of a list."""
|
53
|
+
throws = []
|
54
|
+
for idx in range(frame_idx + 1, MAX_FRAME):
|
55
|
+
throws.extend(self.frames[idx].throws)
|
56
|
+
throws.extend(self.bonus_throws)
|
57
|
+
return throws
|
58
|
+
|
59
|
+
def roll_bonus(self, pins):
|
60
|
+
tenth_frame = self.frames[-1]
|
61
|
+
if tenth_frame.is_open():
|
62
|
+
raise IndexError("cannot throw bonus with an open tenth frame")
|
63
|
+
|
64
|
+
self.bonus_throws.append(pins)
|
65
|
+
|
66
|
+
# Check against invalid fill balls, e.g. [3, 10]
|
67
|
+
if (len(self.bonus_throws) == 2 and self.bonus_throws[0] != 10 and
|
68
|
+
sum(self.bonus_throws) > 10):
|
69
|
+
raise ValueError("invalid fill balls")
|
70
|
+
|
71
|
+
# Check if there are more bonuses than it should be
|
72
|
+
if tenth_frame.is_strike() and len(self.bonus_throws) > 2:
|
73
|
+
raise IndexError(
|
74
|
+
"wrong number of fill balls when the tenth frame is a strike")
|
75
|
+
elif tenth_frame.is_spare() and len(self.bonus_throws) > 1:
|
76
|
+
raise IndexError(
|
77
|
+
"wrong number of fill balls when the tenth frame is a spare")
|
102
78
|
|
103
|
-
def
|
104
|
-
if
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
elif self.isSpare(lastFrame[0], lastFrame[1]):
|
109
|
-
self.bonusRollsAccrued = 1
|
79
|
+
def roll(self, pins):
|
80
|
+
if not 0 <= pins <= 10:
|
81
|
+
raise ValueError("invalid pins")
|
82
|
+
elif self.current_frame_idx == MAX_FRAME:
|
83
|
+
self.roll_bonus(pins)
|
110
84
|
else:
|
111
|
-
self.
|
112
|
-
|
113
|
-
|
114
|
-
def isBonusRoll(self):
|
115
|
-
# if we've already seen all
|
116
|
-
return True if len(self.rolls) >= NUM_FRAMES else False
|
85
|
+
self.current_frame.throw(pins)
|
86
|
+
if self.current_frame.is_closed():
|
87
|
+
self.current_frame_idx += 1
|
117
88
|
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
self.
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
self.rolls[0] = 10
|
130
|
-
self.rolls[1] = 0
|
131
|
-
self.open = False
|
132
|
-
else:
|
133
|
-
# first roll, but frame is still open
|
134
|
-
if self.rolls[0] is None:
|
135
|
-
self.rolls[0] = roll
|
136
|
-
# may need to close bonus roll frames before 2 have been seen
|
137
|
-
if bonusRoll and seenBonuses == accruedBonuses:
|
138
|
-
self.rolls[1] = 0
|
139
|
-
self.open = False
|
140
|
-
else:
|
141
|
-
# second roll, closes frame
|
142
|
-
self.rolls[1] = roll
|
143
|
-
self.open = False
|
144
|
-
|
145
|
-
def isOpen(self):
|
146
|
-
return self.open
|
147
|
-
|
148
|
-
def getFrame(self):
|
149
|
-
return self.rolls
|
89
|
+
def score(self):
|
90
|
+
if self.current_frame_idx < MAX_FRAME:
|
91
|
+
raise IndexError("frame less than 10")
|
92
|
+
if self.frames[-1].is_spare() and len(self.bonus_throws) != 1:
|
93
|
+
raise IndexError(
|
94
|
+
"one bonus must be rolled when the tenth frame is spare")
|
95
|
+
if self.frames[-1].is_strike() and len(self.bonus_throws) != 2:
|
96
|
+
raise IndexError(
|
97
|
+
"two bonuses must be rolled when the tenth frame is strike")
|
98
|
+
return sum(frame.score(self.next_throws(frame.idx))
|
99
|
+
for frame in self.frames)
|
@@ -1,2 +1,2 @@
|
|
1
|
-
def
|
1
|
+
def is_paired(input_string):
|
2
2
|
pass
|
@@ -1,54 +1,54 @@
|
|
1
1
|
import unittest
|
2
2
|
|
3
|
-
from bracket_push import
|
3
|
+
from bracket_push import is_paired
|
4
4
|
|
5
5
|
|
6
|
-
# Tests adapted from `problem-specifications//canonical-data.json` @ v1.
|
6
|
+
# Tests adapted from `problem-specifications//canonical-data.json` @ v1.2.0
|
7
7
|
|
8
8
|
class BracketPushTests(unittest.TestCase):
|
9
9
|
def test_paired_square_brackets(self):
|
10
|
-
self.assertEqual(
|
10
|
+
self.assertEqual(is_paired("[]"), True)
|
11
11
|
|
12
12
|
def test_empty_string(self):
|
13
|
-
self.assertEqual(
|
13
|
+
self.assertEqual(is_paired(""), True)
|
14
14
|
|
15
15
|
def test_unpaired_brackets(self):
|
16
|
-
self.assertEqual(
|
16
|
+
self.assertEqual(is_paired("[["), False)
|
17
17
|
|
18
18
|
def test_wrong_ordered_brackets(self):
|
19
|
-
self.assertEqual(
|
19
|
+
self.assertEqual(is_paired("}{"), False)
|
20
20
|
|
21
21
|
def test_wrong_closing_bracket(self):
|
22
|
-
self.assertEqual(
|
22
|
+
self.assertEqual(is_paired("{]"), False)
|
23
23
|
|
24
24
|
def test_paired_with_whitespace(self):
|
25
|
-
self.assertEqual(
|
25
|
+
self.assertEqual(is_paired("{ }"), True)
|
26
26
|
|
27
27
|
def test_simple_nested_brackets(self):
|
28
|
-
self.assertEqual(
|
28
|
+
self.assertEqual(is_paired("{[]}"), True)
|
29
29
|
|
30
30
|
def test_several_paired_brackets(self):
|
31
|
-
self.assertEqual(
|
31
|
+
self.assertEqual(is_paired("{}[]"), True)
|
32
32
|
|
33
33
|
def test_paired_and_nested_brackets(self):
|
34
|
-
self.assertEqual(
|
34
|
+
self.assertEqual(is_paired("([{}({}[])])"), True)
|
35
35
|
|
36
36
|
def test_unopened_closing_brackets(self):
|
37
|
-
self.assertEqual(
|
37
|
+
self.assertEqual(is_paired("{[)][]}"), False)
|
38
38
|
|
39
39
|
def test_unpaired_and_nested_brackets(self):
|
40
|
-
self.assertEqual(
|
40
|
+
self.assertEqual(is_paired("([{])"), False)
|
41
41
|
|
42
42
|
def test_paired_and_wrong_nested_brackets(self):
|
43
|
-
self.assertEqual(
|
43
|
+
self.assertEqual(is_paired("[({]})"), False)
|
44
44
|
|
45
45
|
def test_math_expression(self):
|
46
46
|
self.assertEqual(
|
47
|
-
|
47
|
+
is_paired("(((185 + 223.85) * 15) - 543)/2"), True)
|
48
48
|
|
49
49
|
def test_complex_latex_expression(self):
|
50
50
|
self.assertEqual(
|
51
|
-
|
51
|
+
is_paired(
|
52
52
|
("\\left(\\begin{array}{cc} \\frac{1}{3} & x\\\\ \\mathrm{e}^{"
|
53
53
|
"x} &... x^2 \\end{array}\\right)")), True)
|
54
54
|
|
@@ -2,8 +2,8 @@ import unittest
|
|
2
2
|
|
3
3
|
from change import find_minimum_coins
|
4
4
|
|
5
|
-
# Tests adapted from `problem-specifications//canonical-data.json` @ v1.1.0
|
6
5
|
|
6
|
+
# Tests adapted from `problem-specifications//canonical-data.json` @ v1.2.0
|
7
7
|
|
8
8
|
class ChangeTest(unittest.TestCase):
|
9
9
|
def test_single_coin_change(self):
|
@@ -37,13 +37,26 @@ class ChangeTest(unittest.TestCase):
|
|
37
37
|
self.assertEqual(find_minimum_coins(0, [1, 5, 10, 21, 25]), [])
|
38
38
|
|
39
39
|
def test_error_testing_for_change_smaller_than_smallest_coin(self):
|
40
|
-
self.
|
40
|
+
with self.assertRaisesWithMessage(ValueError):
|
41
|
+
find_minimum_coins(3, [5, 10])
|
41
42
|
|
42
43
|
def test_error_if_no_combination_can_add_up_to_target(self):
|
43
|
-
self.
|
44
|
+
with self.assertRaisesWithMessage(ValueError):
|
45
|
+
find_minimum_coins(94, [5, 10])
|
44
46
|
|
45
47
|
def test_cannot_find_negative_change_values(self):
|
46
|
-
self.
|
48
|
+
with self.assertRaisesWithMessage(ValueError):
|
49
|
+
find_minimum_coins(-5, [1, 2, 5])
|
50
|
+
|
51
|
+
# Utility functions
|
52
|
+
def setUp(self):
|
53
|
+
try:
|
54
|
+
self.assertRaisesRegex
|
55
|
+
except AttributeError:
|
56
|
+
self.assertRaisesRegex = self.assertRaisesRegexp
|
57
|
+
|
58
|
+
def assertRaisesWithMessage(self, exception):
|
59
|
+
return self.assertRaisesRegex(exception, r".+")
|
47
60
|
|
48
61
|
|
49
62
|
if __name__ == "__main__":
|
@@ -1,6 +1,6 @@
|
|
1
1
|
def find_minimum_coins(total_change, coins):
|
2
2
|
if total_change < 0:
|
3
|
-
|
3
|
+
raise ValueError("cannot find negative change values")
|
4
4
|
min_coins_required = [1e9] * (total_change + 1)
|
5
5
|
last_coin = [0]*(total_change + 1)
|
6
6
|
min_coins_required[0] = 0
|
@@ -15,7 +15,7 @@ def find_minimum_coins(total_change, coins):
|
|
15
15
|
last_coin[change] = change - coin
|
16
16
|
min_coins_required[change] = final_result
|
17
17
|
if min_coins_required[total_change] == 1e9:
|
18
|
-
|
18
|
+
raise ValueError("no combination can add up to target")
|
19
19
|
else:
|
20
20
|
last_coin_value = total_change
|
21
21
|
array = []
|
@@ -7,7 +7,7 @@ from circular_buffer import (
|
|
7
7
|
)
|
8
8
|
|
9
9
|
|
10
|
-
# Tests adapted from `problem-specifications//canonical-data.json` @ v1.0
|
10
|
+
# Tests adapted from `problem-specifications//canonical-data.json` @ v1.1.0
|
11
11
|
|
12
12
|
class CircularBufferTest(unittest.TestCase):
|
13
13
|
def test_read_empty_buffer(self):
|
@@ -34,7 +34,7 @@ class CircularBufferTest(unittest.TestCase):
|
|
34
34
|
self.assertEqual(buf.read(), '1')
|
35
35
|
self.assertEqual(buf.read(), '2')
|
36
36
|
|
37
|
-
def
|
37
|
+
def test_cant_write_to_full_buffer(self):
|
38
38
|
buf = CircularBuffer(1)
|
39
39
|
buf.write('1')
|
40
40
|
with self.assertRaisesWithMessage(BufferFullException):
|
@@ -70,7 +70,7 @@ class CircularBufferTest(unittest.TestCase):
|
|
70
70
|
buf.write('2')
|
71
71
|
self.assertEqual(buf.read(), '2')
|
72
72
|
|
73
|
-
def
|
73
|
+
def test_clear_does_nothing_on_empty_buffer(self):
|
74
74
|
buf = CircularBuffer(1)
|
75
75
|
buf.clear()
|
76
76
|
buf.write('1')
|
@@ -91,14 +91,7 @@ class CircularBufferTest(unittest.TestCase):
|
|
91
91
|
self.assertEqual(buf.read(), '2')
|
92
92
|
self.assertEqual(buf.read(), '3')
|
93
93
|
|
94
|
-
def
|
95
|
-
buf = CircularBuffer(2)
|
96
|
-
buf.write('1')
|
97
|
-
buf.write('2')
|
98
|
-
with self.assertRaisesWithMessage(BufferFullException):
|
99
|
-
buf.write('A')
|
100
|
-
|
101
|
-
def test_over_write_replaces_oldest_remaning_item(self):
|
94
|
+
def test_overwrite_replaces_oldest_remaining_item(self):
|
102
95
|
buf = CircularBuffer(3)
|
103
96
|
buf.write('1')
|
104
97
|
buf.write('2')
|