File: //usr/local/rvm/src/ruby-2.5.9/spec/ruby/core/array/pack/shared/integer.rb
# -*- encoding: ascii-8bit -*-
describe :array_pack_16bit_le, shared: true do
it "encodes the least significant 16 bits of a positive number" do
[ [[0x0000_0021], "\x21\x00"],
[[0x0000_4321], "\x21\x43"],
[[0x0065_4321], "\x21\x43"],
[[0x7865_4321], "\x21\x43"]
].should be_computed_by(:pack, pack_format())
end
it "encodes the least significant 16 bits of a negative number" do
[ [[-0x0000_0021], "\xdf\xff"],
[[-0x0000_4321], "\xdf\xbc"],
[[-0x0065_4321], "\xdf\xbc"],
[[-0x7865_4321], "\xdf\xbc"]
].should be_computed_by(:pack, pack_format())
end
it "encodes a Float truncated as an Integer" do
[ [[2019902241.2], "\x21\x43"],
[[2019902241.8], "\x21\x43"],
[[-2019902241.2], "\xdf\xbc"],
[[-2019902241.8], "\xdf\xbc"]
].should be_computed_by(:pack, pack_format())
end
it "calls #to_int to convert the pack argument to an Integer" do
obj = mock('to_int')
obj.should_receive(:to_int).and_return(0x1234_5678)
[obj].pack(pack_format()).should == "\x78\x56"
end
it "encodes the number of array elements specified by the count modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format(2))
str.should == "\x78\x65\xcd\xab"
end
it "encodes all remaining elements when passed the '*' modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format('*'))
str.should == "\x78\x65\xcd\xab\x21\x43"
end
it "ignores NULL bytes between directives" do
str = [0x1243_6578, 0xdef0_abcd].pack(pack_format("\000", 2))
str.should == "\x78\x65\xcd\xab"
end
it "ignores spaces between directives" do
str = [0x1243_6578, 0xdef0_abcd].pack(pack_format(' ', 2))
str.should == "\x78\x65\xcd\xab"
end
end
describe :array_pack_16bit_be, shared: true do
it "encodes the least significant 16 bits of a positive number" do
[ [[0x0000_0021], "\x00\x21"],
[[0x0000_4321], "\x43\x21"],
[[0x0065_4321], "\x43\x21"],
[[0x7865_4321], "\x43\x21"]
].should be_computed_by(:pack, pack_format())
end
it "encodes the least significant 16 bits of a negative number" do
[ [[-0x0000_0021], "\xff\xdf"],
[[-0x0000_4321], "\xbc\xdf"],
[[-0x0065_4321], "\xbc\xdf"],
[[-0x7865_4321], "\xbc\xdf"]
].should be_computed_by(:pack, pack_format())
end
it "encodes a Float truncated as an Integer" do
[ [[2019902241.2], "\x43\x21"],
[[2019902241.8], "\x43\x21"],
[[-2019902241.2], "\xbc\xdf"],
[[-2019902241.8], "\xbc\xdf"]
].should be_computed_by(:pack, pack_format())
end
it "calls #to_int to convert the pack argument to an Integer" do
obj = mock('to_int')
obj.should_receive(:to_int).and_return(0x1234_5678)
[obj].pack(pack_format()).should == "\x56\x78"
end
it "encodes the number of array elements specified by the count modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format(2))
str.should == "\x65\x78\xab\xcd"
end
it "encodes all remaining elements when passed the '*' modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format('*'))
str.should == "\x65\x78\xab\xcd\x43\x21"
end
it "ignores NULL bytes between directives" do
str = [0x1243_6578, 0xdef0_abcd].pack(pack_format("\000", 2))
str.should == "\x65\x78\xab\xcd"
end
it "ignores spaces between directives" do
str = [0x1243_6578, 0xdef0_abcd].pack(pack_format(' ', 2))
str.should == "\x65\x78\xab\xcd"
end
end
describe :array_pack_32bit_le, shared: true do
it "encodes the least significant 32 bits of a positive number" do
[ [[0x0000_0021], "\x21\x00\x00\x00"],
[[0x0000_4321], "\x21\x43\x00\x00"],
[[0x0065_4321], "\x21\x43\x65\x00"],
[[0x7865_4321], "\x21\x43\x65\x78"]
].should be_computed_by(:pack, pack_format())
end
it "encodes the least significant 32 bits of a negative number" do
[ [[-0x0000_0021], "\xdf\xff\xff\xff"],
[[-0x0000_4321], "\xdf\xbc\xff\xff"],
[[-0x0065_4321], "\xdf\xbc\x9a\xff"],
[[-0x7865_4321], "\xdf\xbc\x9a\x87"]
].should be_computed_by(:pack, pack_format())
end
it "encodes a Float truncated as an Integer" do
[ [[2019902241.2], "\x21\x43\x65\x78"],
[[2019902241.8], "\x21\x43\x65\x78"],
[[-2019902241.2], "\xdf\xbc\x9a\x87"],
[[-2019902241.8], "\xdf\xbc\x9a\x87"]
].should be_computed_by(:pack, pack_format())
end
it "calls #to_int to convert the pack argument to an Integer" do
obj = mock('to_int')
obj.should_receive(:to_int).and_return(0x1234_5678)
[obj].pack(pack_format()).should == "\x78\x56\x34\x12"
end
it "encodes the number of array elements specified by the count modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format(2))
str.should == "\x78\x65\x43\x12\xcd\xab\xf0\xde"
end
it "encodes all remaining elements when passed the '*' modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format('*'))
str.should == "\x78\x65\x43\x12\xcd\xab\xf0\xde\x21\x43\x65\x78"
end
it "ignores NULL bytes between directives" do
str = [0x1243_6578, 0xdef0_abcd].pack(pack_format("\000", 2))
str.should == "\x78\x65\x43\x12\xcd\xab\xf0\xde"
end
it "ignores spaces between directives" do
str = [0x1243_6578, 0xdef0_abcd].pack(pack_format(' ', 2))
str.should == "\x78\x65\x43\x12\xcd\xab\xf0\xde"
end
end
describe :array_pack_32bit_be, shared: true do
it "encodes the least significant 32 bits of a positive number" do
[ [[0x0000_0021], "\x00\x00\x00\x21"],
[[0x0000_4321], "\x00\x00\x43\x21"],
[[0x0065_4321], "\x00\x65\x43\x21"],
[[0x7865_4321], "\x78\x65\x43\x21"]
].should be_computed_by(:pack, pack_format())
end
it "encodes the least significant 32 bits of a negative number" do
[ [[-0x0000_0021], "\xff\xff\xff\xdf"],
[[-0x0000_4321], "\xff\xff\xbc\xdf"],
[[-0x0065_4321], "\xff\x9a\xbc\xdf"],
[[-0x7865_4321], "\x87\x9a\xbc\xdf"]
].should be_computed_by(:pack, pack_format())
end
it "encodes a Float truncated as an Integer" do
[ [[2019902241.2], "\x78\x65\x43\x21"],
[[2019902241.8], "\x78\x65\x43\x21"],
[[-2019902241.2], "\x87\x9a\xbc\xdf"],
[[-2019902241.8], "\x87\x9a\xbc\xdf"]
].should be_computed_by(:pack, pack_format())
end
it "calls #to_int to convert the pack argument to an Integer" do
obj = mock('to_int')
obj.should_receive(:to_int).and_return(0x1234_5678)
[obj].pack(pack_format()).should == "\x12\x34\x56\x78"
end
it "encodes the number of array elements specified by the count modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format(2))
str.should == "\x12\x43\x65\x78\xde\xf0\xab\xcd"
end
it "encodes all remaining elements when passed the '*' modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format('*'))
str.should == "\x12\x43\x65\x78\xde\xf0\xab\xcd\x78\x65\x43\x21"
end
it "ignores NULL bytes between directives" do
str = [0x1243_6578, 0xdef0_abcd].pack(pack_format("\000", 2))
str.should == "\x12\x43\x65\x78\xde\xf0\xab\xcd"
end
it "ignores spaces between directives" do
str = [0x1243_6578, 0xdef0_abcd].pack(pack_format(' ', 2))
str.should == "\x12\x43\x65\x78\xde\xf0\xab\xcd"
end
end
describe :array_pack_32bit_le_platform, shared: true do
it "encodes the least significant 32 bits of a number" do
[ [[0x7865_4321], "\x21\x43\x65\x78"],
[[-0x7865_4321], "\xdf\xbc\x9a\x87"]
].should be_computed_by(:pack, pack_format())
end
it "encodes the number of array elements specified by the count modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format(2))
str.should == "\x78\x65\x43\x12\xcd\xab\xf0\xde"
end
it "encodes all remaining elements when passed the '*' modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format('*'))
str.should == "\x78\x65\x43\x12\xcd\xab\xf0\xde\x21\x43\x65\x78"
end
platform_is wordsize: 64 do
it "encodes the least significant 32 bits of a number that is greater than 32 bits" do
[ [[0xff_7865_4321], "\x21\x43\x65\x78"],
[[-0xff_7865_4321], "\xdf\xbc\x9a\x87"]
].should be_computed_by(:pack, pack_format())
end
end
end
describe :array_pack_32bit_be_platform, shared: true do
it "encodes the least significant 32 bits of a number" do
[ [[0x7865_4321], "\x78\x65\x43\x21"],
[[-0x7865_4321], "\x87\x9a\xbc\xdf"]
].should be_computed_by(:pack, pack_format())
end
it "encodes the number of array elements specified by the count modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format(2))
str.should == "\x12\x43\x65\x78\xde\xf0\xab\xcd"
end
it "encodes all remaining elements when passed the '*' modifier" do
str = [0x1243_6578, 0xdef0_abcd, 0x7865_4321].pack(pack_format('*'))
str.should == "\x12\x43\x65\x78\xde\xf0\xab\xcd\x78\x65\x43\x21"
end
platform_is wordsize: 64 do
it "encodes the least significant 32 bits of a number that is greater than 32 bits" do
[ [[0xff_7865_4321], "\x78\x65\x43\x21"],
[[-0xff_7865_4321], "\x87\x9a\xbc\xdf"]
].should be_computed_by(:pack, pack_format())
end
end
end
describe :array_pack_64bit_le, shared: true do
it "encodes the least significant 64 bits of a positive number" do
[ [[0x0000_0000_0000_0021], "\x21\x00\x00\x00\x00\x00\x00\x00"],
[[0x0000_0000_0000_4321], "\x21\x43\x00\x00\x00\x00\x00\x00"],
[[0x0000_0000_0065_4321], "\x21\x43\x65\x00\x00\x00\x00\x00"],
[[0x0000_0000_7865_4321], "\x21\x43\x65\x78\x00\x00\x00\x00"],
[[0x0000_0090_7865_4321], "\x21\x43\x65\x78\x90\x00\x00\x00"],
[[0x0000_ba90_7865_4321], "\x21\x43\x65\x78\x90\xba\x00\x00"],
[[0x00dc_ba90_7865_4321], "\x21\x43\x65\x78\x90\xba\xdc\x00"],
[[0x7edc_ba90_7865_4321], "\x21\x43\x65\x78\x90\xba\xdc\x7e"]
].should be_computed_by(:pack, pack_format())
end
it "encodes the least significant 64 bits of a negative number" do
[ [[-0x0000_0000_0000_0021], "\xdf\xff\xff\xff\xff\xff\xff\xff"],
[[-0x0000_0000_0000_4321], "\xdf\xbc\xff\xff\xff\xff\xff\xff"],
[[-0x0000_0000_0065_4321], "\xdf\xbc\x9a\xff\xff\xff\xff\xff"],
[[-0x0000_0000_7865_4321], "\xdf\xbc\x9a\x87\xff\xff\xff\xff"],
[[-0x0000_0090_7865_4321], "\xdf\xbc\x9a\x87\x6f\xff\xff\xff"],
[[-0x0000_ba90_7865_4321], "\xdf\xbc\x9a\x87\x6f\x45\xff\xff"],
[[-0x00dc_ba90_7865_4321], "\xdf\xbc\x9a\x87\x6f\x45\x23\xff"],
[[-0x7edc_ba90_7865_4321], "\xdf\xbc\x9a\x87\x6f\x45\x23\x81"]
].should be_computed_by(:pack, pack_format())
end
it "encodes a Float truncated as an Integer" do
[ [[9.14138647331322368e+18], "\x00\x44\x65\x78\x90\xba\xdc\x7e"],
[[-9.14138647331322368e+18], "\x00\xbc\x9a\x87\x6f\x45\x23\x81"]
].should be_computed_by(:pack, pack_format())
end
it "calls #to_int to convert the pack argument to an Integer" do
obj = mock('to_int')
obj.should_receive(:to_int).and_return(0x1234_5678_90ab_cdef)
[obj].pack(pack_format()).should == "\xef\xcd\xab\x90\x78\x56\x34\x12"
end
it "encodes the number of array elements specified by the count modifier" do
str = [0x1234_5678_90ab_cdef,
0xdef0_abcd_3412_7856,
0x7865_4321_dcba_def0].pack(pack_format(2))
str.should == "\xef\xcd\xab\x90\x78\x56\x34\x12\x56\x78\x12\x34\xcd\xab\xf0\xde"
end
it "encodes all remaining elements when passed the '*' modifier" do
str = [0xdef0_abcd_3412_7856, 0x7865_4321_dcba_def0].pack(pack_format('*'))
str.should == "\x56\x78\x12\x34\xcd\xab\xf0\xde\xf0\xde\xba\xdc\x21\x43\x65\x78"
end
it "ignores NULL bytes between directives" do
str = [0xdef0_abcd_3412_7856, 0x7865_4321_dcba_def0].pack(pack_format("\000", 2))
str.should == "\x56\x78\x12\x34\xcd\xab\xf0\xde\xf0\xde\xba\xdc\x21\x43\x65\x78"
end
it "ignores spaces between directives" do
str = [0xdef0_abcd_3412_7856, 0x7865_4321_dcba_def0].pack(pack_format(' ', 2))
str.should == "\x56\x78\x12\x34\xcd\xab\xf0\xde\xf0\xde\xba\xdc\x21\x43\x65\x78"
end
end
describe :array_pack_64bit_be, shared: true do
it "encodes the least significant 64 bits of a positive number" do
[ [[0x0000_0000_0000_0021], "\x00\x00\x00\x00\x00\x00\x00\x21"],
[[0x0000_0000_0000_4321], "\x00\x00\x00\x00\x00\x00\x43\x21"],
[[0x0000_0000_0065_4321], "\x00\x00\x00\x00\x00\x65\x43\x21"],
[[0x0000_0000_7865_4321], "\x00\x00\x00\x00\x78\x65\x43\x21"],
[[0x0000_0090_7865_4321], "\x00\x00\x00\x90\x78\x65\x43\x21"],
[[0x0000_ba90_7865_4321], "\x00\x00\xba\x90\x78\x65\x43\x21"],
[[0x00dc_ba90_7865_4321], "\x00\xdc\xba\x90\x78\x65\x43\x21"],
[[0x7edc_ba90_7865_4321], "\x7e\xdc\xba\x90\x78\x65\x43\x21"]
].should be_computed_by(:pack, pack_format())
end
it "encodes the least significant 64 bits of a negative number" do
[ [[-0x0000_0000_0000_0021], "\xff\xff\xff\xff\xff\xff\xff\xdf"],
[[-0x0000_0000_0000_4321], "\xff\xff\xff\xff\xff\xff\xbc\xdf"],
[[-0x0000_0000_0065_4321], "\xff\xff\xff\xff\xff\x9a\xbc\xdf"],
[[-0x0000_0000_7865_4321], "\xff\xff\xff\xff\x87\x9a\xbc\xdf"],
[[-0x0000_0090_7865_4321], "\xff\xff\xff\x6f\x87\x9a\xbc\xdf"],
[[-0x0000_ba90_7865_4321], "\xff\xff\x45\x6f\x87\x9a\xbc\xdf"],
[[-0x00dc_ba90_7865_4321], "\xff\x23\x45\x6f\x87\x9a\xbc\xdf"],
[[-0x7edc_ba90_7865_4321], "\x81\x23\x45\x6f\x87\x9a\xbc\xdf"]
].should be_computed_by(:pack, pack_format())
end
it "encodes a Float truncated as an Integer" do
[ [[9.14138647331322368e+18], "\x7e\xdc\xba\x90\x78\x65\x44\x00"],
[[-9.14138647331322368e+18], "\x81\x23\x45\x6f\x87\x9a\xbc\x00"]
].should be_computed_by(:pack, pack_format())
end
it "calls #to_int to convert the pack argument to an Integer" do
obj = mock('to_int')
obj.should_receive(:to_int).and_return(0x1234_5678_90ab_cdef)
[obj].pack(pack_format()).should == "\x12\x34\x56\x78\x90\xab\xcd\xef"
end
it "encodes the number of array elements specified by the count modifier" do
str = [0x1234_5678_90ab_cdef,
0xdef0_abcd_3412_7856,
0x7865_4321_dcba_def0].pack(pack_format(2))
str.should == "\x12\x34\x56\x78\x90\xab\xcd\xef\xde\xf0\xab\xcd\x34\x12\x78\x56"
end
it "encodes all remaining elements when passed the '*' modifier" do
str = [0xdef0_abcd_3412_7856, 0x7865_4321_dcba_def0].pack(pack_format('*'))
str.should == "\xde\xf0\xab\xcd\x34\x12\x78\x56\x78\x65\x43\x21\xdc\xba\xde\xf0"
end
it "ignores NULL bytes between directives" do
str = [0xdef0_abcd_3412_7856, 0x7865_4321_dcba_def0].pack(pack_format("\000", 2))
str.should == "\xde\xf0\xab\xcd\x34\x12\x78\x56\x78\x65\x43\x21\xdc\xba\xde\xf0"
end
it "ignores spaces between directives" do
str = [0xdef0_abcd_3412_7856, 0x7865_4321_dcba_def0].pack(pack_format(' ', 2))
str.should == "\xde\xf0\xab\xcd\x34\x12\x78\x56\x78\x65\x43\x21\xdc\xba\xde\xf0"
end
end