-
-
Notifications
You must be signed in to change notification settings - Fork 909
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Can't be used without Rails and with ActiveModel but not ActiveRecord? #1553
Comments
I'd like to decouple the form more from the model in order to provide a better UX with form fields which don't exist on the model. A first step is getting the existing functionality working with form objects. Note that on Edit we print the dates rather than returning the date array from the model. get rid of usage of date array - this hasn't actually been what we use for making the listings for a while now. Building the URL separately based on @event is a tradeoff: without this we need to somehow get the event ID into the form so that `form_with` can do its thing and infer which URL to use, but I couldn't find an approach for that which works well: - adding an extra initialisation parameter breaks the validation specs which are expecting to be able to `build` an activemodel instance with FactoryBot - we could add ID as an attribute and set it in the validation error case on update, but that feels awkward. Note that we need to monkeypatch Shoulda Matchers to run it without ActiveRecord. This is NOT a "responsible" way of monkeypatching, but I couldn't get it to work and all the examples I can find online are about monkeypatching instance methods not class methods. Raised an issue on the Shoulda Matchers repo here: thoughtbot/shoulda-matchers#1553
I'd like to decouple the form more from the model in order to provide a better UX with form fields which don't exist on the model. A first step is getting the existing functionality working with form objects. Note that on Edit we print the dates rather than returning the date array from the model. Get rid of usage of date_array - this hasn't actually been what we use for making the listings for a while now, but it's still been used in parallel - I guess because I wasn't sure about the SwingDates approach (which I still think is kind of batshit crazy and a bad idea, but it does mostly work) Building the URL separately based on @event is a tradeoff: without this we need to somehow get the event ID into the form so that `form_with` can do its thing and infer which URL to use, but I couldn't find an approach for that which works well: - adding an extra initialisation parameter breaks the validation specs which are expecting to be able to `build` an activemodel instance with FactoryBot - we could add ID as an attribute and set it in the validation error case on update, but that feels awkward. Note that we need to monkeypatch Shoulda Matchers to run it without ActiveRecord. This is NOT a "responsible" way of monkeypatching, but I couldn't get it to work and all the examples I can find online are about monkeypatching instance methods not class methods. Raised an issue on the Shoulda Matchers repo here: thoughtbot/shoulda-matchers#1553
I'd like to decouple the form more from the model in order to provide a better UX with form fields which don't exist on the model. A first step is getting the existing functionality working with form objects. Note that on Edit we print the dates rather than returning the date array from the model. Get rid of usage of date_array - this hasn't actually been what we use for making the listings for a while now, but it's still been used in parallel - I guess because I wasn't sure about the SwingDates approach (which I still think is kind of batshit crazy and a bad idea, but it does mostly work) Building the URL separately based on @event is a tradeoff: without this we need to somehow get the event ID into the form so that `form_with` can do its thing and infer which URL to use, but I couldn't find an approach for that which works well: - adding an extra initialisation parameter breaks the validation specs which are expecting to be able to `build` an activemodel instance with FactoryBot - we could add ID as an attribute and set it in the validation error case on update, but that feels awkward. Note that we need to monkeypatch Shoulda Matchers to run it without ActiveRecord. This is NOT a "responsible" way of monkeypatching, but I couldn't get it to work and all the examples I can find online are about monkeypatching instance methods not class methods. Raised an issue on the Shoulda Matchers repo here: thoughtbot/shoulda-matchers#1553
I tried to write a spec for @dgmstuart suggested implementation, without succeeding. So please replace the line shoulda/matchers/rails_shim.rb#L65 with:
|
As I interpret the documentation, it seems like it should be possible to use shoulda-matchers without rails, with
ActiveModel
and notActiveRecord
?I'm trying to use
validates_presence_of
in an isolated spec of an object which includesActiveModel
.This fails with
uninitialized constant ActiveRecord
.This seems to be because the matcher depends on
RailsShim
: shoulda/matchers/active_model/validate_presence_of_matcher.rb#L385...which does a type check of attributes against
::ActiveRecord::Type::Serialized
.shoulda/matchers/rails_shim.rb#L65
It seems like this might be fixable with a check like
Object.const_defined('::ActiveRecord::Type::Serialized')
, but I'm not sure if I understand enough whatRailsShim
is to understand if this is a good idea.The text was updated successfully, but these errors were encountered: