| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- import os
- import shutil
- import tempfile
- from click.testing import CliRunner
- from magic_pdf.tools import cli_dev
- def test_cli_pdf():
- # setup
- unitest_dir = '/tmp/magic_pdf/unittest/tools'
- filename = 'cli_test_01'
- os.makedirs(unitest_dir, exist_ok=True)
- temp_output_dir = tempfile.mkdtemp(dir='/tmp/magic_pdf/unittest/tools')
- # run
- runner = CliRunner()
- result = runner.invoke(
- cli_dev.cli,
- [
- 'pdf',
- '-p',
- 'tests/unittest/test_tools/assets/cli/pdf/cli_test_01.pdf',
- '-j',
- 'tests/unittest/test_tools/assets/cli_dev/cli_test_01.model.json',
- '-o',
- temp_output_dir,
- ],
- )
- # check
- assert result.exit_code == 0
- base_output_dir = os.path.join(temp_output_dir, 'cli_test_01/auto')
- r = os.stat(os.path.join(base_output_dir, f'{filename}_content_list.json'))
- assert r.st_size > 5000
- r = os.stat(os.path.join(base_output_dir, f'{filename}.md'))
- assert r.st_size > 7000
- r = os.stat(os.path.join(base_output_dir, f'{filename}_middle.json'))
- assert r.st_size > 200000
- r = os.stat(os.path.join(base_output_dir, f'{filename}_model.json'))
- assert r.st_size > 15000
- r = os.stat(os.path.join(base_output_dir, f'{filename}_origin.pdf'))
- assert r.st_size > 400000
- r = os.stat(os.path.join(base_output_dir, f'{filename}_layout.pdf'))
- assert r.st_size > 400000
- r = os.stat(os.path.join(base_output_dir, f'{filename}_spans.pdf'))
- assert r.st_size > 400000
- assert os.path.exists(os.path.join(base_output_dir, 'images')) is True
- assert os.path.isdir(os.path.join(base_output_dir, 'images')) is True
- # teardown
- shutil.rmtree(temp_output_dir)
- def test_cli_jsonl():
- # setup
- unitest_dir = '/tmp/magic_pdf/unittest/tools'
- filename = 'cli_test_01'
- os.makedirs(unitest_dir, exist_ok=True)
- temp_output_dir = tempfile.mkdtemp(dir='/tmp/magic_pdf/unittest/tools')
- def mock_read_s3_path(s3path):
- with open(s3path, 'rb') as f:
- return f.read()
- cli_dev.read_s3_path = mock_read_s3_path # mock
- # run
- runner = CliRunner()
- result = runner.invoke(
- cli_dev.cli,
- [
- 'jsonl',
- '-j',
- 'tests/unittest/test_tools/assets/cli_dev/cli_test_01.jsonl',
- '-o',
- temp_output_dir,
- ],
- )
- # check
- assert result.exit_code == 0
- base_output_dir = os.path.join(temp_output_dir, 'cli_test_01/auto')
- r = os.stat(os.path.join(base_output_dir, f'{filename}_content_list.json'))
- assert r.st_size > 5000
- r = os.stat(os.path.join(base_output_dir, f'{filename}.md'))
- assert r.st_size > 7000
- r = os.stat(os.path.join(base_output_dir, f'{filename}_middle.json'))
- assert r.st_size > 200000
- r = os.stat(os.path.join(base_output_dir, f'{filename}_model.json'))
- assert r.st_size > 15000
- r = os.stat(os.path.join(base_output_dir, f'{filename}_origin.pdf'))
- assert r.st_size > 400000
- r = os.stat(os.path.join(base_output_dir, f'{filename}_layout.pdf'))
- assert r.st_size > 400000
- r = os.stat(os.path.join(base_output_dir, f'{filename}_spans.pdf'))
- assert r.st_size > 400000
- assert os.path.exists(os.path.join(base_output_dir, 'images')) is True
- assert os.path.isdir(os.path.join(base_output_dir, 'images')) is True
- # teardown
- shutil.rmtree(temp_output_dir)
|