Sha256: 327e3bf4a219dcb795b1072fc5be96647d370c63a5c9c814da346eefdf6e0237

Contents?: true

Size: 1.22 KB

Versions: 9

Compression:

Stored size: 1.22 KB

Contents

# encoding: utf-8

class Nanoc::CLI::CleaningStreamTest < Nanoc::TestCase

  class Stream

    attr_accessor :called_methods

    def initialize
      @called_methods = Set.new
    end

    def method_missing(symbol, *args)
      @called_methods << symbol
    end

  end

  def test_forward
    methods = [ :write, :<<, :tty?, :flush, :tell, :print, :puts, :string, :reopen, :exist?, :exists?, :close ]

    s = Stream.new
    cs = Nanoc::CLI::CleaningStream.new(s)

    cs.write('aaa')
    cs << 'bb'
    cs.tty?
    cs.flush
    cs.tell
    cs.print('cc')
    cs.puts('dd')
    cs.string
    cs.reopen('/dev/null', 'r')
    cs.exist?
    cs.exists?
    cs.close

    methods.each do |m|
      assert s.called_methods.include?(m), "expected #{m} to be called"
    end
  end

  def test_works_with_logger
    require 'logger'
    stream = StringIO.new
    cleaning_stream = Nanoc::CLI::CleaningStream.new(stream)
    logger = Logger.new(cleaning_stream)
    logger.info("Some info")
    logger.warn("Something could start going wrong!")
  end

  def test_broken_pipe
    stream = StringIO.new
    def stream.write(s) ; raise Errno::EPIPE.new ; end

    cleaning_stream = Nanoc::CLI::CleaningStream.new(stream)
    cleaning_stream.write('lol')
  end

end

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
nanoc-3.7.3 test/cli/test_cleaning_stream.rb
nanoc-3.7.2 test/cli/test_cleaning_stream.rb
nanoc-3.7.1 test/cli/test_cleaning_stream.rb
nanoc-3.7.0 test/cli/test_cleaning_stream.rb
nanoc-3.6.11 test/cli/test_cleaning_stream.rb
nanoc-3.6.10 test/cli/test_cleaning_stream.rb
nanoc-3.6.9 test/cli/test_cleaning_stream.rb
nanoc-3.6.8 test/cli/test_cleaning_stream.rb
nanoc-3.6.7 test/cli/test_cleaning_stream.rb