| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- import tempfile
- import os
- import shutil
- from click.testing import CliRunner
- from magic_pdf.tools.cli import cli
- 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,
- [
- "-p",
- "tests/test_tools/assets/cli/pdf/cli_test_01.pdf",
- "-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}.md"))
- assert r.st_size > 7000
- r = os.stat(os.path.join(base_output_dir, "middle.json"))
- assert r.st_size > 200000
- r = os.stat(os.path.join(base_output_dir, "model.json"))
- assert r.st_size > 15000
- r = os.stat(os.path.join(base_output_dir, "origin.pdf"))
- assert r.st_size > 500000
- r = os.stat(os.path.join(base_output_dir, "layout.pdf"))
- assert r.st_size > 500000
- r = os.stat(os.path.join(base_output_dir, "spans.pdf"))
- assert r.st_size > 500000
- 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
- assert os.path.exists(os.path.join(base_output_dir, "content_list.json")) is False
- # teardown
- shutil.rmtree(temp_output_dir)
- def test_cli_path():
- # setup
- unitest_dir = "/tmp/magic_pdf/unittest/tools"
- 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, ["-p", "tests/test_tools/assets/cli/path", "-o", temp_output_dir]
- )
- # check
- assert result.exit_code == 0
- filename = "cli_test_01"
- base_output_dir = os.path.join(temp_output_dir, "cli_test_01/auto")
- 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, "middle.json"))
- assert r.st_size > 200000
- r = os.stat(os.path.join(base_output_dir, "model.json"))
- assert r.st_size > 15000
- r = os.stat(os.path.join(base_output_dir, "origin.pdf"))
- assert r.st_size > 500000
- r = os.stat(os.path.join(base_output_dir, "layout.pdf"))
- assert r.st_size > 500000
- r = os.stat(os.path.join(base_output_dir, "spans.pdf"))
- assert r.st_size > 500000
- 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
- assert os.path.exists(os.path.join(base_output_dir, "content_list.json")) is False
- base_output_dir = os.path.join(temp_output_dir, "cli_test_02/auto")
- filename = "cli_test_02"
- r = os.stat(os.path.join(base_output_dir, f"{filename}.md"))
- assert r.st_size > 5000
- r = os.stat(os.path.join(base_output_dir, "middle.json"))
- assert r.st_size > 200000
- r = os.stat(os.path.join(base_output_dir, "model.json"))
- assert r.st_size > 15000
- r = os.stat(os.path.join(base_output_dir, "origin.pdf"))
- assert r.st_size > 500000
- r = os.stat(os.path.join(base_output_dir, "layout.pdf"))
- assert r.st_size > 500000
- r = os.stat(os.path.join(base_output_dir, "spans.pdf"))
- assert r.st_size > 500000
- 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
- assert os.path.exists(os.path.join(base_output_dir, "content_list.json")) is False
- # teardown
- shutil.rmtree(temp_output_dir)
|