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
|
describe :array_unshift, shared: true do
it "prepends object to the original array" do
a = [1, 2, 3]
a.send(@method, "a").should equal(a)
a.should == ['a', 1, 2, 3]
a.send(@method).should equal(a)
a.should == ['a', 1, 2, 3]
a.send(@method, 5, 4, 3)
a.should == [5, 4, 3, 'a', 1, 2, 3]
# shift all but one element
a = [1, 2]
a.shift
a.send(@method, 3, 4)
a.should == [3, 4, 2]
# now shift all elements
a.shift
a.shift
a.shift
a.send(@method, 3, 4)
a.should == [3, 4]
end
it "returns self" do
a = [1, 2, 3]
a.send(@method, "a").should.equal?(a)
end
it "quietly ignores unshifting nothing" do
[].send(@method).should == []
end
it "properly handles recursive arrays" do
empty = ArraySpecs.empty_recursive_array
empty.send(@method, :new).should == [:new, empty]
array = ArraySpecs.recursive_array
array.send(@method, :new)
array[0..5].should == [:new, 1, 'two', 3.0, array, array]
end
it "raises a FrozenError on a frozen array when the array is modified" do
-> { ArraySpecs.frozen_array.send(@method, 1) }.should raise_error(FrozenError)
end
# see [ruby-core:23666]
it "raises a FrozenError on a frozen array when the array would not be modified" do
-> { ArraySpecs.frozen_array.send(@method) }.should raise_error(FrozenError)
end
# https://github.com/oracle/truffleruby/issues/2772
it "doesn't rely on Array#[]= so it can be overridden" do
subclass = Class.new(Array) do
def []=(*)
raise "[]= is called"
end
end
array = subclass.new
array.send(@method, 1)
array.should == [1]
end
end
|