README.md in conditional_validation-0.1.0 vs README.md in conditional_validation-1.0.0
- old
+ new
@@ -1,100 +1,160 @@
# Conditional Validation
-[data:image/s3,"s3://crabby-images/5e9de/5e9dea13f1213f526702bb637a16c635e983ecc4" alt="Gem Version"](http://badge.fury.io/rb/conditional_validation)
+[data:image/s3,"s3://crabby-images/4ee3f/4ee3fe47381fe0680edd19b06f4921db3839f968" alt="Gem Version"](https://badge.fury.io/rb/conditional_validation)
+[data:image/s3,"s3://crabby-images/2fff2/2fff244d4af380b7e840a27fbc87ad33d11ad2ea" alt="Build Status"](https://travis-ci.org/pdobb/conditional_validation)
+[data:image/s3,"s3://crabby-images/9f5e2/9f5e27b7ab9598e8a8ea4bbe8cb4655253d7ea91" alt="Test Coverage"](https://codeclimate.com/github/pdobb/conditional_validation/test_coverage)
+[data:image/s3,"s3://crabby-images/c54e6/c54e6b4fd63ed68c1b1484a58c375f09db537ad3" alt="Maintainability"](https://codeclimate.com/github/pdobb/conditional_validation/maintainability)
-Conditional Validation allows validation flags to be enabled to determine when
-certain validations should be run on a model. The idea being that, while models
-tend to have a set of core validations that should always be run, some
-validations may be specific to a certain context or state of the object. Typical
-use-case, then, is to flag a model's non-core validations to run from specific
-controller actions, while they default to not run from all others.
+ConditionalValidation simplifies adding validation flags and then querying state to determine when associated validations should be run on models. While models tend to have a set of core validations that should always be run, some validations may be specific to a certain context.
+The typical use-case for ConditionalValidation is to flag a model's non-core validations to run from specific controller actions, while they default to not run from all others.
-## Compatibility
-Tested with:
-
-* Ruby: MRI 1.9.3
-* Ruby: MRI 2.0.0 +
-* Rails: 3+
-* Rails: 4+
-
-
## Installation
Add this line to your application's Gemfile:
```ruby
-gem 'conditional_validation'
+gem "conditional_validation"
```
And then execute:
+ $ bundle
+
+Or install it yourself as:
+
+ $ gem install conditional_validation
+
+
+## Upgrading from v0.1.0
+
+### Monkey Patching Eliminated
+
+v0.1.0 automatically added ConditionalValidation::ValidationFlag to ActiveRecord::Base. Since monkey patching was never a good idea, ConditionalValidation should now be added to Models manually.
+
```ruby
-bundle
+# app/models/my_model.rb
+class MyModel
+ extend ConditionalValidation::ValidationFlag
+
+ validation_flag :test_attributes
+end
+
+my_model = MyModel.new
+
+my_model.enable_test_attributes_validation
+# => #<MyModel:0x007fd76bbecb80 @_test_attributes_validation_flag=true>
+
+my_model.validate_on_test_attributes?
+# => true
```
+Or, to use ConditionalValidation globally in a Rails app, call extend ConditionalValidation::ValidationFlag within ApplicationRecord.
+```ruby
+# app/models/application_record.rb
+class ApplicationRecord < ActiveRecord::Base
+ extend ConditionalValidation::ValidationFlag
+end
+```
+
+
+### `validation_accessor` Macro Removed
+
+Additionally, the old ConditionalValidation::ValidationAccessor module and its `validation_accessor` macro are gone. To fix: Search and replace `validation_accessor` with `validation_flag`.
+
+
+## Compatibility
+
+Tested MRI Ruby Versions:
+* 2.2.10
+* 2.3.7
+* 2.4.4
+* 2.5.1
+* edge
+
+VersionCompare has no other dependencies.
+
+
## Usage
First, define a validation flag:
```ruby
-# app/models/some_model.rb
-class SomeModel
+# app/models/my_model.rb
+class MyModel
validation_flag :<flag_name>
end
```
-Then, the following methods will be defined on SomeModel for conditional
-validation:
+The `validation_flag` macro will define the following instance methods on MyModel for conditional validation:
```ruby
-enable_<flag_name>_validation # Enables conditional validation
-disable_<flag_name>_validation # Disables conditional validation
-validate_on_<flag_name>? # Check if conditional validation is enabled
+enable_<flag_name>_validation # Enables conditional validation
+disable_<flag_name>_validation # Disables conditional validation
+validate_on_<flag_name>? # Check if conditional validation is enabled or not
```
### A "Real World" Example
```ruby
# app/models/user.rb
-User < ActiveRecord::Base
+class User < ApplicationRecord
# Initialize conditional validation on address attributes
validation_flag :address_attributes
- with_options if: :validate_on_address_attributes? do |obj|
- obj.validates :street, presence: true
- obj.validates :city, presence: true
+ with_options if: :validate_on_address_attributes? do |o|
+ o.validates :street, presence: true
+ o.validates :city, presence: true
# ...
end
end
# app/controllers/user_controller.rb
-def update
- # Enable conditional validation on address attributes
- current_user.enable_address_attributes_validation
- if current_user.save
- # Not typically needed, but disables conditional validation on address attributes
- current_user.disable_address_attributes_validation
- # ...
+class UsersController < ApplicationController
+ def update
+ # Enable conditional validation on address attributes
+ current_user.enable_address_attributes_validation
+
+ if current_user.save
+ # Not typically needed, but disables conditional validation on address attributes
+ current_user.disable_address_attributes_validation
+
+ # ...
+ end
end
end
```
+
### Method Chaining
-The enable and disable methods allow for method chaining so that multiple
-validation flags may be enabled/disabled at once:
+The `enable_<flag_name>_validation` and `disable_<flag_name>_validation` methods allow for method chaining so that multiple validation flags may be enabled/disabled at once:
```ruby
-if current_user.enable_address_attributes_validation.enable_some_other_validation.save
+if current_user.
+ enable_address_attributes_validation.
+ enable_some_other_validation.
+ save
# ...
end
```
-## Author
+## Development
-- Paul Dobbins
+After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake test` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
+
+To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
+
+
+## Contributing
+
+Bug reports and pull requests are welcome on GitHub at https://github.com/pdobb/conditional_validation.
+
+
+## License
+
+The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).