aboutsummaryrefslogtreecommitdiff
path: root/tests/test_commandline_export.py
diff options
context:
space:
mode:
authorBrianna Rainey2026-01-13 19:34:55 -0500
committerGitHub2026-01-13 19:34:55 -0500
commit50f5a76603a3f97f2c6f6a1d3cefea88ed3497aa (patch)
tree226fe223b31af6f217b1dd413629ab2cf26964d4 /tests/test_commandline_export.py
parentb8703752ffc7768b0275897b3c2a869ff41504e5 (diff)
parentf975144f25d34f97329b2d4e52891061573cea08 (diff)
Merge pull request #85 from aeliton/add-pyproject
Use pyproject.toml + uv_build
Diffstat (limited to 'tests/test_commandline_export.py')
-rw-r--r--tests/test_commandline_export.py39
1 files changed, 39 insertions, 0 deletions
diff --git a/tests/test_commandline_export.py b/tests/test_commandline_export.py
new file mode 100644
index 0000000..05ead77
--- /dev/null
+++ b/tests/test_commandline_export.py
@@ -0,0 +1,39 @@
+import sys
+import os
+import tempfile
+from avp.command import Command
+from . import getTestDataPath
+from pytestqt import qtbot
+
+
+def test_commandline_classic_export(qtbot):
+ """Run Qt event loop and create a video in the system /tmp or /temp"""
+ soundFile = getTestDataPath("test.ogg")
+ outputDir = tempfile.mkdtemp(prefix="avp-test-")
+ outputFilename = os.path.join(outputDir, "output.mp4")
+ sys.argv = [
+ "",
+ "-c",
+ "0",
+ "classic",
+ "-i",
+ soundFile,
+ "-o",
+ outputFilename,
+ ]
+
+ command = Command()
+ command.quit = lambda _: None
+ command.parseArgs()
+ # Command object now has a video_thread Worker which is exporting the video
+
+ with qtbot.waitSignal(command.worker.videoCreated, timeout=10000):
+ """
+ Wait until videoCreated is emitted by the video_thread Worker
+ or until 10 second timeout has passed
+ """
+ print(f"Test Video created at {outputFilename}")
+
+ assert os.path.exists(outputFilename)
+ # output video should be at least 200kb
+ assert os.path.getsize(outputFilename) > 200000