#!/usr/bin/env python3 # -*- coding: utf-8 -*- """ Tests for revision response compilation. Tests compile_revision function with various options: - track_changes: Enable change tracking (diff highlighting) - log_callback: Live logging - progress_callback: Progress tracking """ import pytest pytest.importorskip("git") from pathlib import Path from unittest.mock import Mock, patch from scitex_writer._compile.revision import compile_revision from scitex_writer._dataclasses import CompilationResult class TestCompileRevision: """Test suite for compile_revision function.""" def test_import(self): """Test that compile_revision can be imported.""" from scitex_writer._compile import compile_revision as cr assert callable(cr) def test_signature(self): """Test function signature has expected parameters.""" import inspect sig = inspect.signature(compile_revision) params = list(sig.parameters.keys()) assert "project_dir" in params assert "track_changes" in params assert "timeout" in params assert "log_callback" in params assert "progress_callback" in params def test_default_parameters(self): """Test default parameter values.""" import inspect sig = inspect.signature(compile_revision) assert sig.parameters["track_changes"].default is False assert sig.parameters["timeout"].default == 300 assert sig.parameters["log_callback"].default is None assert sig.parameters["progress_callback"].default is None @patch("scitex_writer._compile.revision.run_compile") def test_calls_run_compile_with_revision_type(self, mock_run_compile): """Test that compile_revision calls run_compile with 'revision' doc_type.""" mock_run_compile.return_value = CompilationResult( success=True, exit_code=0, stdout="", stderr="", duration=1.0, ) project_dir = Path("/tmp/test-project") compile_revision(project_dir) mock_run_compile.assert_called_once() args, kwargs = mock_run_compile.call_args assert args[0] == "revision" assert args[1] == project_dir @patch("scitex_writer._compile.revision.run_compile") def test_passes_track_changes_option(self, mock_run_compile): """Test that track_changes option is passed to run_compile.""" mock_run_compile.return_value = CompilationResult( success=True, exit_code=0, stdout="", stderr="", duration=1.0, ) project_dir = Path("/tmp/test-project") compile_revision(project_dir, track_changes=True) _, kwargs = mock_run_compile.call_args assert kwargs["track_changes"] is True @patch("scitex_writer._compile.revision.run_compile") def test_passes_callbacks(self, mock_run_compile): """Test that callbacks are passed to run_compile.""" mock_run_compile.return_value = CompilationResult( success=True, exit_code=0, stdout="", stderr="", duration=1.0, ) log_callback = Mock() progress_callback = Mock() project_dir = Path("/tmp/test-project") compile_revision( project_dir, log_callback=log_callback, progress_callback=progress_callback, ) _, kwargs = mock_run_compile.call_args assert kwargs["log_callback"] is log_callback assert kwargs["progress_callback"] is progress_callback @patch("scitex_writer._compile.revision.run_compile") def test_passes_timeout(self, mock_run_compile): """Test that timeout is passed to run_compile.""" mock_run_compile.return_value = CompilationResult( success=True, exit_code=0, stdout="", stderr="", duration=1.0, ) project_dir = Path("/tmp/test-project") compile_revision(project_dir, timeout=600) _, kwargs = mock_run_compile.call_args assert kwargs["timeout"] == 600 @patch("scitex_writer._compile.revision.run_compile") def test_returns_compilation_result(self, mock_run_compile): """Test that function returns CompilationResult.""" expected_result = CompilationResult( success=True, exit_code=0, stdout="Test output", stderr="", duration=2.5, ) mock_run_compile.return_value = expected_result project_dir = Path("/tmp/test-project") result = compile_revision(project_dir) assert result is expected_result assert result.success is True assert result.exit_code == 0 assert result.duration == 2.5 # EOF if __name__ == "__main__": import os import pytest pytest.main([os.path.abspath(__file__)])