Extend -compile-model for reitit.coercsion.spec#683
Open
jonasseglare wants to merge 1 commit intometosin:masterfrom
Open
Extend -compile-model for reitit.coercsion.spec#683jonasseglare wants to merge 1 commit intometosin:masterfrom
jonasseglare wants to merge 1 commit intometosin:masterfrom
Conversation
Member
|
This seems like a great feature! Could you please add a test case? |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This PR extends the
-compile-modelmethod in thereitit.coercion.specnamespace to work for one more special case: If themodelparameter contains more than one spec but they are all equal, then the merged spec is trivially any of those specs.Background
We encountered the following error when trying to instantiate our router:
So, what it means is that it fails to merge
modelif it isWe can fix this by observing that because it is a vector with the same element being repeated many times, the merged version would trivially be that element, in this case
clojure.core/any?.See relevant part of exception with stack trace:
clojure.lang.ExceptionInfo: :reitit.coercion.spec/model-error