File: byteslice_spec.rb

package info (click to toggle)
jruby 9.4.8.0%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 89,244 kB
  • sloc: ruby: 548,574; java: 276,189; yacc: 25,873; ansic: 6,178; xml: 6,111; sh: 1,855; sed: 94; makefile: 78; jsp: 48; tcl: 40; exp: 12
file content (33 lines) | stat: -rw-r--r-- 1,177 bytes parent folder | download
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
# -*- encoding: binary -*-
require_relative '../../spec_helper'
require_relative 'fixtures/classes'
require_relative 'shared/slice'

describe "String#byteslice" do
  it "needs to reviewed for spec completeness"

  it_behaves_like :string_slice, :byteslice
end

describe "String#byteslice with index, length" do
  it_behaves_like :string_slice_index_length, :byteslice
end

describe "String#byteslice with Range" do
  it_behaves_like :string_slice_range, :byteslice
end

describe "String#byteslice on on non ASCII strings" do
  it "returns byteslice of unicode strings" do
    "\u3042".byteslice(1).should == "\x81".dup.force_encoding("UTF-8")
    "\u3042".byteslice(1, 2).should == "\x81\x82".dup.force_encoding("UTF-8")
    "\u3042".byteslice(1..2).should == "\x81\x82".dup.force_encoding("UTF-8")
    "\u3042".byteslice(-1).should == "\x82".dup.force_encoding("UTF-8")
  end

  it "returns a String in the same encoding as self" do
    "ruby".encode("UTF-8").slice(0).encoding.should == Encoding::UTF_8
    "ruby".encode("US-ASCII").slice(0).encoding.should == Encoding::US_ASCII
    "ruby".encode("Windows-1251").slice(0).encoding.should == Encoding::Windows_1251
  end
end