/
output_to_fd_spec.rb
33 lines (28 loc) · 1.38 KB
/
output_to_fd_spec.rb
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
require 'spec_helper'
require 'mspec/expectations/expectations'
require 'mspec/matchers'
describe OutputToFDMatcher do
# Figure out how in the hell to achieve this
it "matches when running the block produces the expected output to the given FD" do
output_to_fd("Hi\n", STDERR).matches?(lambda { $stderr.print "Hi\n" }).should == true
end
it "does not match if running the block does not produce the expected output to the FD" do
output_to_fd("Hi\n", STDERR).matches?(lambda { $stderr.puts("Hello\n") }).should == false
end
it "defaults to matching against STDOUT" do
output_to_fd("Hi\n").matches?(lambda { $stdout.print "Hi\n" }).should == true
end
it "accepts any IO instance" do
io = IO.new STDOUT.fileno
output_to_fd("Hi\n", io).matches?(lambda { io.print "Hi\n" }).should == true
end
it "allows matching with a Regexp" do
s = "Hi there\n"
output_to_fd(/Hi/, STDERR).matches?(lambda { $stderr.print s }).should == true
output_to_fd(/Hi?/, STDERR).matches?(lambda { $stderr.print s }).should == true
output_to_fd(/[hH]i?/, STDERR).matches?(lambda { $stderr.print s }).should == true
output_to_fd(/.*/, STDERR).matches?(lambda { $stderr.print s }).should == true
output_to_fd(/H.*?here/, STDERR).matches?(lambda { $stderr.print s }).should == true
output_to_fd(/Ahoy/, STDERR).matches?(lambda { $stderr.print s }).should == false
end
end