mirror of
https://github.com/aasm/aasm
synced 2023-03-27 23:22:41 -04:00
39 lines
1.4 KiB
Ruby
39 lines
1.4 KiB
Ruby
require 'spec_helper'
|
|
|
|
describe 'subclassing with multiple state machines' do
|
|
|
|
it 'should have the parent states' do
|
|
SuperClassMultiple.aasm(:left).states.each do |state|
|
|
expect(SubClassWithMoreStatesMultiple.aasm(:left).states).to include(state)
|
|
end
|
|
expect(SubClassMultiple.aasm(:left).states).to eq(SuperClassMultiple.aasm(:left).states)
|
|
|
|
SuperClassMultiple.aasm(:right).states.each do |state|
|
|
expect(SubClassWithMoreStatesMultiple.aasm(:right).states).to include(state)
|
|
end
|
|
expect(SubClassMultiple.aasm(:right).states).to eq(SuperClassMultiple.aasm(:right).states)
|
|
end
|
|
|
|
it 'should not add the child states to the parent machine' do
|
|
expect(SuperClassMultiple.aasm(:left).states).not_to include(:foo)
|
|
expect(SuperClassMultiple.aasm(:right).states).not_to include(:archived)
|
|
end
|
|
|
|
it "should have the same events as its parent" do
|
|
expect(SubClassMultiple.aasm(:left).events).to eq(SuperClassMultiple.aasm(:left).events)
|
|
expect(SubClassMultiple.aasm(:right).events).to eq(SuperClassMultiple.aasm(:right).events)
|
|
end
|
|
|
|
it 'should know how to respond to question methods' do
|
|
expect(SubClassMultiple.new.may_foo?).to be_truthy
|
|
expect(SubClassMultiple.new.may_close?).to be_truthy
|
|
end
|
|
|
|
it 'should not break if I call methods from super class' do
|
|
son = SubClassMultiple.new
|
|
son.update_state
|
|
expect(son.aasm(:left).current_state).to eq(:ended)
|
|
end
|
|
|
|
end
|
|
|