summaryrefslogtreecommitdiff
path: root/spec/ruby/core/string/unpack1_spec.rb
diff options
context:
space:
mode:
authorJean Boussier <jean.boussier@gmail.com>2021-10-18 16:23:54 +0200
committerJean Boussier <jean.boussier@gmail.com>2021-10-26 22:27:30 +0200
commite5319dc9856298f38aa9cdc6ed55e39ad0e8e070 (patch)
tree7c1d685ae65979ce2ae3bee4ccce54507d3f49f8 /spec/ruby/core/string/unpack1_spec.rb
parent717ab0bb2ee63dfe76076e0c9f91fbac3a0de4fd (diff)
pack.c: add an offset argument to unpack and unpack1
[Feature #18254] This is useful to avoid repeteadly copying strings when parsing binary formats
Diffstat (limited to 'spec/ruby/core/string/unpack1_spec.rb')
-rw-r--r--spec/ruby/core/string/unpack1_spec.rb20
1 files changed, 20 insertions, 0 deletions
diff --git a/spec/ruby/core/string/unpack1_spec.rb b/spec/ruby/core/string/unpack1_spec.rb
index 5fe81733fb..f59bd92d6a 100644
--- a/spec/ruby/core/string/unpack1_spec.rb
+++ b/spec/ruby/core/string/unpack1_spec.rb
@@ -7,4 +7,24 @@ describe "String#unpack1" do
"aG9nZWZ1Z2E=".unpack1("m").should == "hogefuga"
"A".unpack1("B*").should == "01000001"
end
+
+ ruby_version_is "3.1" do
+ it "starts unpacking from the given offset" do
+ "ZZABCD".unpack1('x3C', offset: 2).should == "ABCD".unpack('x3C')[0]
+ "ZZZZaG9nZWZ1Z2E=".unpack1("m", offset: 4).should == "hogefuga"
+ "ZA".unpack1("B*", offset: 1).should == "01000001"
+ end
+
+ it "raises an ArgumentError when the offset is negative" do
+ -> { "a".unpack1("C", offset: -1) }.should raise_error(ArgumentError)
+ end
+
+ it "returns nil if the offset is at the end of the string" do
+ "a".unpack1("C", offset: 1).should == nil
+ end
+
+ it "raises an ArgumentError when the offset is larget than the string" do
+ -> { "a".unpack1("C", offset: 2) }.should raise_error(ArgumentError)
+ end
+ end
end