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 / test_main.py
Size: Mime:
from __future__ import (
    absolute_import,
    print_function,
    unicode_literals,
)

from os import unlink
from shutil import copyfile
from subprocess import Popen, PIPE
from tempfile import NamedTemporaryFile
from unittest import TestCase

from nose import SkipTest

from pydocx.__main__ import main
from pydocx.test.testcases import BASE_HTML
from pydocx.test.utils import assert_html_equal


class MainTestCase(TestCase):
    def test_return_code_with_no_args(self):
        result = main()
        self.assertEqual(result, 1)

    def test_return_code_with_one_args(self):
        result = main(['foo'])
        self.assertEqual(result, 1)

    def test_return_code_with_two_args(self):
        result = main(['foo', 'bar'])
        self.assertEqual(result, 1)

    def test_return_code_with_three_args(self):
        result = main(['foo', 'bar', 'baz'])
        self.assertEqual(result, 2)

    def test_convert_to_html_status_code(self):
        with NamedTemporaryFile() as f:
            result = main([
                '--html',
                'tests/fixtures/inline_tags.docx',
                f.name,
            ])
        self.assertEqual(result, 0)

    def test_convert_to_markdown_status_code(self):
        raise SkipTest('Fixture files for markdown do not exist yet')

    def test_convert_to_html_result(self):
        fixture_html = open('tests/fixtures/inline_tags.html').read()
        expected_html = BASE_HTML % fixture_html
        with NamedTemporaryFile() as f:
            result = main([
                '--html',
                'tests/fixtures/inline_tags.docx',
                f.name,
            ])
            data = open(f.name).read()
            assert_html_equal(data, expected_html)
        self.assertEqual(result, 0)

    def test_convert_to_markdown_result(self):
        raise SkipTest('Fixture files for markdown do not exist yet')

    def test_file_handles_to_docx_are_released(self):
        # Copy the docx to another location so we can open it, and delete it
        with NamedTemporaryFile(delete=False) as input_docx:
            copyfile('tests/fixtures/inline_tags.docx', input_docx.name)
            with NamedTemporaryFile() as output:
                result = main(['--html', input_docx.name, output.name])
            self.assertEqual(result, 0)
            unlink(input_docx.name)
            input_docx.close()

    def test_cli_return_code_with_no_args(self):
        result = Popen(['pydocx'], stdout=PIPE).wait()
        self.assertEqual(result, 1)

    def test_cli_return_code_with_one_args(self):
        result = Popen(['pydocx', 'foo'], stdout=PIPE).wait()
        self.assertEqual(result, 1)

    def test_cli_return_code_with_two_args(self):
        result = Popen(['pydocx', 'foo', 'bar'], stdout=PIPE).wait()
        self.assertEqual(result, 1)

    def test_cli_return_code_with_three_args(self):
        result = Popen(['pydocx', 'foo', 'bar', 'baz'], stdout=PIPE).wait()
        self.assertEqual(result, 2)

    def test_cli_convert_to_html_status_code(self):
        with NamedTemporaryFile() as f:
            result = Popen([
                'pydocx',
                '--html',
                'tests/fixtures/inline_tags.docx',
                f.name
            ], stdout=PIPE).wait()
        self.assertEqual(result, 0)