Details
Assignee
UnassignedUnassignedReporter
Ben BrinckerhoffBen BrinckerhoffLabels
Approval
TriagedPriority
MajorAffects versions
Details
Details
Assignee
Unassigned
UnassignedReporter
Ben Brinckerhoff
Ben BrinckerhoffLabels
Approval
Triaged
Priority

Affects versions
Created October 29, 2017 at 8:53 PM
Updated June 22, 2018 at 3:32 PM
Context:
When data fails to conform to a spec, the ":val" of a problem points to the non-conforming data. This has the nice property that the ":val" (for each problem) will exist somewhere within the ":value" (for the entire "explain-data" structure). For example:
(require '[clojure.spec.alpha :as s]) (s/explain-data (s/coll-of int?) [1 2 :a]) ;; #:clojure.spec.alpha{:problems ({:path [], :pred int?, :val :a, :via [], :in [2]}), :spec #object[clojure.spec.alpha$every_impl$reify__934 0x1b235c3e "clojure.spec.alpha$every_impl$reify__934@1b235c3e"], :value [1 2 :a]}
This interpretation of ":val" doesn't seem to apply when a function fails to conform to an fspec spec.
Repro:
(require '[clojure.spec.alpha :as s]) (s/explain-data (s/coll-of (s/fspec :args (s/cat :x int?))) [(fn [%] (/ 1 %))]) ;; #:clojure.spec.alpha{:problems ({:path [], :pred (apply fn), :val (0), :reason "Divide by zero", :via [], :in [0]}), :spec #object[clojure.spec.alpha$every_impl$reify__934 0x420c3355 "clojure.spec.alpha$every_impl$reify__934@420c3355"], :value [#function[expound.alpha/eval28876/fn--28880]]}
Expected: In order to be consistent with the way "val" normally works, "val" should be the anonymous function. While the function arguments are very useful, perhaps they could be associated with a different key?
Actual: "val" contains the arguments to the function, so it's no longer true that the "val" exists within the "value".