aboutsummaryrefslogtreecommitdiffstats
path: root/test/rubygems/test_deprecate.rb
blob: fab4f33b860b77d246c6b4381ddca05930acb95a (plain)
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
# frozen_string_literal: true
require 'rubygems/test_case'
# require 'rubygems/builder'
# require 'rubygems/package'
require 'rubygems/deprecate'

class TestDeprecate < Gem::TestCase

  def setup
    super

    # Gem::Deprecate.saved_warnings.clear
    @original_skip = Gem::Deprecate.skip
    Gem::Deprecate.skip = false
  end

  def teardown
    super

    # Gem::Deprecate.saved_warnings.clear
    Gem::Deprecate.skip = @original_skip
  end

  def test_defaults
    assert_equal false, @original_skip
  end

  def test_assignment
    Gem::Deprecate.skip = false
    assert_equal false, Gem::Deprecate.skip

    Gem::Deprecate.skip = true
    assert_equal true, Gem::Deprecate.skip

    Gem::Deprecate.skip = nil
    assert([true,false].include? Gem::Deprecate.skip)
  end

  def test_skip
    Gem::Deprecate.skip_during do
      assert_equal true, Gem::Deprecate.skip
    end

    Gem::Deprecate.skip = nil
  end

  class Thing
    extend Gem::Deprecate
    attr_accessor :message
    def foo
      @message = "foo"
    end
    def bar
      @message = "bar"
    end
    deprecate :foo, :bar, 2099, 3
  end

  def test_deprecated_method_calls_the_old_method
    capture_io do
      thing = Thing.new
      thing.foo
      assert_equal "foo", thing.message
    end
  end

  def test_deprecated_method_outputs_a_warning
    out, err = capture_io do
      thing = Thing.new
      thing.foo
    end

    assert_equal "", out
    assert_match(/Thing#foo is deprecated; use bar instead\./, err)
    assert_match(/on or after 2099-03-01/, err)
  end
end