diff --git a/.travis.yml b/.travis.yml index cb29bb0..e40f453 100644 --- a/.travis.yml +++ b/.travis.yml @@ -14,13 +14,10 @@ services: - redis-server gemfile: - - gemfiles/rails_3.2_stable.gemfile + - gemfiles/rails_3.2.gemfile - gemfiles/rails_4.0.gemfile - - gemfiles/rails_4.0_mongo_mapper.gemfile - gemfiles/rails_4.2.gemfile - - gemfiles/rails_4.2_mongoid_4.gemfile - gemfiles/rails_4.2_mongoid_5.gemfile - - gemfiles/rails_4.2_mongo_mapper.gemfile - gemfiles/rails_5.0.gemfile before_script: @@ -30,28 +27,21 @@ before_script: - mongod --version matrix: - allow_failures: - - rvm: jruby-9.0.5.0 - gemfile: gemfiles/rails_5.0.gemfile - - rvm: rbx-2.5.8 - gemfile: gemfiles/rails_5.0.gemfile exclude: - - rvm: 1.9.3 - gemfile: gemfiles/rails_4.2_mongoid_4.gemfile - rvm: 1.9.3 gemfile: gemfiles/rails_4.2_mongoid_5.gemfile - rvm: 1.9.3 gemfile: gemfiles/rails_5.0.gemfile - - rvm: 2.2.5 - gemfile: gemfiles/rails_3.2_stable.gemfile - - rvm: 2.3.1 - gemfile: gemfiles/rails_3.2_stable.gemfile - - rvm: jruby-1.7 - gemfile: gemfiles/rails_4.2_mongoid_4.gemfile + - rvm: 2.2.6 + gemfile: gemfiles/rails_3.2.gemfile + - rvm: 2.3.3 + gemfile: gemfiles/rails_3.2.gemfile - rvm: jruby-1.7 gemfile: gemfiles/rails_4.2_mongoid_5.gemfile - rvm: jruby-1.7 gemfile: gemfiles/rails_5.0.gemfile + - rvm: jruby-9.0.5.0 + gemfile: gemfiles/rails_5.0.gemfile notifications: slack: diff --git a/Appraisals b/Appraisals index 2b32e3d..fea49a6 100644 --- a/Appraisals +++ b/Appraisals @@ -1,23 +1,12 @@ -appraise 'rails_3.2_stable' do - gem 'sqlite3', :platforms => :ruby - gem 'rubysl', :platforms => :rbx - gem 'rubinius-developer_tools', :platforms => :rbx - gem 'jruby-openssl', :platforms => :jruby - gem 'activerecord-jdbcsqlite3-adapter', :platforms => :jruby - gem 'rails', :github => 'rails/rails', :branch => '3-2-stable' +appraise 'rails_3.2' do + gem 'rails', '~>3.2.22' gem 'mongoid', '~>3.1' gem 'sequel' - gem 'mongo_mapper', '~>0.13' gem 'bson_ext', :platforms => :ruby gem 'test-unit', '~> 3.0' end appraise 'rails_4.0' do - gem 'sqlite3', :platforms => :ruby - gem 'rubysl', :platforms => :rbx - gem 'rubinius-developer_tools', :platforms => :rbx - gem 'jruby-openssl', :platforms => :jruby - gem 'activerecord-jdbcsqlite3-adapter', :platforms => :jruby gem 'mime-types', '~> 2', :platforms => [:ruby_19, :jruby] gem 'rails', '4.0.13' gem 'mongoid', '~>4.0' @@ -27,87 +16,25 @@ appraise 'rails_4.0' do gem 'redis-objects' end -appraise 'rails_4.0_mongo_mapper' do - gem 'sqlite3', :platforms => :ruby - gem 'rubysl', :platforms => :rbx - gem 'rubinius-developer_tools', :platforms => :rbx - gem 'jruby-openssl', :platforms => :jruby - gem 'activerecord-jdbcsqlite3-adapter', :platforms => :jruby - gem 'mime-types', '~> 2', :platforms => [:ruby_19, :jruby] - gem 'rails', '4.0.13' - gem 'sequel' - gem 'mongo_mapper', '~>0.13.1' - gem 'bson_ext', :platforms => :ruby - gem 'dynamoid', '~> 1', :platforms => :ruby - gem 'aws-sdk', '~>2', :platforms => :ruby -end - appraise 'rails_4.2' do - gem 'sqlite3', :platforms => :ruby - gem 'rubysl', :platforms => :rbx - gem 'rubinius-developer_tools', :platforms => :rbx - gem 'jruby-openssl', :platforms => :jruby - gem 'activerecord-jdbcsqlite3-adapter', :platforms => :jruby + gem 'nokogiri', '1.6.8.1', :platforms => [:ruby_19] gem 'mime-types', '~> 2', :platforms => [:ruby_19, :jruby] gem 'rails', '4.2.5' - gem 'sequel' - gem 'dynamoid', '~> 1', :platforms => :ruby - gem 'aws-sdk', '~>2', :platforms => :ruby -end - -appraise 'rails_4.2_mongoid_4' do - gem 'sqlite3', :platforms => :ruby - gem 'rubysl', :platforms => :rbx - gem 'rubinius-developer_tools', :platforms => :rbx - gem 'jruby-openssl', :platforms => :jruby - gem 'activerecord-jdbcsqlite3-adapter', :platforms => :jruby - gem 'mime-types', '~> 2', :platforms => [:ruby_19, :jruby] - gem 'rails', '4.2.5' - gem 'mongoid', '~>4.0', :platforms => [:ruby_22, :ruby_23, :jruby] + gem 'mongoid', '~>4.0' gem 'sequel' gem 'dynamoid', '~> 1', :platforms => :ruby gem 'aws-sdk', '~>2', :platforms => :ruby end appraise 'rails_4.2_mongoid_5' do - gem 'sqlite3', :platforms => :ruby - gem 'rubysl', :platforms => :rbx - gem 'rubinius-developer_tools', :platforms => :rbx - gem 'jruby-openssl', :platforms => :jruby - gem 'activerecord-jdbcsqlite3-adapter', :platforms => :jruby gem 'mime-types', '~> 2', :platforms => [:ruby_19, :jruby] gem 'rails', '4.2.5' - gem 'mongoid', '~>5.0', :platforms => [:ruby_22, :ruby_23, :jruby] - gem 'sequel' - gem 'dynamoid', '~> 1', :platforms => :ruby - gem 'aws-sdk', '~>2', :platforms => :ruby -end - -appraise 'rails_4.2_mongo_mapper' do - gem 'sqlite3', :platforms => :ruby - gem 'rubysl', :platforms => :rbx - gem 'rubinius-developer_tools', :platforms => :rbx - gem 'jruby-openssl', :platforms => :jruby - gem 'activerecord-jdbcsqlite3-adapter', :platforms => :jruby - gem 'mime-types', '~> 2', :platforms => [:ruby_19, :jruby] - gem 'rails', '4.2.5' - gem 'sequel' - gem 'mongo_mapper' - gem 'bson_ext', :platforms => :ruby - gem 'dynamoid', '~> 1', :platforms => :ruby - gem 'aws-sdk', '~>2', :platforms => :ruby - gem 'redis-objects' + gem 'mongoid', '~>5.0' end appraise 'rails_5.0' do - gem 'sqlite3', :platforms => :ruby - gem 'rubysl', :platforms => :rbx - gem 'rubinius-developer_tools', :platforms => :rbx - gem 'jruby-openssl', :platforms => :jruby - gem 'activerecord-jdbcsqlite3-adapter', :platforms => :jruby gem 'rails', '5.0.0' - # mongoid is not yet Rails 5 compatible - # gem 'mongoid', '~>4.0', :platforms => [:ruby_22, :ruby_23, :jruby] + gem 'mongoid', '~>6.0' gem 'sequel' # dynamoid is not yet Rails 5 compatible diff --git a/Gemfile b/Gemfile index b2b6791..61d96fc 100644 --- a/Gemfile +++ b/Gemfile @@ -2,5 +2,6 @@ source "https://rubygems.org" gemspec -gem "rails", "4.2.7.1" -gem "sqlite3" +gem 'sqlite3', :platforms => :ruby +gem 'activerecord-jdbcsqlite3-adapter', :platforms => :jruby +gem 'rails', '5.0.0' diff --git a/README.md b/README.md index 2953217..33b9cc2 100644 --- a/README.md +++ b/README.md @@ -10,7 +10,7 @@ This package contains AASM, a library for adding finite state machines to Ruby c AASM started as the *acts_as_state_machine* plugin but has evolved into a more generic library that no longer targets only ActiveRecord models. It currently provides adapters for [ActiveRecord](http://api.rubyonrails.org/classes/ActiveRecord/Base.html), -[Mongoid](http://mongoid.org/), and [Mongomapper](http://mongomapper.com/) but it can be used for any Ruby class, no matter what +and [Mongoid](http://mongoid.org/) but it can be used for any Ruby class, no matter what parent class it has (if any). ## Upgrade from version 3 to 4 @@ -677,7 +677,7 @@ to ```false```. ### Sequel -AASM also supports [Sequel](http://sequel.jeremyevans.net/) besides _ActiveRecord_, _Mongoid_, and _MongoMapper_. +AASM also supports [Sequel](http://sequel.jeremyevans.net/) besides _ActiveRecord_, and _Mongoid_. ```ruby class Job < Sequel::Model @@ -713,23 +713,6 @@ class Job end ``` -### MongoMapper - -AASM also supports persistence to Mongodb if you're using MongoMapper. Make sure -to include MongoMapper::Document before you include AASM. - -```ruby -class Job - include MongoMapper::Document - include AASM - - key :aasm_state, Symbol - aasm do - ... - end -end -``` - ### Redis AASM also supports persistence in Redis. diff --git a/TESTING.md b/TESTING.md index a8fe27a..e942a87 100644 --- a/TESTING.md +++ b/TESTING.md @@ -18,8 +18,8 @@ Or for specific one: Or for one particular test file - appraisal rails_4.2_mongo_mapper rspec spec/unit/persistence/mongo_mapper_persistence_multiple_spec.rb + appraisal rails_4.2_mongoid_5 rspec spec/unit/persistence/mongoid_persistence_multiple_spec.rb Or down to one test case - appraisal rails_4.2_mongo_mapper rspec spec/unit/persistence/mongo_mapper_persistence_multiple_spec.rb:92 \ No newline at end of file + appraisal rails_4.2_mongoid_5 rspec spec/unit/persistence/mongoid_persistence_multiple_spec.rb:92 diff --git a/gemfiles/rails_3.2_stable.gemfile b/gemfiles/rails_3.2.gemfile similarity index 57% rename from gemfiles/rails_3.2_stable.gemfile rename to gemfiles/rails_3.2.gemfile index c2afda1..93b3742 100644 --- a/gemfiles/rails_3.2_stable.gemfile +++ b/gemfiles/rails_3.2.gemfile @@ -3,14 +3,10 @@ source "https://rubygems.org" gem "sqlite3", :platforms => :ruby -gem "rubysl", :platforms => :rbx -gem "rubinius-developer_tools", :platforms => :rbx -gem "jruby-openssl", :platforms => :jruby gem "activerecord-jdbcsqlite3-adapter", :platforms => :jruby -gem "rails", :github => "rails/rails", :branch => "3-2-stable" +gem "rails", "~>3.2.22" gem "mongoid", "~>3.1" gem "sequel" -gem "mongo_mapper", "~>0.13" gem "bson_ext", :platforms => :ruby gem "test-unit", "~> 3.0" diff --git a/gemfiles/rails_4.0.gemfile b/gemfiles/rails_4.0.gemfile index 6609c3a..c429e20 100644 --- a/gemfiles/rails_4.0.gemfile +++ b/gemfiles/rails_4.0.gemfile @@ -3,12 +3,9 @@ source "https://rubygems.org" gem "sqlite3", :platforms => :ruby -gem "rubysl", :platforms => :rbx -gem "rubinius-developer_tools", :platforms => :rbx -gem "jruby-openssl", :platforms => :jruby gem "activerecord-jdbcsqlite3-adapter", :platforms => :jruby -gem "mime-types", "~> 2", :platforms => [:ruby_19, :jruby] gem "rails", "4.0.13" +gem "mime-types", "~> 2", :platforms => [:ruby_19, :jruby] gem "mongoid", "~>4.0" gem "sequel" gem "dynamoid", "~> 1", :platforms => :ruby diff --git a/gemfiles/rails_4.0_mongo_mapper.gemfile b/gemfiles/rails_4.0_mongo_mapper.gemfile deleted file mode 100644 index acb4167..0000000 --- a/gemfiles/rails_4.0_mongo_mapper.gemfile +++ /dev/null @@ -1,18 +0,0 @@ -# This file was generated by Appraisal - -source "https://rubygems.org" - -gem "sqlite3", :platforms => :ruby -gem "rubysl", :platforms => :rbx -gem "rubinius-developer_tools", :platforms => :rbx -gem "jruby-openssl", :platforms => :jruby -gem "activerecord-jdbcsqlite3-adapter", :platforms => :jruby -gem "mime-types", "~> 2", :platforms => [:ruby_19, :jruby] -gem "rails", "4.0.13" -gem "sequel" -gem "mongo_mapper", "~>0.13.1" -gem "bson_ext", :platforms => :ruby -gem "dynamoid", "~> 1", :platforms => :ruby -gem "aws-sdk", "~>2", :platforms => :ruby - -gemspec :path => "../" diff --git a/gemfiles/rails_4.2.gemfile b/gemfiles/rails_4.2.gemfile index 3f4955e..05363a7 100644 --- a/gemfiles/rails_4.2.gemfile +++ b/gemfiles/rails_4.2.gemfile @@ -3,17 +3,13 @@ source "https://rubygems.org" gem "sqlite3", :platforms => :ruby -gem "nokogiri", "1.6.8.1", :platforms => [:ruby_19] -gem "rubysl", :platforms => :rbx -gem "rubinius-developer_tools", :platforms => :rbx -gem "jruby-openssl", :platforms => :jruby gem "activerecord-jdbcsqlite3-adapter", :platforms => :jruby -gem "mime-types", "~> 2", :platforms => [:ruby_19, :jruby] gem "rails", "4.2.5" +gem "nokogiri", "1.6.8.1", :platforms => [:ruby_19] +gem "mime-types", "~> 2", :platforms => [:ruby_19, :jruby] +gem "mongoid", "~>4.0" gem "sequel" -if ENV['CI'] = 'true' - gem "dynamoid", "~> 1", :platforms => :ruby -end +gem "dynamoid", "~> 1", :platforms => :ruby gem "aws-sdk", "~>2", :platforms => :ruby gemspec :path => "../" diff --git a/gemfiles/rails_4.2_mongo_mapper.gemfile b/gemfiles/rails_4.2_mongo_mapper.gemfile deleted file mode 100644 index e8641ff..0000000 --- a/gemfiles/rails_4.2_mongo_mapper.gemfile +++ /dev/null @@ -1,20 +0,0 @@ -# This file was generated by Appraisal - -source "https://rubygems.org" - -gem "sqlite3", :platforms => :ruby -gem "nokogiri", "1.6.8.1", :platforms => [:ruby_19] -gem "rubysl", :platforms => :rbx -gem "rubinius-developer_tools", :platforms => :rbx -gem "jruby-openssl", :platforms => :jruby -gem "activerecord-jdbcsqlite3-adapter", :platforms => :jruby -gem "mime-types", "~> 2", :platforms => [:ruby_19, :jruby] -gem "rails", "4.2.5" -gem "sequel" -gem "mongo_mapper" -gem "bson_ext", :platforms => :ruby -gem "dynamoid", "~> 1", :platforms => :ruby -gem "aws-sdk", "~>2", :platforms => :ruby -gem "redis-objects" - -gemspec :path => "../" diff --git a/gemfiles/rails_4.2_mongoid_4.gemfile b/gemfiles/rails_4.2_mongoid_4.gemfile deleted file mode 100644 index 38daf98..0000000 --- a/gemfiles/rails_4.2_mongoid_4.gemfile +++ /dev/null @@ -1,17 +0,0 @@ -# This file was generated by Appraisal - -source "https://rubygems.org" - -gem "sqlite3", :platforms => :ruby -gem "rubysl", :platforms => :rbx -gem "rubinius-developer_tools", :platforms => :rbx -gem "jruby-openssl", :platforms => :jruby -gem "activerecord-jdbcsqlite3-adapter", :platforms => :jruby -gem "mime-types", "~> 2", :platforms => [:ruby_19, :jruby] -gem "rails", "4.2.5" -gem "mongoid", "~>4.0", :platforms => [:ruby_22, :ruby_23, :jruby] -gem "sequel" -gem "dynamoid", "~> 1", :platforms => :ruby -gem "aws-sdk", "~>2", :platforms => :ruby - -gemspec :path => "../" diff --git a/gemfiles/rails_4.2_mongoid_5.gemfile b/gemfiles/rails_4.2_mongoid_5.gemfile index eaadcce..d33fe94 100644 --- a/gemfiles/rails_4.2_mongoid_5.gemfile +++ b/gemfiles/rails_4.2_mongoid_5.gemfile @@ -3,15 +3,9 @@ source "https://rubygems.org" gem "sqlite3", :platforms => :ruby -gem "rubysl", :platforms => :rbx -gem "rubinius-developer_tools", :platforms => :rbx -gem "jruby-openssl", :platforms => :jruby gem "activerecord-jdbcsqlite3-adapter", :platforms => :jruby -gem "mime-types", "~> 2", :platforms => [:ruby_19, :jruby] gem "rails", "4.2.5" -gem "mongoid", "~>5.0", :platforms => [:ruby_22, :ruby_23, :jruby] -gem "sequel" -gem "dynamoid", "~> 1", :platforms => :ruby -gem "aws-sdk", "~>2", :platforms => :ruby +gem "mime-types", "~> 2", :platforms => [:ruby_19, :jruby] +gem "mongoid", "~>5.0" gemspec :path => "../" diff --git a/gemfiles/rails_5.0.gemfile b/gemfiles/rails_5.0.gemfile index 9d1b434..3683eb7 100644 --- a/gemfiles/rails_5.0.gemfile +++ b/gemfiles/rails_5.0.gemfile @@ -3,11 +3,9 @@ source "https://rubygems.org" gem "sqlite3", :platforms => :ruby -gem "rubysl", :platforms => :rbx -gem "rubinius-developer_tools", :platforms => :rbx -gem "jruby-openssl", :platforms => :jruby gem "activerecord-jdbcsqlite3-adapter", :platforms => :jruby gem "rails", "5.0.0" +gem "mongoid", "~>6.0" gem "sequel" gem "aws-sdk", "~>2", :platforms => :ruby diff --git a/lib/aasm/persistence.rb b/lib/aasm/persistence.rb index 256c933..4e549eb 100644 --- a/lib/aasm/persistence.rb +++ b/lib/aasm/persistence.rb @@ -12,9 +12,6 @@ module AASM elsif hierarchy.include?("Mongoid::Document") require_persistence :mongoid include_persistence base, :mongoid - elsif hierarchy.include?("MongoMapper::Document") - require_persistence :mongo_mapper - include_persistence base, :mongo_mapper elsif hierarchy.include?("Sequel::Model") require_persistence :sequel include_persistence base, :sequel diff --git a/lib/aasm/persistence/mongo_mapper_persistence.rb b/lib/aasm/persistence/mongo_mapper_persistence.rb deleted file mode 100644 index edf11ed..0000000 --- a/lib/aasm/persistence/mongo_mapper_persistence.rb +++ /dev/null @@ -1,163 +0,0 @@ -module AASM - module Persistence - module MongoMapperPersistence - # This method: - # - # * extends the model with ClassMethods - # * includes InstanceMethods - # - # Adds - # - # before_validation :aasm_ensure_initial_state, :on => :create - # - # As a result, it doesn't matter when you define your methods - the following 2 are equivalent - # - # class Foo - # include MongoMapper::Document - # def aasm_write_state(state) - # "bar" - # end - # include AASM - # end - # - # class Foo < ActiveRecord::Base - # include MongoMapper::Document - # include AASM - # def aasm_write_state(state) - # "bar" - # end - # end - # - def self.included(base) - base.send(:include, AASM::Persistence::Base) - base.send(:include, AASM::Persistence::MongoMapperPersistence::InstanceMethods) - base.extend AASM::Persistence::MongoMapperPersistence::ClassMethods - - base.before_create :aasm_ensure_initial_state - - # ensure state is in the list of states - base.validate :aasm_validate_states - end - - module ClassMethods - def aasm_create_scope(state_machine_name, scope_name) - conditions = { aasm(state_machine_name).attribute_name.to_sym => scope_name.to_s } - scope(scope_name, lambda { where(conditions) }) - end - end - - module InstanceMethods - - # Writes state to the state column and persists it to the database - # - # foo = Foo.find(1) - # foo.aasm.current_state # => :opened - # foo.close! - # foo.aasm.current_state # => :closed - # Foo.find(1).aasm.current_state # => :closed - # - # NOTE: intended to be called from an event - def aasm_write_state(state, name=:default) - old_value = read_attribute(self.class.aasm(name).attribute_name) - write_attribute(self.class.aasm(name).attribute_name, state) - - success = if aasm_skipping_validations(name) - value = aasm_raw_attribute_value(state, name) - self.class.where(self.class.primary_key => self.id).update_all(self.class.aasm(name).attribute_name => value) == 1 - else - self.save - end - unless success - write_attribute(self.class.aasm(name).attribute_name, old_value) - return false - end - - true - end - - # Writes state to the state column, but does not persist it to the database - # - # foo = Foo.find(1) - # foo.aasm.current_state # => :opened - # foo.close - # foo.aasm.current_state # => :closed - # Foo.find(1).aasm.current_state # => :opened - # foo.save - # foo.aasm.current_state # => :closed - # Foo.find(1).aasm.current_state # => :closed - # - # NOTE: intended to be called from an event - def aasm_write_state_without_persistence(state, name=:default) - aasm_write_attribute(state, name) - end - - private - def aasm_enum(name=:default) - case AASM::StateMachineStore.fetch(self.class, true).machine(name).config.enum - when false then nil - when true then aasm_guess_enum_method(name) - when nil then aasm_guess_enum_method(name) if aasm_column_looks_like_enum(name) - else AASM::StateMachineStore.fetch(self.class, true).machine(name).config.enum - end - end - - def aasm_column_looks_like_enum(name) - self.class.keys[self.class.aasm(name).attribute_name.to_s].type == Integer - end - - def aasm_guess_enum_method(name) - self.class.aasm(name).attribute_name.to_s.pluralize.to_sym - end - - def aasm_skipping_validations(state_machine_name) - AASM::StateMachineStore.fetch(self.class, true).machine(state_machine_name).config.skip_validation_on_save - end - - def aasm_write_attribute(state, name=:default) - write_attribute self.class.aasm(name).attribute_name, aasm_raw_attribute_value(state, name) - end - - def aasm_raw_attribute_value(state, name=:default) - if aasm_enum(name) - self.class.send(aasm_enum(name))[state] - else - state.to_s - end - end - - # Ensures that if the aasm_state column is nil and the record is new - # that the initial state gets populated before validation on create - # - # foo = Foo.new - # foo.aasm_state # => nil - # foo.valid? - # foo.aasm_state # => "open" (where :open is the initial state) - # - # - # foo = Foo.find(:first) - # foo.aasm_state # => 1 - # foo.aasm_state = nil - # foo.valid? - # foo.aasm_state # => nil - # - def aasm_ensure_initial_state - AASM::StateMachineStore.fetch(self.class, true).machine_names.each do |state_machine_name| - send("#{self.class.aasm(state_machine_name).attribute_name}=", aasm(state_machine_name).enter_initial_state.to_s) if send(self.class.aasm(state_machine_name).attribute_name).blank? - end - end - - def aasm_validate_states - AASM::StateMachineStore.fetch(self.class, true).machine_names.each do |state_machine_name| - send("#{self.class.aasm(state_machine_name).attribute_name}=", aasm(state_machine_name).enter_initial_state.to_s) if send(self.class.aasm(state_machine_name).attribute_name).blank? - unless AASM::StateMachineStore.fetch(self.class, true).machine(state_machine_name).config.skip_validation_on_save - if aasm(state_machine_name).current_state && !aasm(state_machine_name).states.include?(aasm(state_machine_name).current_state) - self.errors.add(AASM::StateMachineStore.fetch(self.class, true).machine(state_machine_name).config.column , "is invalid") - end - end - end - end - end # InstanceMethods - - end - end # Persistence -end # AASM diff --git a/lib/motion-aasm.rb b/lib/motion-aasm.rb index 8967695..d8c9b32 100644 --- a/lib/motion-aasm.rb +++ b/lib/motion-aasm.rb @@ -13,7 +13,6 @@ exclude_files = [ 'aasm/rspec.*', 'aasm/persistence/active_record_persistence.rb', 'aasm/persistence/dynamoid_persistence.rb', - 'aasm/persistence/mongo_mapper_persistence.rb', 'aasm/persistence/mongoid_persistence.rb', 'aasm/persistence/sequel_persistence.rb', 'aasm/persistence/redis_persistence.rb' diff --git a/spec/models/mongo_mapper/complex_mongo_mapper_example.rb b/spec/models/mongo_mapper/complex_mongo_mapper_example.rb deleted file mode 100644 index efb1e5b..0000000 --- a/spec/models/mongo_mapper/complex_mongo_mapper_example.rb +++ /dev/null @@ -1,37 +0,0 @@ -class ComplexMongoMapperExample - include MongoMapper::Document - include AASM - - key :left, String - key :right, String - - aasm :left, :column => 'left' do - state :one, :initial => true - state :two - state :three - - event :increment do - transitions :from => :one, :to => :two - transitions :from => :two, :to => :three - end - event :reset do - transitions :from => :three, :to => :one - end - end - - aasm :right, :column => 'right' do - state :alpha, :initial => true - state :beta - state :gamma - - event :level_up do - transitions :from => :alpha, :to => :beta - transitions :from => :beta, :to => :gamma - end - event :level_down do - transitions :from => :gamma, :to => :beta - transitions :from => :beta, :to => :alpha - end - end - -end diff --git a/spec/models/mongo_mapper/no_scope_mongo_mapper.rb b/spec/models/mongo_mapper/no_scope_mongo_mapper.rb deleted file mode 100644 index d79d3f8..0000000 --- a/spec/models/mongo_mapper/no_scope_mongo_mapper.rb +++ /dev/null @@ -1,21 +0,0 @@ -class NoScopeMongoMapper - include MongoMapper::Document - include AASM - - key :status, String - - aasm :create_scopes => false, :column => :status do - state :ignored_scope - end -end - -class NoScopeMongoMapperMultiple - include MongoMapper::Document - include AASM - - key :status, String - - aasm :left, :create_scopes => false, :column => :status do - state :ignored_scope - end -end diff --git a/spec/models/mongo_mapper/simple_mongo_mapper.rb b/spec/models/mongo_mapper/simple_mongo_mapper.rb deleted file mode 100644 index 7d11437..0000000 --- a/spec/models/mongo_mapper/simple_mongo_mapper.rb +++ /dev/null @@ -1,23 +0,0 @@ -class SimpleMongoMapper - include MongoMapper::Document - include AASM - - key :status, String - - aasm column: :status do - state :unknown_scope, :another_unknown_scope - state :next - end -end - -class SimpleMongoMapperMultiple - include MongoMapper::Document - include AASM - - key :status, String - - aasm :left, column: :status do - state :unknown_scope, :another_unknown_scope - state :next - end -end diff --git a/spec/models/mongo_mapper/simple_new_dsl_mongo_mapper.rb b/spec/models/mongo_mapper/simple_new_dsl_mongo_mapper.rb deleted file mode 100644 index 87bd7b5..0000000 --- a/spec/models/mongo_mapper/simple_new_dsl_mongo_mapper.rb +++ /dev/null @@ -1,25 +0,0 @@ -class SimpleNewDslMongoMapper - include MongoMapper::Document - include AASM - - key :status, String - - aasm :column => :status - aasm do - state :unknown_scope - state :next - end -end - -class SimpleNewDslMongoMapperMultiple - include MongoMapper::Document - include AASM - - key :status, String - - aasm :left, :column => :status - aasm :left do - state :unknown_scope - state :next - end -end diff --git a/spec/spec_helpers/mongo_mapper.rb b/spec/spec_helpers/mongo_mapper.rb deleted file mode 100644 index 176c35e..0000000 --- a/spec/spec_helpers/mongo_mapper.rb +++ /dev/null @@ -1,7 +0,0 @@ -# encoding: utf-8 -begin - require 'mongo_mapper' - puts "mongo_mapper gem found, running MongoMapper specs \e[32m#{'✔'}\e[0m" -rescue LoadError - puts "mongo_mapper gem not found, not running MongoMapper specs \e[31m#{'✖'}\e[0m" -end diff --git a/spec/unit/persistence/mongo_mapper_persistence_multiple_spec.rb b/spec/unit/persistence/mongo_mapper_persistence_multiple_spec.rb deleted file mode 100644 index 6124426..0000000 --- a/spec/unit/persistence/mongo_mapper_persistence_multiple_spec.rb +++ /dev/null @@ -1,144 +0,0 @@ -require 'spec_helper' - -if defined?(MongoMapper) - describe 'mongo_mapper' do - - Dir[File.dirname(__FILE__) + "/../../models/mongo_mapper/*.rb"].sort.each do |f| - require File.expand_path(f) - end - - before(:all) do - config = { - 'test' => { - 'database' => "mongo_mapper_#{Process.pid}" - } - } - - MongoMapper.setup(config, 'test') #, :logger => Logger.new(STDERR)) - end - - after do - # Clear Out all non-system Mongo collections between tests - MongoMapper.database.collections.each do |collection| - collection.drop unless collection.capped? || (collection.name =~ /\Asystem/) - end - end - - describe "named scopes with the old DSL" do - - context "Does not already respond_to? the scope name" do - it "should add a scope for each state" do - expect(SimpleMongoMapperMultiple).to respond_to(:unknown_scope) - expect(SimpleMongoMapperMultiple).to respond_to(:another_unknown_scope) - - expect(SimpleMongoMapperMultiple.unknown_scope.class).to eq(MongoMapper::Plugins::Querying::DecoratedPluckyQuery) - expect(SimpleMongoMapperMultiple.another_unknown_scope.class).to eq(MongoMapper::Plugins::Querying::DecoratedPluckyQuery) - #expect(SimpleMongoMapperMultiple.unknown_scope.is_a?(ActiveRecord::Relation)).to be_truthy - end - end - - context "Already respond_to? the scope name" do - it "should not add a scope" do - expect(SimpleMongoMapperMultiple).to respond_to(:next) - expect(SimpleMongoMapperMultiple.new.class).to eq(SimpleMongoMapperMultiple) - end - end - - end - - describe "named scopes with the new DSL" do - - context "Does not already respond_to? the scope name" do - it "should add a scope" do - expect(SimpleNewDslMongoMapperMultiple).to respond_to(:unknown_scope) - expect(SimpleNewDslMongoMapperMultiple.unknown_scope.class).to eq(MongoMapper::Plugins::Querying::DecoratedPluckyQuery) - end - end - - context "Already respond_to? the scope name" do - it "should not add a scope" do - expect(SimpleNewDslMongoMapperMultiple).to respond_to(:next) - expect(SimpleNewDslMongoMapperMultiple.new.class).to eq(SimpleNewDslMongoMapperMultiple) - end - end - - it "does not create scopes if requested" do - expect(NoScopeMongoMapperMultiple).not_to respond_to(:ignored_scope) - end - - end - - describe "instance methods" do - - let(:simple) {SimpleNewDslMongoMapperMultiple.new} - - it "should call aasm_ensure_initial_state on validation before create" do - expect(SimpleNewDslMongoMapperMultiple.aasm(:left).initial_state).to eq(:unknown_scope) - expect(SimpleNewDslMongoMapperMultiple.aasm(:left).attribute_name).to eq(:status) - expect(simple.status).to eq(nil) - simple.valid? - expect(simple.status).to eq('unknown_scope') - end - - it "should call aasm_ensure_initial_state before create, even if skipping validations" do - expect(simple.status).to eq(nil) - simple.save(:validate => false) - expect(simple.status).to eq('unknown_scope') - end - end - - describe "complex example" do - it "works" do - record = ComplexMongoMapperExample.new - expect(record.aasm(:left).current_state).to eql :one - expect(record.left).to be_nil - expect(record.aasm(:right).current_state).to eql :alpha - expect(record.right).to be_nil - - record.save! - expect_aasm_states record, :one, :alpha - record.reload - expect_aasm_states record, :one, :alpha - - record.increment! - expect_aasm_states record, :two, :alpha - record.reload - expect_aasm_states record, :two, :alpha - - record.level_up! - expect_aasm_states record, :two, :beta - record.reload - expect_aasm_states record, :two, :beta - - record.increment! - expect { record.increment! }.to raise_error(AASM::InvalidTransition) - expect_aasm_states record, :three, :beta - record.reload - expect_aasm_states record, :three, :beta - - record.level_up! - expect_aasm_states record, :three, :gamma - record.reload - expect_aasm_states record, :three, :gamma - - record.level_down # without saving - expect_aasm_states record, :three, :beta - record.reload - expect_aasm_states record, :three, :gamma - - record.level_down # without saving - expect_aasm_states record, :three, :beta - record.reset! - expect_aasm_states record, :one, :beta - end - - def expect_aasm_states(record, left_state, right_state) - expect(record.aasm(:left).current_state).to eql left_state.to_sym - expect(record.left).to eql left_state.to_s - expect(record.aasm(:right).current_state).to eql right_state.to_sym - expect(record.right).to eql right_state.to_s - end - end - - end -end diff --git a/spec/unit/persistence/mongo_mapper_persistence_spec.rb b/spec/unit/persistence/mongo_mapper_persistence_spec.rb deleted file mode 100644 index 6ba7d80..0000000 --- a/spec/unit/persistence/mongo_mapper_persistence_spec.rb +++ /dev/null @@ -1,91 +0,0 @@ -require 'spec_helper' - -if defined?(MongoMapper) - describe 'mongo_mapper' do - - Dir[File.dirname(__FILE__) + "/../../models/mongo_mapper/*.rb"].sort.each do |f| - require File.expand_path(f) - end - - before(:all) do - config = { - 'test' => { - 'database' => "mongo_mapper_#{Process.pid}" - } - } - - MongoMapper.setup(config, 'test') #, :logger => Logger.new(STDERR)) - end - - after do - # Clear Out all non-system Mongo collections between tests - MongoMapper.database.collections.each do |collection| - collection.drop unless collection.capped? || (collection.name =~ /\Asystem/) - end - end - - describe "named scopes with the old DSL" do - - context "Does not already respond_to? the scope name" do - it "should add a scope for each state" do - expect(SimpleMongoMapper).to respond_to(:unknown_scope) - expect(SimpleMongoMapper).to respond_to(:another_unknown_scope) - - expect(SimpleMongoMapper.unknown_scope.class).to eq(MongoMapper::Plugins::Querying::DecoratedPluckyQuery) - expect(SimpleMongoMapper.another_unknown_scope.class).to eq(MongoMapper::Plugins::Querying::DecoratedPluckyQuery) - #expect(SimpleMongoMapper.unknown_scope.is_a?(ActiveRecord::Relation)).to be_truthy - end - end - - context "Already respond_to? the scope name" do - it "should not add a scope" do - expect(SimpleMongoMapper).to respond_to(:next) - expect(SimpleMongoMapper.new.class).to eq(SimpleMongoMapper) - end - end - - end - - describe "named scopes with the new DSL" do - - context "Does not already respond_to? the scope name" do - it "should add a scope" do - expect(SimpleNewDslMongoMapper).to respond_to(:unknown_scope) - expect(SimpleNewDslMongoMapper.unknown_scope.class).to eq(MongoMapper::Plugins::Querying::DecoratedPluckyQuery) - end - end - - context "Already respond_to? the scope name" do - it "should not add a scope" do - expect(SimpleNewDslMongoMapper).to respond_to(:next) - expect(SimpleNewDslMongoMapper.new.class).to eq(SimpleNewDslMongoMapper) - end - end - - it "does not create scopes if requested" do - expect(NoScopeMongoMapper).not_to respond_to(:ignored_scope) - end - - end - - describe "instance methods" do - - let(:simple) {SimpleNewDslMongoMapper.new} - - it "should call aasm_ensure_initial_state on validation before create" do - expect(SimpleNewDslMongoMapper.aasm.initial_state).to eq(:unknown_scope) - expect(SimpleNewDslMongoMapper.aasm.attribute_name).to eq(:status) - expect(simple.status).to eq(nil) - simple.valid? - expect(simple.status).to eq('unknown_scope') - end - - it "should call aasm_ensure_initial_state before create, even if skipping validations" do - expect(simple.status).to eq(nil) - simple.save(:validate => false) - expect(simple.status).to eq('unknown_scope') - end - end - - end -end