File: error_generator_spec.rb

package info (click to toggle)
ruby-rspec 3.5.0c3e0m0s0-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 6,312 kB
  • ctags: 4,788
  • sloc: ruby: 62,572; sh: 785; makefile: 100
file content (89 lines) | stat: -rw-r--r-- 2,857 bytes parent folder | download | duplicates (6)
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
require "spec_helper"

module RSpec
  module Mocks
    RSpec.describe ErrorGenerator do
      context "when inserting a backtrace line" do
        def has_java_frames?
          yield
        rescue RSpec::Mocks::MockExpectationError => e
          e.backtrace.grep(/\.java:/).any?
        else
          raise "got no exception"
        end

        it "produces stacktraces that match how `raise` produces stacktraces (on JRuby `caller` and `raise` can differ about the presence of java frames)" do
          raise_has_java_frames = has_java_frames? { raise RSpec::Mocks::MockExpectationError }

          eg_has_java_frames = has_java_frames? do
            ErrorGenerator.new.send(:__raise, "message", "foo.rb:1")
          end

          expect(raise_has_java_frames).to eq eg_has_java_frames
        end
      end

      def unexpected_failure_message_for(object_description)
        /received unexpected message :bees with \(#{object_description}\)/
      end

      describe "formatting arguments" do
        it 'formats time objects with increased precision' do
          time = Time.utc(1969, 12, 31, 19, 01, 40, 101)
          expected_output = "1969-12-31 19:01:40.000101"

          o = double(:double)
          expect {
            o.bees(time)
          }.to fail_including(expected_output)
        end

        context "on non-matcher objects that define #description" do
          it "does not use the object's description" do
            o = double(:double, :description => "Friends")
            expect {
              o.bees(o)
            }.to fail_with(unexpected_failure_message_for(o.inspect))
          end
        end

        context "on matcher objects" do
          context "that define description" do
            it "uses the object's description" do
              d = double(:double)
              o = fake_matcher(Object.new)
              expect {
                d.bees(o)
              }.to raise_error(unexpected_failure_message_for(o.description))
            end
          end

          context "that do not define description" do
            it "does not use the object's description" do
              d = double(:double)
              o = Class.new do
                def self.name
                  "RSpec::Mocks::ArgumentMatchers::"
                end
              end.new

              expect(RSpec::Support.is_a_matcher?(o)).to be true

              expect {
                d.bees(o)
              }.to fail_with(unexpected_failure_message_for(o.inspect))
            end
          end

          context "on default method stub" do
            it "error message display starts in new line" do
              d = double(:double)
              allow(d).to receive(:foo).with({})
              expect { d.foo([]) }.to fail_with(/\nDiff/)
            end
          end
        end
      end
    end
  end
end