2018-03-04 10:09:32 -05:00
|
|
|
require_relative '../../spec_helper'
|
|
|
|
require_relative 'fixtures/classes'
|
2017-05-07 08:04:49 -04:00
|
|
|
|
|
|
|
describe "Array#reverse" do
|
|
|
|
it "returns a new array with the elements in reverse order" do
|
|
|
|
[].reverse.should == []
|
|
|
|
[1, 3, 5, 2].reverse.should == [2, 5, 3, 1]
|
|
|
|
end
|
|
|
|
|
|
|
|
it "properly handles recursive arrays" do
|
|
|
|
empty = ArraySpecs.empty_recursive_array
|
|
|
|
empty.reverse.should == empty
|
|
|
|
|
|
|
|
array = ArraySpecs.recursive_array
|
|
|
|
array.reverse.should == [array, array, array, array, array, 3.0, 'two', 1]
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not return subclass instance on Array subclasses" do
|
|
|
|
ArraySpecs::MyArray[1, 2, 3].reverse.should be_an_instance_of(Array)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "Array#reverse!" do
|
|
|
|
it "reverses the elements in place" do
|
|
|
|
a = [6, 3, 4, 2, 1]
|
|
|
|
a.reverse!.should equal(a)
|
|
|
|
a.should == [1, 2, 4, 3, 6]
|
|
|
|
[].reverse!.should == []
|
|
|
|
end
|
|
|
|
|
|
|
|
it "properly handles recursive arrays" do
|
|
|
|
empty = ArraySpecs.empty_recursive_array
|
|
|
|
empty.reverse!.should == [empty]
|
|
|
|
|
|
|
|
array = ArraySpecs.recursive_array
|
|
|
|
array.reverse!.should == [array, array, array, array, array, 3.0, 'two', 1]
|
|
|
|
end
|
|
|
|
|
2017-12-27 11:12:47 -05:00
|
|
|
it "raises a #{frozen_error_class} on a frozen array" do
|
|
|
|
lambda { ArraySpecs.frozen_array.reverse! }.should raise_error(frozen_error_class)
|
2017-05-07 08:04:49 -04:00
|
|
|
end
|
|
|
|
end
|