Giter VIP home page Giter VIP logo

remarkable's Introduction

This fork can be installed by adding the following to your Gemfile:

gem "remarkable_activerecord", :git => "git://github.com/sujoyg/remarkable.git"

I have used this with Rails 3.2.1 for some basic association tests.

Remarkable

You can read this file nicely formatted at the Rubyforge project page:

http://remarkable.rubyforge.org/

Description

Remarkable is a framework for rspec matchers that supports macros and I18n. It's constituted of three pieces:

  • Remarkable: the framework with helpers, DSL, I18n and rspec features;

  • Remarkable ActiveModel: a collection of matchers for ActiveModel compliant models. It currently supports all ActiveModel validations. Future plan include testing for ActiveModel API compliance and ActiveModel serialization.

  • Remarkable ActiveRecord: a collection of matchers for ActiveRecord. It supports all ActiveRecord validations, associations and some extra matchers.

  • Remarkable Rails: a collection of matchers for ActionController. It also includes MacroStubs, which is a clean DSL for stubbing your controller methods.

    NOTE: Remarkable Rails is currently not available for version 4.0.0.alpha1 We are thinking of breaking this up into Remarkable Rack, and Remarkable ActionController gems, along the lines of splitting off ActiveModel macros.

In each folder above, you can find a README more detailed description of each piece.

Why use Remarkable for Rails?

  • The only one with matchers for all ActiveRecord validations, with support to all options (except :on and the option :with in validates_format_of);

  • Matchers for all ActiveRecord associations. The only one which supports all these options:

    :through, :source, :source_type, :class_name, :foreign_key, :dependent, :join_table, :uniq, :readonly, :validate, :autosave, :counter_cache, :polymorphic

    Plus Arel scopes:

    :select, :where, :include, :group, :having, :order, :limit, :offset

    Besides in Remarkable 4.0 matchers became much smarter. Whenever :join_table or :through is given as option, it checks if the given table exists. Whenever :foreign_key or :counter_cache is given, it checks if the given column exists;

  • ActionController matchers:

    :assign_to, :filter_params, :redirect_to, :render_with_layout, :respond_with, :render_template, :route, :set_session and :set_the_flash;

  • Macro stubs: make your controllers specs easier to main, more readable and DRY;

  • Tests and more tests. We have a huge tests suite ready to run and tested in Rails 2.1.2, 2.2.2 and 2.3.2;

  • I18n and great documentation.

  • It has your style. You can choose between:

    1. it { should validate_numericality_of(:age).greater_than(18).only_integer }

    2. it { should validate_numericality_of(:age, :greater_than => 18, :only_integer => true) }

    3. should_validate_numericality_of :age, :greater_than => 18, :only_integer => true

    4. should_validate_numericality_of :age do |m| m.only_integer m.greater_than 18

      Or: m.greater_than = 18

      end

Remarkable Rails requires rspec >= 2.0.0 and rspec-rails >= 2.0.0.

Install on Rails

Install the gem:

sudo gem install remarkable_rails

This will install remarkable, remarkable_activerecord and remarkable_rails gems.

Inside Rails you need to require just this gem. If you are using ActiveRecord, it will automatically require the remarkable_activerecord gem.

Rails 3

In Rails 3, in order to rspec load properly, you have to use this configuration on your Gemfile

gem "rspec" gem "rspec-rails" gem "remarkable_activerecord"

NOTE: remarkable_rails is currently not supported.

Add the require after the rspec/rails line in your spec_helpers.rb. Although RSpec2 convention encourages you to use spec/support/, if you have Remarkable matchers in there, you will want to load that after you load Remarkable

require 'rspec/rails' require 'remarkable/active_record'

Alternatively, if you are using an ActiveModel-compliant gem, such as the newer Mongo and CouchDB gems, you can use:

require 'remarkable/active_model'

and have access to all ActiveModel matchers. Note that loading remarkable/active_record will automatically load remarkable/active_model

This is the safest way to avoid conflicts.

Please note, due to the massive refactoring in Rails 3 and RSpec 2, we are not supporting backwards compatibility with Rails 2 or RSpec 1. You will need to use the Remarkable 3.x series if you are still using Rails 2.

How to setup your machine to contribute with remarkable?

gem install bundler bundle install rake # red, green, refactor

Developers

If you are developing matchers, for example hpricot matchers, you need to install only the remarkable "core" gem:

sudo gem install remarkable

If you stumble into any problem or have doubts while building your matchers, please drop us a line. We are currently searching for people who wants to join us and provide matchers for Datamapper, Sequel, Sinatra and all other possible options. :)

Browse the documentation

Remarkable: http://remarkable.rubyforge.org/core/

Remarkable ActiveRecord: http://remarkable.rubyforge.org/activerecord/ http://remarkable.rubyforge.org/activerecord/classes/Remarkable/ActiveRecord/Matchers.html

Remarkable Rails: http://remarkable.rubyforge.org/rails/ http://remarkable.rubyforge.org/rails/classes/Remarkable/ActionController/Matchers.html

More information

Google group: http://groups.google.com/group/remarkable-core Bug tracking: http://github.com/remarkable/remarkable/issues

Contributors

http://github.com/remarkable/remarkable/contributors

LICENSE

All projects are under MIT LICENSE.

remarkable's People

Contributors

josevalim avatar carlosbrando avatar hosh avatar dcrec1 avatar joaovitor avatar lawrencepit avatar sujoyg avatar carlosantoniodasilva avatar negonicrac avatar sjmadsen avatar wildchild avatar vesan avatar ragaskar avatar chrislloyd avatar codebeige avatar szimek avatar yolk avatar myronmarston avatar jonathantron avatar jqr avatar dmgk avatar andersondias avatar

Watchers

 avatar James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo 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.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.