-
Notifications
You must be signed in to change notification settings - Fork 254
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
SimpleVCell does not implement Serializable #308
Comments
Thanks for the report. This cell is a global singleton used to implement On the one hand I don't see the harm in adding the interface, but also don't want to lead people down a path fraught with other issues. Would you mind elaborating a bit on the use case for serializing fns, and what behaviour is typical / expected in situations like this? Thanks! |
In this particular case fn's are being serialized and distributed over a compute cluster by google dataflow. In such a case yeah obviously anything like a mutable global singleton is going to be fairly meaningless, existing concurrently on multiple compute nodes as it does. In that situation I would just expect a function like My thinking is functions generated by clojure.core/defn are "serializable (if AOT'd) but buyer beware", so functions generated by prismatic.schema/defn should also be "serializable but buyer beware". I suppose an alternative would be I write my own s/defn that doesn't provide the with-fn-validation functionality (or provides it using a var or something) |
Sounds reasonable to me, PR welcome. FWIW, you could also set compile-fn-validation to false which would have the effect you mention (removes all the validation logic entirely from the macroexpansion) |
Ah but I'm actually more inclined to just have validation on all the time for every function :-) sure I'll try and get a PR up monday. |
hmm, recent addition of (delay for the checker seems to have made this a fair bit harder =/ |
So the new issue is that Do you see a way to achieve this result without sacrificing performance in the common case? |
A delay isn't serializable because it has state, in general stateful things aren't marked as serializable in clj. For instance a memoized function would not be serializable. I'm not really seeing an easy way to reconcile the performance optimisation and keeping functions serializable, I'm probably going to have to create a fork where all the decisions have to happen at creation time for the fn, ie both whether to compile and whether to validate. |
Well, In any case, if you can lay out what you're thinking in terms of a fork, I'd be happy to think about how we might accomplish that within core instead. |
That's true, I guess it's a bit of a violation of that. But I suppose it would be odd if a data structure weren't serializable. shrug My basic plan is to consolidate the global compile and validate options into one, if it's turned on at the time of fn creation we both compile the validation, and have it turned on. If it's not then we don't. This would mirror how we generally turn on/off validation, which is at an environment level (dev(Y), master(Y), staging(Y), production(N)) |
So to be clear, is what you want (more or less) is a third option |
that sounds right. I'm going to put something in our backlog to do that, but y'know the real world may intervene :-) |
Sounds good, thanks :) |
Clojure functions are normally Serializable if they are AOT'd, however schema attaches some extra information to the class generated for a function when using schema.core/defn, in the form of SimpleVCell, which is a deftype that does not implement java.io.Serializable. As a result functions defined using schema.core/defn can't be serialized. Can be fixed just by adding "Serializable" to the list of interfaces for SimpleVCell.
The text was updated successfully, but these errors were encountered: