waiter_spec.rb 1003 Bytes
Newer Older
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 34 35 36 37
# frozen_string_literal: true

require 'logger'

describe QA::Support::Waiter do
  before do
    logger = ::Logger.new $stdout
    logger.level = ::Logger::DEBUG
    QA::Runtime::Logger.logger = logger
  end

  describe '.wait' do
    context 'when the condition is true' do
      it 'logs the start' do
        expect { subject.wait(max: 0) {} }
        .to output(/with wait: max 0; interval 0.1/).to_stdout_from_any_process
      end

      it 'logs the end' do
        expect { subject.wait(max: 0) {} }
        .to output(/ended wait after .* seconds$/).to_stdout_from_any_process
      end
    end

    context 'when the condition is false' do
      it 'logs the start' do
        expect { subject.wait(max: 0) { false } }
        .to output(/with wait: max 0; interval 0.1/).to_stdout_from_any_process
      end

      it 'logs the end' do
        expect { subject.wait(max: 0) { false } }
        .to output(/ended wait after .* seconds$/).to_stdout_from_any_process
      end
    end
  end
end