1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151
|
require File.expand_path('../../../spec_helper', __FILE__)
require File.expand_path('../fixtures/classes', __FILE__)
require File.expand_path('../shared/step', __FILE__)
describe "Numeric#step" do
describe 'with positional args' do
it "raises an ArgumentError when step is 0" do
lambda { 1.step(5, 0) {} }.should raise_error(ArgumentError)
end
it "raises an ArgumentError when step is 0.0" do
lambda { 1.step(2, 0.0) {} }.should raise_error(ArgumentError)
end
before :all do
# This lambda definition limits to return the arguments it receives.
# It's needed to test numeric_step behaviour with positional arguments.
@step_args = ->(*args) { args }
end
it_behaves_like :numeric_step, :step
describe "when no block is given" do
it "returns an Enumerator when step is 0" do
1.step(5, 0).should be_an_instance_of(Enumerator)
end
it "returns an Enumerator when step is 0.0" do
1.step(2, 0.0).should be_an_instance_of(Enumerator)
end
describe "returned Enumerator" do
describe "size" do
it "raises an ArgumentError when step is 0" do
enum = 1.step(5, 0)
lambda { enum.size }.should raise_error(ArgumentError)
end
it "raises an ArgumentError when step is 0.0" do
enum = 1.step(2, 0.0)
lambda { enum.size }.should raise_error(ArgumentError)
end
end
end
end
end
describe 'with keyword arguments' do
it "doesn't raise an error when step is 0" do
lambda { 1.step(to: 5, by: 0) { break } }.should_not raise_error
end
it "doesn't raise an error when step is 0.0" do
lambda { 1.step(to: 2, by: 0.0) { break } }.should_not raise_error
end
it "should loop over self when step is 0 or 0.0" do
1.step(to: 2, by: 0.0).take(5).should eql [1.0, 1.0, 1.0, 1.0, 1.0]
1.step(to: 2, by: 0).take(5).should eql [1, 1, 1, 1, 1]
1.1.step(to: 2, by: 0).take(5).should eql [1.1, 1.1, 1.1, 1.1, 1.1]
end
describe "when no block is given" do
describe "returned Enumerator" do
describe "size" do
it "should return infinity_value when step is 0" do
1.step(to: 5, by: 0).size.should == infinity_value
end
it "should return infinity_value when step is 0.0" do
1.step(to: 2, by: 0.0).size.should == infinity_value
end
it "should return infinity_value when the limit is Float::INFINITY" do
1.step(to: Float::INFINITY, by: 42).size.should == infinity_value
end
it "should return 1 when the both limit and step are Float::INFINITY" do
1.step(to: Float::INFINITY, by: Float::INFINITY).size.should == 1
end
end
end
end
before :all do
# This lambda transforms a positional step method args into
# keyword arguments.
# It's needed to test numeric_step behaviour with keyword arguments.
@step_args = ->(*args) do
kw_args = {to: args[0]}
kw_args[:by] = args[1] if args.size == 2
[kw_args]
end
end
it_behaves_like :numeric_step, :step
end
describe 'with mixed arguments' do
it "doesn't raise an error when step is 0" do
lambda { 1.step(5, by: 0) { break } }.should_not raise_error
end
it "doesn't raise an error when step is 0.0" do
lambda { 1.step(2, by: 0.0) { break } }.should_not raise_error
end
it "raises a ArgumentError when limit and to are defined" do
lambda { 1.step(5, 1, to: 5) { break } }.should raise_error(ArgumentError)
end
it "raises a ArgumentError when step and by are defined" do
lambda { 1.step(5, 1, by: 5) { break } }.should raise_error(ArgumentError)
end
it "should loop over self when step is 0 or 0.0" do
1.step(2, by: 0.0).take(5).should eql [1.0, 1.0, 1.0, 1.0, 1.0]
1.step(2, by: 0).take(5).should eql [1, 1, 1, 1, 1]
1.1.step(2, by: 0).take(5).should eql [1.1, 1.1, 1.1, 1.1, 1.1]
end
describe "when no block is given" do
describe "returned Enumerator" do
describe "size" do
it "should return infinity_value when step is 0" do
1.step(5, by: 0).size.should == infinity_value
end
it "should return infinity_value when step is 0.0" do
1.step(2, by: 0.0).size.should == infinity_value
end
end
end
end
before :all do
# This lambda definition transforms a positional step method args into
# a mix of positional and keyword arguments.
# It's needed to test numeric_step behaviour with positional mixed with
# keyword arguments.
@step_args = ->(*args) do
if args.size == 2
[args[0], {by: args[1]}]
else
args
end
end
end
it_behaves_like :numeric_step, :step
end
end
|