This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2018-02-08
Channels
- # aleph (2)
- # aws (1)
- # beginners (172)
- # boot (15)
- # cider (17)
- # clara (7)
- # cljs-dev (22)
- # cljsrn (12)
- # clojars (3)
- # clojure (110)
- # clojure-dev (5)
- # clojure-italy (13)
- # clojure-sanfrancisco (5)
- # clojure-spec (3)
- # clojure-uk (31)
- # clojurescript (110)
- # community-development (2)
- # cursive (16)
- # datomic (19)
- # docs (4)
- # emacs (49)
- # fulcro (24)
- # jobs (5)
- # keechma (2)
- # lein-figwheel (41)
- # leiningen (10)
- # luminus (4)
- # lumo (24)
- # mount (24)
- # numerical-computing (1)
- # off-topic (16)
- # om (4)
- # onyx (6)
- # parinfer (9)
- # planck (8)
- # re-frame (7)
- # reagent (6)
- # shadow-cljs (125)
- # sql (5)
- # test-check (9)
- # unrepl (6)
- # yada (5)
hello, I'm trying to limit the recursion of a generator, the problem is that the recursion is not "direct", it generates something, that generates something else, and ends up in circle, but this kind of recursion seems to not be detected by test.check recursion limit
I was thinking about using some dynamic var to track how many times my generator was called, and stop if goes after a number in a call stack
I was trying something like this:
(s/def ::query-root
(s/coll-of ::query-expr-root :kind vector?
:gen #(if (> *max-depth* 0)
(binding [*max-depth* (dec *max-depth*)]
(s/gen (s/coll-of ::query-expr-root :kind vector? :max-count 5)))
(s/gen #{[]}))))
but this doesn't work, because the binding is running on the generator definition, and not when the actual gen is running
I was trying to find a way to wrap some generator with this logic, but can't figure how to hook it up
how can I make this? because otherwise my generator fail about 80% of the time because of stack overflow =/
by "test.check recursion limit" you're referring to the mechanism in clojure.spec that's used when generating generators?
have you tried expressing the generator for the whole thing using gen/recursive-gen
?