summaryrefslogtreecommitdiff
path: root/spec/ruby/core/module/ancestors_spec.rb
blob: 90c26941d14a1b6db0094bfed8432b7108bd8759 (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
78
79
80
81
82
83
84
85
86
87
88
require_relative '../../spec_helper'
require_relative 'fixtures/classes'

describe "Module#ancestors" do
  it "returns a list of modules included in self (including self)" do
    BasicObject.ancestors.should == [BasicObject]
    ModuleSpecs.ancestors.should == [ModuleSpecs]
    ModuleSpecs::Basic.ancestors.should == [ModuleSpecs::Basic]
    ModuleSpecs::Super.ancestors.should == [ModuleSpecs::Super, ModuleSpecs::Basic]
    if defined?(Ruby::Box) && Ruby::Box.enabled?
      ModuleSpecs.without_test_modules(ModuleSpecs::Parent.ancestors).should ==
        [ModuleSpecs::Parent, Object, Ruby::Box::Loader, Kernel, BasicObject]
      ModuleSpecs.without_test_modules(ModuleSpecs::Child.ancestors).should ==
        [ModuleSpecs::Child, ModuleSpecs::Super, ModuleSpecs::Basic, ModuleSpecs::Parent, Object, Ruby::Box::Loader, Kernel, BasicObject]
    else
      ModuleSpecs.without_test_modules(ModuleSpecs::Parent.ancestors).should ==
        [ModuleSpecs::Parent, Object, Kernel, BasicObject]
      ModuleSpecs.without_test_modules(ModuleSpecs::Child.ancestors).should ==
        [ModuleSpecs::Child, ModuleSpecs::Super, ModuleSpecs::Basic, ModuleSpecs::Parent, Object, Kernel, BasicObject]
    end
  end

  it "returns only modules and classes" do
    class << ModuleSpecs::Child; self; end.ancestors.should include(ModuleSpecs::Internal, Class, Module, Object, Kernel)
  end

  it "has 1 entry per module or class" do
    ModuleSpecs::Parent.ancestors.should == ModuleSpecs::Parent.ancestors.uniq
  end

  it "returns a module that is included later into a nested module as well" do
    m1 = Module.new
    m2 = Module.new
    m3 = Module.new do
      include m2
    end
    m2.include m1 # should be after m3 includes m2

    m3.ancestors.should == [m3, m2, m1]
  end

  describe "when called on a singleton class" do
    it "includes the singleton classes of ancestors" do
      parent  = Class.new
      child   = Class.new(parent)
      schild  = child.singleton_class

      schild.ancestors.should include(schild,
                                      parent.singleton_class,
                                      Object.singleton_class,
                                      BasicObject.singleton_class,
                                      Class,
                                      Module,
                                      Object,
                                      Kernel,
                                      BasicObject)

    end

    describe 'for a standalone module' do
      it 'does not include Class' do
        s_mod = ModuleSpecs.singleton_class
        s_mod.ancestors.should_not include(Class)
      end

      it 'does not include other singleton classes' do
        s_standalone_mod = ModuleSpecs.singleton_class
        s_module = Module.singleton_class
        s_object = Object.singleton_class
        s_basic_object = BasicObject.singleton_class

        s_standalone_mod.ancestors.should_not include(s_module, s_object, s_basic_object)
      end

      it 'includes its own singleton class' do
        s_mod = ModuleSpecs.singleton_class

        s_mod.ancestors.should include(s_mod)
      end

      it 'includes standard chain' do
        s_mod = ModuleSpecs.singleton_class

        s_mod.ancestors.should include(Module, Object, Kernel, BasicObject)
      end
    end
  end
end