Add test for string/drop
This adds a test for the `string/drop` instruction
This commit is contained in:
parent
f14d738669
commit
19b67cdfec
@ -96,9 +96,21 @@
|
|||||||
(prop/for-all [str gen/string
|
(prop/for-all [str gen/string
|
||||||
char gen/char]
|
char gen/char]
|
||||||
(check-contains-char str char)))
|
(check-contains-char str char)))
|
||||||
|
|
||||||
|
|
||||||
|
;; string/drop
|
||||||
|
|
||||||
|
(defn check-drop
|
||||||
|
[value n]
|
||||||
|
(let [start-state (-> state/empty-state
|
||||||
|
(state/push-to-stack :string value)
|
||||||
|
(state/push-to-stack :integer n))
|
||||||
|
end-state ((:string_drop @core/instruction-table) start-state)
|
||||||
|
expected-result (apply str (drop n value))]
|
||||||
|
(= expected-result
|
||||||
(state/peek-stack end-state :string))))
|
(state/peek-stack end-state :string))))
|
||||||
|
|
||||||
(defspec contains-char-spec 100
|
(defspec drop-spec 100
|
||||||
(prop/for-all [str gen/string
|
(prop/for-all [str gen/string
|
||||||
char gen/string]
|
int gen/small-integer]
|
||||||
(check-concat str char)))
|
(check-drop str int)))
|
Loading…
x
Reference in New Issue
Block a user