1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
ruby--ruby/spec/rubyspec/core/kernel/open_spec.rb
eregon 95e8c48dd3 Add in-tree mspec and ruby/spec
* For easier modifications of ruby/spec by MRI developers.
* .gitignore: track changes under spec.
* spec/mspec, spec/rubyspec: add in-tree mspec and ruby/spec.
  These files can therefore be updated like any other file in MRI.
  Instructions are provided in spec/README.
  [Feature #13156] [ruby-core:79246]

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@58595 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2017-05-07 12:04:49 +00:00

141 lines
3.5 KiB
Ruby

require File.expand_path('../../../spec_helper', __FILE__)
require File.expand_path('../fixtures/classes', __FILE__)
describe "Kernel#open" do
before :each do
@name = tmp("kernel_open.txt")
@content = "This is a test"
touch(@name) { |f| f.write @content }
@file = nil
end
after :each do
@file.close if @file
rm_r @name
end
it "is a private method" do
Kernel.should have_private_instance_method(:open)
end
it "opens a file when given a valid filename" do
@file = open(@name)
@file.should be_kind_of(File)
end
it "opens a file when called with a block" do
open(@name, "r") { |f| f.gets }.should == @content
end
platform_is_not :windows do
it "opens an io when path starts with a pipe" do
@io = open("|date")
begin
@io.should be_kind_of(IO)
ensure
@io.close
end
end
it "opens an io when called with a block" do
@output = open("|date") { |f| f.gets }
@output.should_not == ''
end
it "opens an io for writing" do
bytes = open("|cat", "w") { |io| io.write(".") }
bytes.should == 1
end
end
platform_is :windows do
it "opens an io when path starts with a pipe" do
@io = open("|date /t")
begin
@io.should be_kind_of(IO)
@io.read
ensure
@io.close
end
end
it "opens an io when called with a block" do
@output = open("|date /t") { |f| f.gets }
@output.should_not == ''
end
end
it "raises an ArgumentError if not passed one argument" do
lambda { open }.should raise_error(ArgumentError)
end
describe "when given an object that responds to to_open" do
before :each do
ScratchPad.clear
end
it "calls #to_path to covert the argument to a String before calling #to_str" do
obj = mock("open to_path")
obj.should_receive(:to_path).at_least(1).times.and_return(@name)
obj.should_not_receive(:to_str)
open(obj, "r") { |f| f.gets }.should == @content
end
it "calls #to_str to convert the argument to a String" do
obj = mock("open to_str")
obj.should_receive(:to_str).at_least(1).times.and_return(@name)
open(obj, "r") { |f| f.gets }.should == @content
end
it "calls #to_open on argument" do
obj = mock('fileish')
@file = File.open(@name)
obj.should_receive(:to_open).and_return(@file)
@file = open(obj)
@file.should be_kind_of(File)
end
it "returns the value from #to_open" do
obj = mock('to_open')
obj.should_receive(:to_open).and_return(:value)
open(obj).should == :value
end
it "passes its arguments onto #to_open" do
obj = mock('to_open')
obj.should_receive(:to_open).with(1,2,3)
open(obj, 1, 2, 3)
end
it "passes the return value from #to_open to a block" do
obj = mock('to_open')
obj.should_receive(:to_open).and_return(:value)
open(obj) do |mock|
ScratchPad.record(mock)
end
ScratchPad.recorded.should == :value
end
end
it "raises a TypeError if passed a non-String that does not respond to #to_open" do
obj = mock('non-fileish')
lambda { open(obj) }.should raise_error(TypeError)
lambda { open(nil) }.should raise_error(TypeError)
lambda { open(7) }.should raise_error(TypeError)
end
it "accepts nil for mode and permission" do
open(@name, nil, nil) { |f| f.gets }.should == @content
end
end
describe "Kernel.open" do
it "needs to be reviewed for spec completeness"
end