summaryrefslogtreecommitdiff
path: root/spec/ruby/library/stringio
diff options
context:
space:
mode:
Diffstat (limited to 'spec/ruby/library/stringio')
-rw-r--r--spec/ruby/library/stringio/each_byte_spec.rb46
-rw-r--r--spec/ruby/library/stringio/each_char_spec.rb33
-rw-r--r--spec/ruby/library/stringio/each_codepoint_spec.rb46
-rw-r--r--spec/ruby/library/stringio/each_line_spec.rb199
-rw-r--r--spec/ruby/library/stringio/each_spec.rb33
-rw-r--r--spec/ruby/library/stringio/eof_spec.rb30
-rw-r--r--spec/ruby/library/stringio/isatty_spec.rb7
-rw-r--r--spec/ruby/library/stringio/length_spec.rb7
-rw-r--r--spec/ruby/library/stringio/pos_spec.rb12
-rw-r--r--spec/ruby/library/stringio/shared/codepoints.rb45
-rw-r--r--spec/ruby/library/stringio/shared/each.rb209
-rw-r--r--spec/ruby/library/stringio/shared/each_byte.rb48
-rw-r--r--spec/ruby/library/stringio/shared/each_char.rb36
-rw-r--r--spec/ruby/library/stringio/shared/eof.rb24
-rw-r--r--spec/ruby/library/stringio/shared/isatty.rb5
-rw-r--r--spec/ruby/library/stringio/shared/length.rb5
-rw-r--r--spec/ruby/library/stringio/shared/tell.rb12
-rw-r--r--spec/ruby/library/stringio/size_spec.rb7
-rw-r--r--spec/ruby/library/stringio/tell_spec.rb7
-rw-r--r--spec/ruby/library/stringio/tty_spec.rb7
20 files changed, 368 insertions, 450 deletions
diff --git a/spec/ruby/library/stringio/each_byte_spec.rb b/spec/ruby/library/stringio/each_byte_spec.rb
index 6f82a32441..1be0081c1e 100644
--- a/spec/ruby/library/stringio/each_byte_spec.rb
+++ b/spec/ruby/library/stringio/each_byte_spec.rb
@@ -1,11 +1,51 @@
require_relative '../../spec_helper'
require 'stringio'
-require_relative 'shared/each_byte'
describe "StringIO#each_byte" do
- it_behaves_like :stringio_each_byte, :each_byte
+ before :each do
+ @io = StringIO.new("xyz")
+ end
+
+ it "yields each character code in turn" do
+ seen = []
+ @io.each_byte { |b| seen << b }
+ seen.should == [120, 121, 122]
+ end
+
+ it "updates the position before each yield" do
+ seen = []
+ @io.each_byte { |b| seen << @io.pos }
+ seen.should == [1, 2, 3]
+ end
+
+ it "does not yield if the current position is out of bounds" do
+ @io.pos = 1000
+ seen = nil
+ @io.each_byte { |b| seen = b }
+ seen.should == nil
+ end
+
+ it "returns self" do
+ @io.each_byte {}.should.equal?(@io)
+ end
+
+ it "returns an Enumerator when passed no block" do
+ enum = @io.each_byte
+ enum.instance_of?(Enumerator).should == true
+
+ seen = []
+ enum.each { |b| seen << b }
+ seen.should == [120, 121, 122]
+ end
end
describe "StringIO#each_byte when self is not readable" do
- it_behaves_like :stringio_each_byte_not_readable, :each_byte
+ it "raises an IOError" do
+ io = StringIO.new(+"xyz", "w")
+ -> { io.each_byte { |b| b } }.should.raise(IOError)
+
+ io = StringIO.new("xyz")
+ io.close_read
+ -> { io.each_byte { |b| b } }.should.raise(IOError)
+ end
end
diff --git a/spec/ruby/library/stringio/each_char_spec.rb b/spec/ruby/library/stringio/each_char_spec.rb
index 14b2f09a17..1db80c7d07 100644
--- a/spec/ruby/library/stringio/each_char_spec.rb
+++ b/spec/ruby/library/stringio/each_char_spec.rb
@@ -1,11 +1,38 @@
require_relative '../../spec_helper'
require 'stringio'
-require_relative 'shared/each_char'
describe "StringIO#each_char" do
- it_behaves_like :stringio_each_char, :each_char
+ before :each do
+ @io = StringIO.new("xyz äöü")
+ end
+
+ it "yields each character code in turn" do
+ seen = []
+ @io.each_char { |c| seen << c }
+ seen.should == ["x", "y", "z", " ", "ä", "ö", "ü"]
+ end
+
+ it "returns self" do
+ @io.each_char {}.should.equal?(@io)
+ end
+
+ it "returns an Enumerator when passed no block" do
+ enum = @io.each_char
+ enum.instance_of?(Enumerator).should == true
+
+ seen = []
+ enum.each { |c| seen << c }
+ seen.should == ["x", "y", "z", " ", "ä", "ö", "ü"]
+ end
end
describe "StringIO#each_char when self is not readable" do
- it_behaves_like :stringio_each_char_not_readable, :each_char
+ it "raises an IOError" do
+ io = StringIO.new(+"xyz", "w")
+ -> { io.each_char { |b| b } }.should.raise(IOError)
+
+ io = StringIO.new("xyz")
+ io.close_read
+ -> { io.each_char { |b| b } }.should.raise(IOError)
+ end
end
diff --git a/spec/ruby/library/stringio/each_codepoint_spec.rb b/spec/ruby/library/stringio/each_codepoint_spec.rb
index f18de22aad..d4f461db90 100644
--- a/spec/ruby/library/stringio/each_codepoint_spec.rb
+++ b/spec/ruby/library/stringio/each_codepoint_spec.rb
@@ -1,9 +1,47 @@
-# -*- encoding: utf-8 -*-
require_relative '../../spec_helper'
-require_relative 'fixtures/classes'
-require_relative 'shared/codepoints'
+require 'stringio'
# See redmine #1667
describe "StringIO#each_codepoint" do
- it_behaves_like :stringio_codepoints, :each_codepoint
+ before :each do
+ @io = StringIO.new("∂φ/∂x = gaîté")
+ @enum = @io.each_codepoint
+ end
+
+ it "returns an Enumerator" do
+ @enum.should.instance_of?(Enumerator)
+ end
+
+ it "yields each codepoint code in turn" do
+ @enum.to_a.should == [8706, 966, 47, 8706, 120, 32, 61, 32, 103, 97, 238, 116, 233]
+ end
+
+ it "yields each codepoint starting from the current position" do
+ @io.pos = 15
+ @enum.to_a.should == [238, 116, 233]
+ end
+
+ it "raises an error if reading invalid sequence" do
+ @io.pos = 1 # inside of a multibyte sequence
+ -> { @enum.first }.should.raise(ArgumentError)
+ end
+
+ it "raises an IOError if not readable" do
+ @io.close_read
+ -> { @enum.to_a }.should.raise(IOError)
+
+ io = StringIO.new(+"xyz", "w")
+ -> { io.each_codepoint.to_a }.should.raise(IOError)
+ end
+
+
+ it "calls the given block" do
+ r = []
+ @io.each_codepoint{|c| r << c }
+ r.should == [8706, 966, 47, 8706, 120, 32, 61, 32, 103, 97, 238, 116, 233]
+ end
+
+ it "returns self" do
+ @io.each_codepoint {|l| l }.should.equal?(@io)
+ end
end
diff --git a/spec/ruby/library/stringio/each_line_spec.rb b/spec/ruby/library/stringio/each_line_spec.rb
index 4ac0db7c45..4abecbf026 100644
--- a/spec/ruby/library/stringio/each_line_spec.rb
+++ b/spec/ruby/library/stringio/each_line_spec.rb
@@ -1,27 +1,212 @@
require_relative '../../spec_helper'
require_relative 'fixtures/classes'
-require_relative 'shared/each'
describe "StringIO#each_line when passed a separator" do
- it_behaves_like :stringio_each_separator, :each_line
+ before :each do
+ @io = StringIO.new("a b c d e\n1 2 3 4 5")
+ end
+
+ it "uses the passed argument as the line separator" do
+ seen = []
+ @io.each_line(" ") {|s| seen << s}
+ seen.should == ["a ", "b ", "c ", "d ", "e\n1 ", "2 ", "3 ", "4 ", "5"]
+ end
+
+ it "does not change $_" do
+ $_ = "test"
+ @io.each_line(" ") { |s| s}
+ $_.should == "test"
+ end
+
+ it "returns self" do
+ @io.each_line {|l| l }.should.equal?(@io)
+ end
+
+ it "tries to convert the passed separator to a String using #to_str" do
+ obj = mock("to_str")
+ obj.stub!(:to_str).and_return(" ")
+
+ seen = []
+ @io.each_line(obj) { |l| seen << l }
+ seen.should == ["a ", "b ", "c ", "d ", "e\n1 ", "2 ", "3 ", "4 ", "5"]
+ end
+
+ it "yields self's content starting from the current position when the passed separator is nil" do
+ seen = []
+ io = StringIO.new("1 2 1 2 1 2")
+ io.pos = 2
+ io.each_line(nil) {|s| seen << s}
+ seen.should == ["2 1 2 1 2"]
+ end
+
+ it "yields each paragraph with all separation characters when passed an empty String as separator" do
+ seen = []
+ io = StringIO.new("para1\n\npara2\n\n\npara3")
+ io.each_line("") {|s| seen << s}
+ seen.should == ["para1\n\n", "para2\n\n\n", "para3"]
+ end
end
describe "StringIO#each_line when passed no arguments" do
- it_behaves_like :stringio_each_no_arguments, :each_line
+ before :each do
+ @io = StringIO.new("a b c d e\n1 2 3 4 5")
+ end
+
+ it "yields each line to the passed block" do
+ seen = []
+ @io.each_line {|s| seen << s }
+ seen.should == ["a b c d e\n", "1 2 3 4 5"]
+ end
+
+ it "yields each line starting from the current position" do
+ seen = []
+ @io.pos = 4
+ @io.each_line {|s| seen << s }
+ seen.should == ["c d e\n", "1 2 3 4 5"]
+ end
+
+ it "does not change $_" do
+ $_ = "test"
+ @io.each_line { |s| s}
+ $_.should == "test"
+ end
+
+ it "uses $/ as the default line separator" do
+ seen = []
+ begin
+ old_rs = $/
+ suppress_warning {$/ = " "}
+ @io.each_line {|s| seen << s }
+ seen.should.eql?(["a ", "b ", "c ", "d ", "e\n1 ", "2 ", "3 ", "4 ", "5"])
+ ensure
+ suppress_warning {$/ = old_rs}
+ end
+ end
+
+ it "returns self" do
+ @io.each_line {|l| l }.should.equal?(@io)
+ end
+
+ it "returns an Enumerator when passed no block" do
+ enum = @io.each_line
+ enum.instance_of?(Enumerator).should == true
+
+ seen = []
+ enum.each { |b| seen << b }
+ seen.should == ["a b c d e\n", "1 2 3 4 5"]
+ end
end
describe "StringIO#each_line when self is not readable" do
- it_behaves_like :stringio_each_not_readable, :each_line
+ it "raises an IOError" do
+ io = StringIO.new(+"a b c d e", "w")
+ -> { io.each_line { |b| b } }.should.raise(IOError)
+
+ io = StringIO.new("a b c d e")
+ io.close_read
+ -> { io.each_line { |b| b } }.should.raise(IOError)
+ end
+end
+
+describe "StringIO#each_line when passed chomp" do
+ it "yields each line with removed newline characters to the passed block" do
+ seen = []
+ io = StringIO.new("a b \rc d e\n1 2 3 4 5\r\nthe end")
+ io.each_line(chomp: true) {|s| seen << s }
+ seen.should == ["a b \rc d e", "1 2 3 4 5", "the end"]
+ end
+
+ it "returns each line with removed newline characters when called without block" do
+ seen = []
+ io = StringIO.new("a b \rc d e\n1 2 3 4 5\r\nthe end")
+ enum = io.each_line(chomp: true)
+ enum.each {|s| seen << s }
+ seen.should == ["a b \rc d e", "1 2 3 4 5", "the end"]
+ end
end
describe "StringIO#each_line when passed chomp" do
- it_behaves_like :stringio_each_chomp, :each_line
+ it "yields each line with removed separator to the passed block" do
+ seen = []
+ io = StringIO.new("a b \nc d e|1 2 3 4 5\n|the end")
+ io.each_line("|", chomp: true) {|s| seen << s }
+ seen.should == ["a b \nc d e", "1 2 3 4 5\n", "the end"]
+ end
+
+ it "returns each line with removed separator when called without block" do
+ seen = []
+ io = StringIO.new("a b \nc d e|1 2 3 4 5\n|the end")
+ enum = io.each_line("|", chomp: true)
+ enum.each {|s| seen << s }
+ seen.should == ["a b \nc d e", "1 2 3 4 5\n", "the end"]
+ end
end
describe "StringIO#each_line when passed limit" do
- it_behaves_like :stringio_each_limit, :each_line
+ before :each do
+ @io = StringIO.new("a b c d e\n1 2 3 4 5")
+ end
+
+ it "returns the data read until the limit is met" do
+ seen = []
+ @io.each_line(4) { |s| seen << s }
+ seen.should == ["a b ", "c d ", "e\n", "1 2 ", "3 4 ", "5"]
+ end
end
describe "StringIO#each when passed separator and limit" do
- it_behaves_like :stringio_each_separator_and_limit, :each_line
+ before :each do
+ @io = StringIO.new("this>is>an>example")
+ end
+
+ it "returns the data read until the limit is consumed or the separator is met" do
+ @io.each_line('>', 8) { |s| break s }.should == "this>"
+ @io.each_line('>', 2) { |s| break s }.should == "is"
+ @io.each_line('>', 10) { |s| break s }.should == ">"
+ @io.each_line('>', 6) { |s| break s }.should == "an>"
+ @io.each_line('>', 5) { |s| break s }.should == "examp"
+ end
+
+ it "truncates the multi-character separator at the end to meet the limit" do
+ @io.each_line("is>an", 7) { |s| break s }.should == "this>is"
+ end
+
+ it "does not change $_" do
+ $_ = "test"
+ @io.each_line('>', 8) { |s| s }
+ $_.should == "test"
+ end
+
+ it "updates self's lineno by one" do
+ @io.each_line('>', 3) { |s| break s }
+ @io.lineno.should.eql?(1)
+
+ @io.each_line('>', 3) { |s| break s }
+ @io.lineno.should.eql?(2)
+
+ @io.each_line('>', 3) { |s| break s }
+ @io.lineno.should.eql?(3)
+ end
+
+ it "tries to convert the passed separator to a String using #to_str" do # TODO
+ obj = mock('to_str')
+ obj.should_receive(:to_str).and_return('>')
+
+ seen = []
+ @io.each_line(obj, 5) { |s| seen << s }
+ seen.should == ["this>", "is>", "an>", "examp", "le"]
+ end
+
+ it "does not raise TypeError if passed separator is nil" do
+ @io.each_line(nil, 5) { |s| break s }.should == "this>"
+ end
+
+ it "tries to convert the passed limit to an Integer using #to_int" do # TODO
+ obj = mock('to_int')
+ obj.should_receive(:to_int).and_return(5)
+
+ seen = []
+ @io.each_line('>', obj) { |s| seen << s }
+ seen.should == ["this>", "is>", "an>", "examp", "le"]
+ end
end
diff --git a/spec/ruby/library/stringio/each_spec.rb b/spec/ruby/library/stringio/each_spec.rb
index 7eb322f3ff..f3785bc18f 100644
--- a/spec/ruby/library/stringio/each_spec.rb
+++ b/spec/ruby/library/stringio/each_spec.rb
@@ -1,31 +1,8 @@
require_relative '../../spec_helper'
-require_relative 'fixtures/classes'
-require_relative 'shared/each'
+require 'stringio'
-describe "StringIO#each when passed a separator" do
- it_behaves_like :stringio_each_separator, :each
-end
-
-describe "StringIO#each when passed no arguments" do
- it_behaves_like :stringio_each_no_arguments, :each
-end
-
-describe "StringIO#each when self is not readable" do
- it_behaves_like :stringio_each_not_readable, :each
-end
-
-describe "StringIO#each when passed chomp" do
- it_behaves_like :stringio_each_chomp, :each
-end
-
-describe "StringIO#each when passed chomp" do
- it_behaves_like :stringio_each_separator_and_chomp, :each
-end
-
-describe "StringIO#each when passed limit" do
- it_behaves_like :stringio_each_limit, :each
-end
-
-describe "StringIO#each when passed separator and limit" do
- it_behaves_like :stringio_each_separator_and_limit, :each
+describe "StringIO#each" do
+ it "is an alias of StringIO#each_line" do
+ StringIO.instance_method(:each).should == StringIO.instance_method(:each_line)
+ end
end
diff --git a/spec/ruby/library/stringio/eof_spec.rb b/spec/ruby/library/stringio/eof_spec.rb
index af0170977c..acc49305f5 100644
--- a/spec/ruby/library/stringio/eof_spec.rb
+++ b/spec/ruby/library/stringio/eof_spec.rb
@@ -1,11 +1,33 @@
require_relative '../../spec_helper'
-require_relative 'fixtures/classes'
-require_relative 'shared/eof'
+require 'stringio'
describe "StringIO#eof?" do
- it_behaves_like :stringio_eof, :eof?
+ before :each do
+ @io = StringIO.new("eof")
+ end
+
+ it "returns true when self's position is greater than or equal to self's size" do
+ @io.pos = 3
+ @io.eof?.should == true
+
+ @io.pos = 6
+ @io.eof?.should == true
+ end
+
+ it "returns false when self's position is less than self's size" do
+ @io.pos = 0
+ @io.eof?.should == false
+
+ @io.pos = 1
+ @io.eof?.should == false
+
+ @io.pos = 2
+ @io.eof?.should == false
+ end
end
describe "StringIO#eof" do
- it_behaves_like :stringio_eof, :eof
+ it "is an alias of StringIO#eof?" do
+ StringIO.instance_method(:eof).should == StringIO.instance_method(:eof?)
+ end
end
diff --git a/spec/ruby/library/stringio/isatty_spec.rb b/spec/ruby/library/stringio/isatty_spec.rb
index 1ef33978b5..07743acc12 100644
--- a/spec/ruby/library/stringio/isatty_spec.rb
+++ b/spec/ruby/library/stringio/isatty_spec.rb
@@ -1,7 +1,8 @@
require_relative '../../spec_helper'
-require_relative 'fixtures/classes'
-require_relative 'shared/isatty'
+require 'stringio'
describe "StringIO#isatty" do
- it_behaves_like :stringio_isatty, :isatty
+ it "is an alias of StringIO#tty?" do
+ StringIO.instance_method(:isatty).should == StringIO.instance_method(:tty?)
+ end
end
diff --git a/spec/ruby/library/stringio/length_spec.rb b/spec/ruby/library/stringio/length_spec.rb
index d3070f50a7..a83be6256a 100644
--- a/spec/ruby/library/stringio/length_spec.rb
+++ b/spec/ruby/library/stringio/length_spec.rb
@@ -1,7 +1,8 @@
require_relative '../../spec_helper'
-require_relative 'fixtures/classes'
-require_relative 'shared/length'
+require 'stringio'
describe "StringIO#length" do
- it_behaves_like :stringio_length, :length
+ it "returns the length of the wrapped string" do
+ StringIO.new("example").length.should == 7
+ end
end
diff --git a/spec/ruby/library/stringio/pos_spec.rb b/spec/ruby/library/stringio/pos_spec.rb
index ba640f8c18..16f068b049 100644
--- a/spec/ruby/library/stringio/pos_spec.rb
+++ b/spec/ruby/library/stringio/pos_spec.rb
@@ -1,9 +1,17 @@
require_relative '../../spec_helper'
require_relative 'fixtures/classes'
-require_relative 'shared/tell'
describe "StringIO#pos" do
- it_behaves_like :stringio_tell, :pos
+ before :each do
+ @io = StringIOSpecs.build
+ end
+
+ it "returns the current byte offset" do
+ @io.getc
+ @io.pos.should == 1
+ @io.read(7)
+ @io.pos.should == 8
+ end
end
describe "StringIO#pos=" do
diff --git a/spec/ruby/library/stringio/shared/codepoints.rb b/spec/ruby/library/stringio/shared/codepoints.rb
deleted file mode 100644
index e35a02ccb4..0000000000
--- a/spec/ruby/library/stringio/shared/codepoints.rb
+++ /dev/null
@@ -1,45 +0,0 @@
-# -*- encoding: utf-8 -*-
-describe :stringio_codepoints, shared: true do
- before :each do
- @io = StringIO.new("∂φ/∂x = gaîté")
- @enum = @io.send(@method)
- end
-
- it "returns an Enumerator" do
- @enum.should.instance_of?(Enumerator)
- end
-
- it "yields each codepoint code in turn" do
- @enum.to_a.should == [8706, 966, 47, 8706, 120, 32, 61, 32, 103, 97, 238, 116, 233]
- end
-
- it "yields each codepoint starting from the current position" do
- @io.pos = 15
- @enum.to_a.should == [238, 116, 233]
- end
-
- it "raises an error if reading invalid sequence" do
- @io.pos = 1 # inside of a multibyte sequence
- -> { @enum.first }.should.raise(ArgumentError)
- end
-
- it "raises an IOError if not readable" do
- @io.close_read
- -> { @enum.to_a }.should.raise(IOError)
-
- io = StringIO.new(+"xyz", "w")
- -> { io.send(@method).to_a }.should.raise(IOError)
- end
-
-
- it "calls the given block" do
- r = []
- @io.send(@method){|c| r << c }
- r.should == [8706, 966, 47, 8706, 120, 32, 61, 32, 103, 97, 238, 116, 233]
- end
-
- it "returns self" do
- @io.send(@method) {|l| l }.should.equal?(@io)
- end
-
-end
diff --git a/spec/ruby/library/stringio/shared/each.rb b/spec/ruby/library/stringio/shared/each.rb
deleted file mode 100644
index 04e40b6b2a..0000000000
--- a/spec/ruby/library/stringio/shared/each.rb
+++ /dev/null
@@ -1,209 +0,0 @@
-describe :stringio_each_separator, shared: true do
- before :each do
- @io = StringIO.new("a b c d e\n1 2 3 4 5")
- end
-
- it "uses the passed argument as the line separator" do
- seen = []
- @io.send(@method, " ") {|s| seen << s}
- seen.should == ["a ", "b ", "c ", "d ", "e\n1 ", "2 ", "3 ", "4 ", "5"]
- end
-
- it "does not change $_" do
- $_ = "test"
- @io.send(@method, " ") { |s| s}
- $_.should == "test"
- end
-
- it "returns self" do
- @io.send(@method) {|l| l }.should.equal?(@io)
- end
-
- it "tries to convert the passed separator to a String using #to_str" do
- obj = mock("to_str")
- obj.stub!(:to_str).and_return(" ")
-
- seen = []
- @io.send(@method, obj) { |l| seen << l }
- seen.should == ["a ", "b ", "c ", "d ", "e\n1 ", "2 ", "3 ", "4 ", "5"]
- end
-
- it "yields self's content starting from the current position when the passed separator is nil" do
- seen = []
- io = StringIO.new("1 2 1 2 1 2")
- io.pos = 2
- io.send(@method, nil) {|s| seen << s}
- seen.should == ["2 1 2 1 2"]
- end
-
- it "yields each paragraph with all separation characters when passed an empty String as separator" do
- seen = []
- io = StringIO.new("para1\n\npara2\n\n\npara3")
- io.send(@method, "") {|s| seen << s}
- seen.should == ["para1\n\n", "para2\n\n\n", "para3"]
- end
-end
-
-describe :stringio_each_no_arguments, shared: true do
- before :each do
- @io = StringIO.new("a b c d e\n1 2 3 4 5")
- end
-
- it "yields each line to the passed block" do
- seen = []
- @io.send(@method) {|s| seen << s }
- seen.should == ["a b c d e\n", "1 2 3 4 5"]
- end
-
- it "yields each line starting from the current position" do
- seen = []
- @io.pos = 4
- @io.send(@method) {|s| seen << s }
- seen.should == ["c d e\n", "1 2 3 4 5"]
- end
-
- it "does not change $_" do
- $_ = "test"
- @io.send(@method) { |s| s}
- $_.should == "test"
- end
-
- it "uses $/ as the default line separator" do
- seen = []
- begin
- old_rs = $/
- suppress_warning {$/ = " "}
- @io.send(@method) {|s| seen << s }
- seen.should.eql?(["a ", "b ", "c ", "d ", "e\n1 ", "2 ", "3 ", "4 ", "5"])
- ensure
- suppress_warning {$/ = old_rs}
- end
- end
-
- it "returns self" do
- @io.send(@method) {|l| l }.should.equal?(@io)
- end
-
- it "returns an Enumerator when passed no block" do
- enum = @io.send(@method)
- enum.instance_of?(Enumerator).should == true
-
- seen = []
- enum.each { |b| seen << b }
- seen.should == ["a b c d e\n", "1 2 3 4 5"]
- end
-end
-
-describe :stringio_each_not_readable, shared: true do
- it "raises an IOError" do
- io = StringIO.new(+"a b c d e", "w")
- -> { io.send(@method) { |b| b } }.should.raise(IOError)
-
- io = StringIO.new("a b c d e")
- io.close_read
- -> { io.send(@method) { |b| b } }.should.raise(IOError)
- end
-end
-
-describe :stringio_each_chomp, shared: true do
- it "yields each line with removed newline characters to the passed block" do
- seen = []
- io = StringIO.new("a b \rc d e\n1 2 3 4 5\r\nthe end")
- io.send(@method, chomp: true) {|s| seen << s }
- seen.should == ["a b \rc d e", "1 2 3 4 5", "the end"]
- end
-
- it "returns each line with removed newline characters when called without block" do
- seen = []
- io = StringIO.new("a b \rc d e\n1 2 3 4 5\r\nthe end")
- enum = io.send(@method, chomp: true)
- enum.each {|s| seen << s }
- seen.should == ["a b \rc d e", "1 2 3 4 5", "the end"]
- end
-end
-
-describe :stringio_each_separator_and_chomp, shared: true do
- it "yields each line with removed separator to the passed block" do
- seen = []
- io = StringIO.new("a b \nc d e|1 2 3 4 5\n|the end")
- io.send(@method, "|", chomp: true) {|s| seen << s }
- seen.should == ["a b \nc d e", "1 2 3 4 5\n", "the end"]
- end
-
- it "returns each line with removed separator when called without block" do
- seen = []
- io = StringIO.new("a b \nc d e|1 2 3 4 5\n|the end")
- enum = io.send(@method, "|", chomp: true)
- enum.each {|s| seen << s }
- seen.should == ["a b \nc d e", "1 2 3 4 5\n", "the end"]
- end
-end
-
-describe :stringio_each_limit, shared: true do
- before :each do
- @io = StringIO.new("a b c d e\n1 2 3 4 5")
- end
-
- it "returns the data read until the limit is met" do
- seen = []
- @io.send(@method, 4) { |s| seen << s }
- seen.should == ["a b ", "c d ", "e\n", "1 2 ", "3 4 ", "5"]
- end
-end
-
-describe :stringio_each_separator_and_limit, shared: true do
- before :each do
- @io = StringIO.new("this>is>an>example")
- end
-
- it "returns the data read until the limit is consumed or the separator is met" do
- @io.send(@method, '>', 8) { |s| break s }.should == "this>"
- @io.send(@method, '>', 2) { |s| break s }.should == "is"
- @io.send(@method, '>', 10) { |s| break s }.should == ">"
- @io.send(@method, '>', 6) { |s| break s }.should == "an>"
- @io.send(@method, '>', 5) { |s| break s }.should == "examp"
- end
-
- it "truncates the multi-character separator at the end to meet the limit" do
- @io.send(@method, "is>an", 7) { |s| break s }.should == "this>is"
- end
-
- it "does not change $_" do
- $_ = "test"
- @io.send(@method, '>', 8) { |s| s }
- $_.should == "test"
- end
-
- it "updates self's lineno by one" do
- @io.send(@method, '>', 3) { |s| break s }
- @io.lineno.should.eql?(1)
-
- @io.send(@method, '>', 3) { |s| break s }
- @io.lineno.should.eql?(2)
-
- @io.send(@method, '>', 3) { |s| break s }
- @io.lineno.should.eql?(3)
- end
-
- it "tries to convert the passed separator to a String using #to_str" do # TODO
- obj = mock('to_str')
- obj.should_receive(:to_str).and_return('>')
-
- seen = []
- @io.send(@method, obj, 5) { |s| seen << s }
- seen.should == ["this>", "is>", "an>", "examp", "le"]
- end
-
- it "does not raise TypeError if passed separator is nil" do
- @io.send(@method, nil, 5) { |s| break s }.should == "this>"
- end
-
- it "tries to convert the passed limit to an Integer using #to_int" do # TODO
- obj = mock('to_int')
- obj.should_receive(:to_int).and_return(5)
-
- seen = []
- @io.send(@method, '>', obj) { |s| seen << s }
- seen.should == ["this>", "is>", "an>", "examp", "le"]
- end
-end
diff --git a/spec/ruby/library/stringio/shared/each_byte.rb b/spec/ruby/library/stringio/shared/each_byte.rb
deleted file mode 100644
index b3939c26de..0000000000
--- a/spec/ruby/library/stringio/shared/each_byte.rb
+++ /dev/null
@@ -1,48 +0,0 @@
-describe :stringio_each_byte, shared: true do
- before :each do
- @io = StringIO.new("xyz")
- end
-
- it "yields each character code in turn" do
- seen = []
- @io.send(@method) { |b| seen << b }
- seen.should == [120, 121, 122]
- end
-
- it "updates the position before each yield" do
- seen = []
- @io.send(@method) { |b| seen << @io.pos }
- seen.should == [1, 2, 3]
- end
-
- it "does not yield if the current position is out of bounds" do
- @io.pos = 1000
- seen = nil
- @io.send(@method) { |b| seen = b }
- seen.should == nil
- end
-
- it "returns self" do
- @io.send(@method) {}.should.equal?(@io)
- end
-
- it "returns an Enumerator when passed no block" do
- enum = @io.send(@method)
- enum.instance_of?(Enumerator).should == true
-
- seen = []
- enum.each { |b| seen << b }
- seen.should == [120, 121, 122]
- end
-end
-
-describe :stringio_each_byte_not_readable, shared: true do
- it "raises an IOError" do
- io = StringIO.new(+"xyz", "w")
- -> { io.send(@method) { |b| b } }.should.raise(IOError)
-
- io = StringIO.new("xyz")
- io.close_read
- -> { io.send(@method) { |b| b } }.should.raise(IOError)
- end
-end
diff --git a/spec/ruby/library/stringio/shared/each_char.rb b/spec/ruby/library/stringio/shared/each_char.rb
deleted file mode 100644
index 4215a9952b..0000000000
--- a/spec/ruby/library/stringio/shared/each_char.rb
+++ /dev/null
@@ -1,36 +0,0 @@
-# -*- encoding: utf-8 -*-
-describe :stringio_each_char, shared: true do
- before :each do
- @io = StringIO.new("xyz äöü")
- end
-
- it "yields each character code in turn" do
- seen = []
- @io.send(@method) { |c| seen << c }
- seen.should == ["x", "y", "z", " ", "ä", "ö", "ü"]
- end
-
- it "returns self" do
- @io.send(@method) {}.should.equal?(@io)
- end
-
- it "returns an Enumerator when passed no block" do
- enum = @io.send(@method)
- enum.instance_of?(Enumerator).should == true
-
- seen = []
- enum.each { |c| seen << c }
- seen.should == ["x", "y", "z", " ", "ä", "ö", "ü"]
- end
-end
-
-describe :stringio_each_char_not_readable, shared: true do
- it "raises an IOError" do
- io = StringIO.new(+"xyz", "w")
- -> { io.send(@method) { |b| b } }.should.raise(IOError)
-
- io = StringIO.new("xyz")
- io.close_read
- -> { io.send(@method) { |b| b } }.should.raise(IOError)
- end
-end
diff --git a/spec/ruby/library/stringio/shared/eof.rb b/spec/ruby/library/stringio/shared/eof.rb
deleted file mode 100644
index a9489581fc..0000000000
--- a/spec/ruby/library/stringio/shared/eof.rb
+++ /dev/null
@@ -1,24 +0,0 @@
-describe :stringio_eof, shared: true do
- before :each do
- @io = StringIO.new("eof")
- end
-
- it "returns true when self's position is greater than or equal to self's size" do
- @io.pos = 3
- @io.send(@method).should == true
-
- @io.pos = 6
- @io.send(@method).should == true
- end
-
- it "returns false when self's position is less than self's size" do
- @io.pos = 0
- @io.send(@method).should == false
-
- @io.pos = 1
- @io.send(@method).should == false
-
- @io.pos = 2
- @io.send(@method).should == false
- end
-end
diff --git a/spec/ruby/library/stringio/shared/isatty.rb b/spec/ruby/library/stringio/shared/isatty.rb
deleted file mode 100644
index 2b92e8d656..0000000000
--- a/spec/ruby/library/stringio/shared/isatty.rb
+++ /dev/null
@@ -1,5 +0,0 @@
-describe :stringio_isatty, shared: true do
- it "returns false" do
- StringIO.new("tty").send(@method).should == false
- end
-end
diff --git a/spec/ruby/library/stringio/shared/length.rb b/spec/ruby/library/stringio/shared/length.rb
deleted file mode 100644
index 60a4eb1bdd..0000000000
--- a/spec/ruby/library/stringio/shared/length.rb
+++ /dev/null
@@ -1,5 +0,0 @@
-describe :stringio_length, shared: true do
- it "returns the length of the wrapped string" do
- StringIO.new("example").send(@method).should == 7
- end
-end
diff --git a/spec/ruby/library/stringio/shared/tell.rb b/spec/ruby/library/stringio/shared/tell.rb
deleted file mode 100644
index 852c51c192..0000000000
--- a/spec/ruby/library/stringio/shared/tell.rb
+++ /dev/null
@@ -1,12 +0,0 @@
-describe :stringio_tell, shared: true do
- before :each do
- @io = StringIOSpecs.build
- end
-
- it "returns the current byte offset" do
- @io.getc
- @io.send(@method).should == 1
- @io.read(7)
- @io.send(@method).should == 8
- end
-end
diff --git a/spec/ruby/library/stringio/size_spec.rb b/spec/ruby/library/stringio/size_spec.rb
index f674d22db9..33e574ddae 100644
--- a/spec/ruby/library/stringio/size_spec.rb
+++ b/spec/ruby/library/stringio/size_spec.rb
@@ -1,7 +1,8 @@
require_relative '../../spec_helper'
-require_relative 'fixtures/classes'
-require_relative 'shared/length'
+require 'stringio'
describe "StringIO#size" do
- it_behaves_like :stringio_length, :size
+ it "is an alias of StringIO#length" do
+ StringIO.instance_method(:size).should == StringIO.instance_method(:length)
+ end
end
diff --git a/spec/ruby/library/stringio/tell_spec.rb b/spec/ruby/library/stringio/tell_spec.rb
index 8350ee6f4d..80095999e9 100644
--- a/spec/ruby/library/stringio/tell_spec.rb
+++ b/spec/ruby/library/stringio/tell_spec.rb
@@ -1,7 +1,8 @@
require_relative '../../spec_helper'
-require_relative 'fixtures/classes'
-require_relative 'shared/tell'
+require 'stringio'
describe "StringIO#tell" do
- it_behaves_like :stringio_tell, :tell
+ it "is an alias of StringIO#pos" do
+ StringIO.instance_method(:tell).should == StringIO.instance_method(:pos)
+ end
end
diff --git a/spec/ruby/library/stringio/tty_spec.rb b/spec/ruby/library/stringio/tty_spec.rb
index c6293dcbd7..87e22d49a5 100644
--- a/spec/ruby/library/stringio/tty_spec.rb
+++ b/spec/ruby/library/stringio/tty_spec.rb
@@ -1,7 +1,8 @@
require_relative '../../spec_helper'
-require_relative 'fixtures/classes'
-require_relative 'shared/isatty'
+require 'stringio'
describe "StringIO#tty?" do
- it_behaves_like :stringio_isatty, :tty?
+ it "returns false" do
+ StringIO.new("tty").tty?.should == false
+ end
end