Compare commits

..

4 Commits

Author SHA1 Message Date
Flea Flicker 4965d374a5 Remove deploy-dev and deploy-uat CI jobs (CAR-1069)
CI / lint (pull_request) Successful in 7s
CI / test (pull_request) Failing after 43s
CI / build-and-push (pull_request) Has been skipped
CI / typecheck (pull_request) Failing after 1m0s
2026-05-27 01:43:44 +00:00
Chris Farhood 24d1b199ea Add .mcp.json
CI / lint (push) Successful in 4s
CI / typecheck (push) Failing after 18s
CI / test (push) Failing after 1m13s
CI / build-and-push (push) Has been skipped
CI / deploy-dev (push) Failing after 31s
CI / deploy-uat (push) Failing after 32s
2026-05-25 21:46:58 +00:00
Savannah Savings 46906cc333 Merge pull request 'Promote to Production: CAR-894 Gitea workflows migration' (#36) from uat into main
CI / lint (push) Successful in 4s
CI / typecheck (push) Failing after 18s
CI / test (push) Failing after 1m31s
CI / build-and-push (push) Has been skipped
CI / deploy-uat (push) Failing after 26s
CI / deploy-dev (push) Failing after 34s
2026-05-24 18:51:43 +00:00
cartsnitch-ceo[bot] cb180b511f release: promote API migration to production
Production merge approved by CEO (Coupon Carl). All SDLC gates cleared: QA passed, UAT regression passed (CAR-727), security review cleared. Pre-existing CI lint failures are unrelated to this PR's changes (CI workflow, .grype.yaml, CLAUDE.md only).
2026-04-19 12:27:19 +00:00
2 changed files with 8 additions and 30 deletions
+8 -21
View File
@@ -51,21 +51,12 @@ def disable_rate_limiting():
@pytest.fixture
def engine():
"""Sync in-memory SQLite engine for model unit tests.
Strips PostgreSQL-specific server_default expressions so SQLite can
handle all column inserts without missing-function errors.
"""
"""Sync in-memory SQLite engine for model unit tests."""
eng = create_engine("sqlite:///:memory:")
from cartsnitch_api.models.user import User
for table in Base.metadata.tables.values():
for col in table.columns.values():
sd = col.server_default
if sd is not None:
expr_str = str(sd.expression).lower()
if "gen_random_uuid" in expr_str or "gen_random_bytes" in expr_str:
col.server_default = None
col = User.__table__.columns["email_inbound_token"]
col.server_default = None
Base.metadata.create_all(eng)
yield eng
eng.dispose()
@@ -89,16 +80,12 @@ async def db_engine():
cursor.execute("PRAGMA foreign_keys=ON")
cursor.close()
for table in Base.metadata.tables.values():
for col in table.columns.values():
sd = col.server_default
if sd is not None:
expr_str = str(sd.expression).lower()
if "gen_random_uuid" in expr_str or "gen_random_bytes" in expr_str:
col.server_default = None
async with engine.begin() as conn:
from cartsnitch_api.models.user import User
User.__table__.columns["email_inbound_token"].server_default = None
await conn.run_sync(Base.metadata.create_all)
# Create Better-Auth tables (not managed by SQLAlchemy models)
await conn.execute(
text("""
CREATE TABLE IF NOT EXISTS sessions (
-9
View File
@@ -17,15 +17,6 @@ from cartsnitch_api.models.user import User, UserStoreAccount
@pytest.fixture
def engine():
eng = create_engine("sqlite:///:memory:")
for table in Base.metadata.tables.values():
for col in table.columns.values():
sd = col.server_default
if sd is not None:
expr_str = str(sd.expression).lower()
if "gen_random_uuid" in expr_str or "gen_random_bytes" in expr_str:
col.server_default = None
Base.metadata.create_all(eng)
yield eng
eng.dispose()