Sha256: 1aff91f161bc14490cff6da1099e56483ae7b8560c9f50c23724a433c7813c1f

Contents?: true

Size: 1.91 KB

Versions: 8

Compression:

Stored size: 1.91 KB

Contents

Feature: deprecation_stream

  Define a custom output stream for warning about deprecations (default `$stderr`).

    RSpec.configure {|c| c.deprecation_stream = File.open('deprecations.txt', 'w') }

  or

    RSpec.configure {|c| c.deprecation_stream = 'deprecations.txt' }

  Background:
    Given a file named "lib/foo.rb" with:
      """ruby
      class Foo
        def bar
          RSpec.deprecate "Foo#bar"
        end
      end
      """

  Scenario: default - print deprecations to $stderr
    Given a file named "spec/example_spec.rb" with:
      """ruby
      require "foo"
      describe "calling a deprecated method" do
        example { Foo.new.bar }
      end
      """
    When I run `rspec spec/example_spec.rb`
    Then the output should contain "Deprecation Warnings:\n\nFoo#bar is deprecated"

  Scenario: configure using the path to a file
    Given a file named "spec/example_spec.rb" with:
      """ruby
      require "foo"
      RSpec.configure {|c| c.deprecation_stream = 'deprecations.txt' }
      describe "calling a deprecated method" do
        example { Foo.new.bar }
      end
      """
    When I run `rspec spec/example_spec.rb`
    Then the output should not contain "Deprecation Warnings:"
    But the output should contain "1 deprecation logged to deprecations.txt"
    And the file "deprecations.txt" should contain "Foo#bar is deprecated"

  Scenario: configure using a File object
    Given a file named "spec/example_spec.rb" with:
      """ruby
      require "foo"
      RSpec.configure {|c| c.deprecation_stream = File.open('deprecations.txt', 'w') }
      describe "calling a deprecated method" do
        example { Foo.new.bar }
      end
      """
    When I run `rspec spec/example_spec.rb`
    Then the output should not contain "Deprecation Warnings:"
    But the output should contain "1 deprecation logged to deprecations.txt"
    And the file "deprecations.txt" should contain "Foo#bar is deprecated"

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
rspec-core-2.99.2 features/configuration/deprecation_stream.feature
rspec-core-2.99.1 features/configuration/deprecation_stream.feature
rspec-core-2.99.0 features/configuration/deprecation_stream.feature
rspec-core-2.99.0.rc1 features/configuration/deprecation_stream.feature
rspec-core-3.0.0.beta2 features/configuration/deprecation_stream.feature
rspec-core-2.99.0.beta2 features/configuration/deprecation_stream.feature
rspec-core-3.0.0.beta1 features/configuration/deprecation_stream.feature
rspec-core-2.99.0.beta1 features/configuration/deprecation_stream.feature