Sha256: 07fb74c71f652f1057d80553096b23f596aa131f6ab97b1bf27b5f893b7da811

Contents?: true

Size: 1.6 KB

Versions: 9

Compression:

Stored size: 1.6 KB

Contents

# frozen_string_literal: true

require 'test_helper'

module Vedeu

  module Logging

    describe Debug do

      let(:described) { Vedeu::Logging::Debug }

      before do
        File.stubs(:open).with('/tmp/vedeu_profile', 'w').returns(:some_code)
      end

      describe '.debug' do
        let(:_binding) {}
        let(:_obj)     {}

        subject { described.debug(_binding, _obj) }

        context 'when pry is available' do
          # @todo Add more tests.
        end

        context 'when pry is not available' do
          before { Vedeu.stubs(:requires_gem!).raises(Vedeu::Error::Fatal) }

          it { proc { subject }.must_raise(Vedeu::Error::Fatal) }
        end
      end

      describe '.profile' do
        let(:filename)  { 'vedeu_profile' }
        let(:some_code) { :some_code }

        subject { described.profile(filename) { some_code } }

        context 'when ruby-prof is available' do
          before { Vedeu.stubs(:requires_gem!).returns(true) }

          context 'when the block is not given' do
            subject { described.profile(filename) }

            it { proc { subject }.must_raise(Vedeu::Error::RequiresBlock) }
          end

          context 'when the block is given' do
            subject { described.profile(filename) { some_code } }

            it { subject.must_equal(some_code) }
          end
        end

        context 'when ruby-prof is not available' do
          before { Vedeu.stubs(:requires_gem!).raises(Vedeu::Error::Fatal) }

          it { proc { subject }.must_raise(Vedeu::Error::Fatal) }
        end
      end

    end # Debug

  end # Logging

end # Vedeu

Version data entries

9 entries across 9 versions & 1 rubygems

Version Path
vedeu-0.8.21 test/lib/vedeu/logging/debug_test.rb
vedeu-0.8.20 test/lib/vedeu/logging/debug_test.rb
vedeu-0.8.19 test/lib/vedeu/logging/debug_test.rb
vedeu-0.8.18 test/lib/vedeu/logging/debug_test.rb
vedeu-0.8.17 test/lib/vedeu/logging/debug_test.rb
vedeu-0.8.16 test/lib/vedeu/logging/debug_test.rb
vedeu-0.8.15 test/lib/vedeu/logging/debug_test.rb
vedeu-0.8.14 test/lib/vedeu/logging/debug_test.rb
vedeu-0.8.13 test/lib/vedeu/logging/debug_test.rb