Comments (5)
@carocad Thanks for reporting this!
I agree, the "Relevant specs" section is very noisy right now.
collapse irrelevant spec pieces into ... and show only the key-predicate that failed
I have some ideas about to compact this section. One idea is to omit parts of it, as you have suggested. I am also thinking about a format like the one show in this video clip (the output of syndoc
). Unfortunately, that will probably need to wait.
make relevant specs section optional and configurable when setting up the printer
Good news 😄 ! This is available today:
(binding [s/*explain-out* (expound/custom-printer {:print-specs? false})]
(s/explain my-spec my-data))
This option has not been documented properly, but I'm going to merge in some doc fixes soon to fix this.
Please give it a try and let me know what you think.
from expound.
I am also thinking about a format like the one show in this video clip (the output of syndoc). Unfortunately, that will probably need to wait.
It looks like a very interesting way of approaching the problem :)
I think however that you should avoid trying to define (yet)
another grammar language for displaying specs. I dont have a good proposal about it unfortunately, but in my experience creating mappings between two worlds always ends up with leaky abstractions and complications for the users.
from expound.
I think however that you should avoid trying to define (yet) another grammar language for displaying specs. I dont have a good proposal about it unfortunately, but in my experience creating mappings between two worlds always ends up with leaky abstractions and complications for the users.
That's a very good point. I'll think more about this.
Did the (expound/custom-printer {:print-specs? false})
work for you to just hide the "Relevant Specs" section?
from expound.
yes using :print-specs false
solved the issue :)
thanks for the info
from expound.
@carocad Thanks for reporting this! Since there is an option to turn of relevant specs, I'm going to close this for now and continue to think about ways to make this section less verbose.
from expound.
Related Issues (20)
- Error reports returned as :cause string in an exception when produced by instrumentation within generative testing HOT 11
- allow passing options map to expound/expound-str HOT 1
- Improve grouping of spec errors HOT 2
- Unnecessary dependency on `cider-nrepl` HOT 1
- Regression of #3 HOT 4
- Easier editing of error messages
- `printer` has invalid spec HOT 2
- "Cannot convert path" on instrumentation failures in the wild HOT 4
- (cljs.spec.test.alpha/instrument) breaks expound due to wrong arity HOT 4
- should expound work anywhere s/explain works? - clojurescript error HOT 7
- Error in :ret check when using with Orchestra 2020.07.12-1 HOT 5
- Internal error in `lift-singleton-groups` when having a datomic db value in fn args HOT 13
- Crash bug when printing, if a datomic db is present and the spec fails HOT 19
- Feature inquiry: a convenience function for validating a value against a spec HOT 4
- Wrapped `s/keys` does not properly display unqualified keyword specs HOT 5
- ClassCastException from `expound-str` when running in AWS Lambda HOT 9
- Small *print-length* and/or *print-level* sometimes yield NPE HOT 5
- PersistentList cannot be cast to class Named HOT 3
- proposal : defmsg equivalent for arbitrary predicates HOT 15
- optional include location of the spec error in the message. HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from expound.