Skip to content

refactor(test): replace SimpleNamespace with real Site model in test_fields.py#37680

Open
lavkeshdwivedi wants to merge 4 commits into
langgenius:mainfrom
lavkeshdwivedi:refactor/test-fields-real-site-model
Open

refactor(test): replace SimpleNamespace with real Site model in test_fields.py#37680
lavkeshdwivedi wants to merge 4 commits into
langgenius:mainfrom
lavkeshdwivedi:refactor/test-fields-real-site-model

Conversation

@lavkeshdwivedi

Copy link
Copy Markdown

Summary

Addresses #37604.

test_fields.py used SimpleNamespace to stand in for the ORM Site model passed to Site.model_validate(). pyrefly flags this as a type error since SimpleNamespace doesn't satisfy the Site type annotation.

Changes

  • Replace both SimpleNamespace(...) site stubs with models.model.Site(...) instances
  • Site has a custom_disclaimer property backed by _custom_disclaimer, so all fields accessed by the Pydantic Site serializer are correctly typed
  • Remove the now-unused SimpleNamespace import

Why this works

models.model.Site has mapped_column declarations for all fields the Pydantic Site model reads (title, icon_type, icon, default_language, show_workflow_steps, etc.). The custom_disclaimer column is exposed via a @property, so from_attributes=True reads it correctly.

Test plan

  • uv run pytest api/tests/unit_tests/controllers/common/test_fields.py passes
  • uv run pyrefly check api/tests/unit_tests/controllers/common/test_fields.py reports no SimpleNamespace-related errors

SQLAlchemy's CursorResult.rowcount can return None for some DBAPI
drivers/operations. Five bulk-delete methods used result.rowcount
directly in += or as a return value, causing:

  TypeError: unsupported operand type(s) for +=: 'int' and 'NoneType'

Apply the `result.rowcount or 0` pattern already used in sibling
methods (delete_by_runs, count_by_runs) across all five affected sites:

- sqlalchemy_api_workflow_node_execution_repository.py
  - delete_expired_executions
  - delete_executions_by_app
  - delete_executions_by_ids
- sqlalchemy_api_workflow_run_repository.py
  - delete_runs_by_ids
  - delete_runs_by_app

Fixes langgenius#37643
Covers all five affected methods to guard against regression:
- delete_expired_executions, delete_executions_by_app,
  delete_executions_by_ids (node execution repository)
- delete_runs_by_ids, delete_runs_by_app (run repository)

Each test mocks the DBAPI session to return rowcount=None and asserts
the method returns 0 instead of raising TypeError.
…test_snippet.py

Fixes the pyrefly type errors reported in langgenius#37604.

SimpleNamespace objects passed where Workflow, Account, and Tag are
expected do not satisfy the type checker. Replace with real ORM
instances so pyrefly can verify the fields being accessed actually
exist on the model.

Also replace SimpleNamespace session stubs with unittest.mock.Mock,
which is the standard pattern in the rest of the test suite.

Refs langgenius#37604
…fields.py

Fixes pyrefly type errors from langgenius#37604.

Pydantic's model_validate receives a real models.model.Site ORM instance
instead of a SimpleNamespace. This satisfies the type checker since Site
has all the required attributes (title, icon_type, icon, etc.) as mapped
columns, and custom_disclaimer is exposed via a property on the model.

Also removes the unused SimpleNamespace import.

Refs langgenius#37604
@dosubot dosubot Bot added size:S This PR changes 10-29 lines, ignoring generated files. refactor labels Jun 20, 2026
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

refactor size:S This PR changes 10-29 lines, ignoring generated files.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant