molybdenum-99/infoboxer

View on GitHub
spec/infoboxer/tree/nodes_spec.rb

Summary

Maintainability
A
1 hr
Test Coverage
module Infoboxer
  module Tree
    describe Nodes do
      describe :inspect do
        subject { nodes.inspect }

        context 'by default' do
          let(:nodes) { Nodes[Text.new('some text')] }

          it { is_expected.to eq '[#<Text: some text>]' }
        end

        context 'really long children list' do
          let(:children) { Array.new(20) { Text.new('some text') } }
          let(:nodes) { Nodes[*children] }

          it { is_expected.to eq '[#<Text: some text>, #<Text: some text>, #<Text: some text>, #<Text: some text>, #<Text: some text>, ...15 more nodes]' }
        end
      end

      describe 'as Enumerable' do
        let(:nodes) { Nodes[Text.new('one'), Text.new('two')] }

        it 'should be nodes always' do
          expect(nodes.select { |n| n.text == 'one' }).to be_a(Nodes)
          expect(nodes.reject { |n| n.text == 'one' }).to be_a(Nodes)
          expect(nodes.sort_by(&:text)).to be_a(Nodes)
        end

        it 'is smart when mapping' do
          expect(nodes.map { |n| n }).to be_a(Nodes)
          expect(nodes.map(&:text)).to be_an(Array)
        end
      end

      describe :strip do
        context 'last empty texts' do
          subject { Nodes[Text.new('test'), Text.new(' ')] }

          its(:strip) { is_expected.to eq Nodes[Text.new('test')] }
        end

        context 'spaces in last text' do
          subject { Nodes[Text.new('test ')] }

          its(:strip) { is_expected.to eq Nodes[Text.new('test')] }
        end
      end

      describe :<< do
        describe 'merging' do
          context 'text' do
            context 'when previous was text' do
              subject { Nodes[Text.new('test')] }

              before {
                subject << Text.new(' me')
              }
              it { is_expected.to eq [Text.new('test me')] }
            end

            context 'when previous was not a text' do
              subject { Nodes[Italic.new(Text.new('test'))] }

              before {
                subject << Text.new(' me')
              }
              it { is_expected.to eq [Italic.new(Text.new('test')), Text.new(' me')] }
            end

            context 'when its first text' do
              subject { Nodes[] }

              before {
                subject << 'test'
              }
              it { is_expected.to eq [Text.new('test')] }
            end
          end

          context 'paragraphs' do
            context 'when can merge' do
              subject { Nodes[Paragraph.new(Text.new('test'))] }

              before {
                subject << Paragraph.new(Text.new('me'))
              }
              it { is_expected.to eq [Paragraph.new(Text.new('test me'))] }
            end

            context 'when can\'t merge' do
              subject { Nodes[Paragraph.new(Text.new('test'))] }

              before {
                subject << Pre.new(Text.new('me'))
              }
              it { is_expected.to eq [Paragraph.new(Text.new('test')), Pre.new(Text.new('me'))] }
            end

            context 'children\'s #parent rewriting' do
              let(:para) { Nodes[Paragraph.new(Text.new('test'))] }

              before {
                para << Paragraph.new([Text.new('me, '), Italic.new(Text.new('please'))])
              }
              subject { para.lookup(:Italic).first }

              its(:parent) { is_expected.to eq para.first }
            end
          end
        end

        describe 'empty paragraphs dropping' do
          context 'into paragraph' do
            subject { Nodes[Paragraph.new(Text.new('test'))] }

            before {
              subject << EmptyParagraph.new(' ')
            }
            it { is_expected.to eq [Paragraph.new(Text.new('test'))] }
            its(:last) { is_expected.to be_closed }
          end

          context 'into pre' do
            subject { Nodes[Pre.new(Text.new('test'))] }

            before {
              subject << EmptyParagraph.new('   ')
            }
            it { is_expected.to eq [Pre.new(Text.new("test\n  "))] }
            its(:last) { is_expected.not_to be_closed }
          end

          context 'into pre -- really empty' do
            subject { Nodes[Pre.new(Text.new('test'))] }

            before {
              subject << EmptyParagraph.new('')
            }
            it { is_expected.to eq [Pre.new(Text.new('test'))] }
            its(:last) { is_expected.to be_closed }
          end
        end

        describe 'implicit flatten' do
          subject { Nodes[Text.new('test')] }

          before {
            subject << [Text.new(' me')]
          }
          it { is_expected.to eq [Text.new('test me')] }
        end

        xdescribe 'flowing-in templates' do
          let(:nodes) {
            Nodes[Paragraph.new(
              [Text.new(' '),
               Template.new('one'),
               Text.new("\n"),
               Template.new('two')]
            ),
            ]
          }

          subject { nodes.flow_templates }

          its(:count) { is_expected.to eq 2 }
          it { is_expected.to all(be_a(Template)) }
        end

        describe 'ignoring of empty nodes' do
          context 'text' do
            subject { Nodes[Italic.new(Text.new('test'))] }

            before {
              subject << Text.new('')
            }
            it { is_expected.to eq [Italic.new(Text.new('test'))] }
          end

          context 'compound' do
            subject { Nodes[Paragraph.new(Text.new('test'))] }

            before {
              subject << Pre.new
            }
            it { is_expected.to eq [Paragraph.new(Text.new('test'))] }
          end

          context 'but not HTML!' do
            subject { Nodes[Paragraph.new(Text.new('test'))] }

            before {
              subject << HTMLTag.new('br', {})
            }
            it { is_expected.to eq [Paragraph.new(Text.new('test')), HTMLTag.new('br', {})] }
          end

          context 'empty paragraphs' do
            subject { Nodes[Heading.new(Text.new('test'), 2)] }

            before {
              subject << EmptyParagraph.new(' ')
            }
            it { is_expected.to eq [Heading.new(Text.new('test'), 2)] }
          end
        end
      end
    end
  end
end