"""Tests for openai-image-gen helpers."""
import tempfile
from pathlib import Path
import pytest
from gen import (
normalize_background,
normalize_output_format,
normalize_style,
write_gallery,
)
def test_normalize_background_allows_empty_for_non_gpt_models():
assert normalize_background("dall-e-3", "transparent") == ""
def test_normalize_background_allows_empty_for_gpt_models():
assert normalize_background("gpt-image-1", "") == ""
assert normalize_background("gpt-image-1", " ") == ""
def test_normalize_background_normalizes_case_for_gpt_models():
assert normalize_background("gpt-image-1", "TRANSPARENT") == "transparent"
def test_normalize_background_warns_when_model_does_not_support_flag(capsys):
assert normalize_background("dall-e-3", "transparent") == ""
captured = capsys.readouterr()
assert "--background is only supported for gpt-image models" in captured.err
def test_normalize_background_rejects_invalid_values():
with pytest.raises(ValueError, match="Invalid --background"):
normalize_background("gpt-image-1", "checkerboard")
def test_normalize_style_allows_empty_for_non_dalle3_models():
assert normalize_style("gpt-image-1", "vivid") == ""
def test_normalize_style_allows_empty_for_dalle3():
assert normalize_style("dall-e-3", "") == ""
assert normalize_style("dall-e-3", " ") == ""
def test_normalize_style_normalizes_case_for_dalle3():
assert normalize_style("dall-e-3", "NATURAL") == "natural"
def test_normalize_style_warns_when_model_does_not_support_flag(capsys):
assert normalize_style("gpt-image-1", "vivid") == ""
captured = capsys.readouterr()
assert "--style is only supported for dall-e-3" in captured.err
def test_normalize_style_rejects_invalid_values():
with pytest.raises(ValueError, match="Invalid --style"):
normalize_style("dall-e-3", "cinematic")
def test_normalize_output_format_allows_empty_for_non_gpt_models():
assert normalize_output_format("dall-e-3", "jpeg") == ""
def test_normalize_output_format_allows_empty_for_gpt_models():
assert normalize_output_format("gpt-image-1", "") == ""
assert normalize_output_format("gpt-image-1", " ") == ""
def test_normalize_output_format_warns_when_model_does_not_support_flag(capsys):
assert normalize_output_format("dall-e-3", "jpeg") == ""
captured = capsys.readouterr()
assert "--output-format is only supported for gpt-image models" in captured.err
def test_normalize_output_format_normalizes_case_for_supported_values():
assert normalize_output_format("gpt-image-1", "PNG") == "png"
assert normalize_output_format("gpt-image-1", "WEBP") == "webp"
def test_normalize_output_format_strips_whitespace_for_supported_values():
assert normalize_output_format("gpt-image-1", " png ") == "png"
def test_normalize_output_format_keeps_supported_values():
assert normalize_output_format("gpt-image-1", "png") == "png"
assert normalize_output_format("gpt-image-1", "jpeg") == "jpeg"
assert normalize_output_format("gpt-image-1", "webp") == "webp"
def test_normalize_output_format_normalizes_jpg_alias():
assert normalize_output_format("gpt-image-1", "jpg") == "jpeg"
def test_normalize_output_format_rejects_invalid_values():
with pytest.raises(ValueError, match="Invalid --output-format"):
normalize_output_format("gpt-image-1", "svg")
def test_write_gallery_escapes_prompt_xss():
with tempfile.TemporaryDirectory() as tmpdir:
out = Path(tmpdir)
items = [{"prompt": '', "file": "001-test.png"}]
write_gallery(out, items)
html = (out / "index.html").read_text()
assert "