Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
PyDocX / tests / openxml / wordprocessing / test_paragraph.py
Size: Mime:
# coding: utf-8
from __future__ import (
    absolute_import,
    print_function,
    unicode_literals,
)

from unittest import TestCase

from pydocx.openxml.wordprocessing import Paragraph
from pydocx.util.xml import parse_xml_from_string


class ParagraphTestBase(TestCase):
    def _load_from_xml(self, xml):
        root = parse_xml_from_string(xml)
        return Paragraph.load(root)


class GetTextTestCase(ParagraphTestBase):
    def test_no_runs(self):
        xml = '<p/>'
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_text(), '')

    def test_no_text_nodes_several_runs(self):
        xml = '<p><r /><r /></p>'
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_text(), '')

    def test_only_non_text_children_in_run(self):
        xml = '<p><r><br /></r></p>'
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_text(), '')

    def test_single_run_single_text_node(self):
        xml = '<p><r><t>foo</t></r></p>'
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_text(), 'foo')

    def test_single_run_many_text_nodes(self):
        xml = '''
            <p>
                <r>
                    <t>a</t>
                    <t>b</t>
                    <t>c</t>
                </r>
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_text(), 'abc')

    def test_many_runs_many_text_nodes(self):
        xml = '''
            <p>
                <r>
                    <t>a</t>
                    <t>b</t>
                </r>
                <r>
                    <t>c</t>
                    <t>d</t>
                </r>
                <r>
                    <t>e</t>
                    <t>f</t>
                </r>
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_text(), 'abcdef')

    def test_single_run_many_text_nodes_with_non_text_nodes(self):
        xml = '''
            <p>
                <r>
                    <t>a</t>
                    <br />
                    <t>b</t>
                    <tab />
                    <t>c</t>
                    <noBreakHyphen />
                </r>
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_text(), 'abc')

    def test_single_run_many_text_nodes_with_spacing(self):
        xml = '''
            <p>
                <r>
                    <t> a </t>
                    <t> b </t>
                    <t> c </t>
                </r>
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_text(), ' a  b  c ')

    def test_with_tab_char_set(self):
        xml = '''
            <p>
                <r>
                    <t>a</t>
                    <tab />
                    <t>b</t>
                </r>
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_text(tab_char=' '), 'a b')


class GetNumberOfInitialTabsTestCase(ParagraphTestBase):
    def test_empty_paragraph(self):
        xml = '<p />'
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_number_of_initial_tabs(), 0)

    def test_empty_run(self):
        xml = '''
            <p>
                <r />
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_number_of_initial_tabs(), 0)

    def test_single_run_single_text_node(self):
        xml = '''
            <p>
                <r>
                    <t>Foo</t>
                </r>
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_number_of_initial_tabs(), 0)

    def test_single_initial_tab(self):
        xml = '''
            <p>
                <r>
                    <tab />
                </r>
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_number_of_initial_tabs(), 1)

    def test_many_runs_many_tabs(self):
        xml = '''
            <p>
                <r>
                    <tab />
                    <tab />
                </r>
                <r>
                    <tab />
                </r>
                <r />
                <r>
                    <tab />
                    <tab />
                </r>
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_number_of_initial_tabs(), 5)

    def test_break_tag_stops_counting(self):
        xml = '''
            <p>
                <r>
                    <tab />
                </r>
                <r>
                    <tab />
                    <br />
                    <tab />
                </r>
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_number_of_initial_tabs(), 2)

    def test_text_node_stops_counting(self):
        xml = '''
            <p>
                <r>
                    <tab />
                </r>
                <r>
                    <tab />
                    <t>Foo</t>
                    <tab />
                </r>
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_number_of_initial_tabs(), 2)

    def test_hyperlink_stops_counting(self):
        xml = '''
            <p>
                <r>
                    <tab />
                </r>
                <hyperlink />
                <r>
                    <tab />
                </r>
            </p>
        '''
        paragraph = self._load_from_xml(xml)
        self.assertEqual(paragraph.get_number_of_initial_tabs(), 1)