Files
orion/alembic/versions_backup/82ea1b4a3ccb_add_test_run_tables.py
Samir Boulahtit f20266167d
Some checks failed
CI / ruff (push) Failing after 7s
CI / pytest (push) Failing after 1s
CI / architecture (push) Failing after 9s
CI / dependency-scanning (push) Successful in 27s
CI / audit (push) Successful in 8s
CI / docs (push) Has been skipped
fix(lint): auto-fix ruff violations and tune lint rules
- Auto-fixed 4,496 lint issues (import sorting, modern syntax, etc.)
- Added ignore rules for patterns intentional in this codebase:
  E402 (late imports), E712 (SQLAlchemy filters), B904 (raise from),
  SIM108/SIM105/SIM117 (readability preferences)
- Added per-file ignores for tests and scripts
- Excluded broken scripts/rename_terminology.py (has curly quotes)

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-12 23:10:42 +01:00

104 lines
4.9 KiB
Python

"""add_test_run_tables
Revision ID: 82ea1b4a3ccb
Revises: b4c5d6e7f8a9
Create Date: 2025-12-12 22:48:09.501172
"""
from collections.abc import Sequence
import sqlalchemy as sa
from alembic import op
# revision identifiers, used by Alembic.
revision: str = "82ea1b4a3ccb"
down_revision: str | None = "b4c5d6e7f8a9"
branch_labels: str | Sequence[str] | None = None
depends_on: str | Sequence[str] | None = None
def upgrade() -> None:
# Create test_collections table
op.create_table("test_collections",
sa.Column("id", sa.Integer(), nullable=False),
sa.Column("total_tests", sa.Integer(), nullable=True),
sa.Column("total_files", sa.Integer(), nullable=True),
sa.Column("total_classes", sa.Integer(), nullable=True),
sa.Column("unit_tests", sa.Integer(), nullable=True),
sa.Column("integration_tests", sa.Integer(), nullable=True),
sa.Column("performance_tests", sa.Integer(), nullable=True),
sa.Column("system_tests", sa.Integer(), nullable=True),
sa.Column("test_files", sa.JSON(), nullable=True),
sa.Column("collected_at", sa.DateTime(timezone=True), server_default=sa.text("(CURRENT_TIMESTAMP)"), nullable=False),
sa.PrimaryKeyConstraint("id")
)
op.create_index(op.f("ix_test_collections_id"), "test_collections", ["id"], unique=False)
# Create test_runs table
op.create_table("test_runs",
sa.Column("id", sa.Integer(), nullable=False),
sa.Column("timestamp", sa.DateTime(timezone=True), server_default=sa.text("(CURRENT_TIMESTAMP)"), nullable=False),
sa.Column("total_tests", sa.Integer(), nullable=True),
sa.Column("passed", sa.Integer(), nullable=True),
sa.Column("failed", sa.Integer(), nullable=True),
sa.Column("errors", sa.Integer(), nullable=True),
sa.Column("skipped", sa.Integer(), nullable=True),
sa.Column("xfailed", sa.Integer(), nullable=True),
sa.Column("xpassed", sa.Integer(), nullable=True),
sa.Column("coverage_percent", sa.Float(), nullable=True),
sa.Column("duration_seconds", sa.Float(), nullable=True),
sa.Column("triggered_by", sa.String(length=100), nullable=True),
sa.Column("git_commit_hash", sa.String(length=40), nullable=True),
sa.Column("git_branch", sa.String(length=100), nullable=True),
sa.Column("test_path", sa.String(length=500), nullable=True),
sa.Column("pytest_args", sa.String(length=500), nullable=True),
sa.Column("status", sa.String(length=20), nullable=True),
sa.PrimaryKeyConstraint("id")
)
op.create_index(op.f("ix_test_runs_id"), "test_runs", ["id"], unique=False)
op.create_index(op.f("ix_test_runs_status"), "test_runs", ["status"], unique=False)
op.create_index(op.f("ix_test_runs_timestamp"), "test_runs", ["timestamp"], unique=False)
# Create test_results table
op.create_table("test_results",
sa.Column("id", sa.Integer(), nullable=False),
sa.Column("run_id", sa.Integer(), nullable=False),
sa.Column("node_id", sa.String(length=500), nullable=False),
sa.Column("test_name", sa.String(length=200), nullable=False),
sa.Column("test_file", sa.String(length=300), nullable=False),
sa.Column("test_class", sa.String(length=200), nullable=True),
sa.Column("outcome", sa.String(length=20), nullable=False),
sa.Column("duration_seconds", sa.Float(), nullable=True),
sa.Column("error_message", sa.Text(), nullable=True),
sa.Column("traceback", sa.Text(), nullable=True),
sa.Column("markers", sa.JSON(), nullable=True),
sa.Column("parameters", sa.JSON(), nullable=True),
sa.Column("created_at", sa.DateTime(timezone=True), server_default=sa.text("(CURRENT_TIMESTAMP)"), nullable=False),
sa.ForeignKeyConstraint(["run_id"], ["test_runs.id"], ),
sa.PrimaryKeyConstraint("id")
)
op.create_index(op.f("ix_test_results_id"), "test_results", ["id"], unique=False)
op.create_index(op.f("ix_test_results_node_id"), "test_results", ["node_id"], unique=False)
op.create_index(op.f("ix_test_results_outcome"), "test_results", ["outcome"], unique=False)
op.create_index(op.f("ix_test_results_run_id"), "test_results", ["run_id"], unique=False)
def downgrade() -> None:
# Drop test_results table first (has foreign key to test_runs)
op.drop_index(op.f("ix_test_results_run_id"), table_name="test_results")
op.drop_index(op.f("ix_test_results_outcome"), table_name="test_results")
op.drop_index(op.f("ix_test_results_node_id"), table_name="test_results")
op.drop_index(op.f("ix_test_results_id"), table_name="test_results")
op.drop_table("test_results")
# Drop test_runs table
op.drop_index(op.f("ix_test_runs_timestamp"), table_name="test_runs")
op.drop_index(op.f("ix_test_runs_status"), table_name="test_runs")
op.drop_index(op.f("ix_test_runs_id"), table_name="test_runs")
op.drop_table("test_runs")
# Drop test_collections table
op.drop_index(op.f("ix_test_collections_id"), table_name="test_collections")
op.drop_table("test_collections")