Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement mypy #60

Merged
merged 9 commits into from
May 16, 2023
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
46 changes: 46 additions & 0 deletions .github/actions/action.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
name: Build Poetry

description: 'Build Poetry'

runs:
using: 'composite'

steps:
- uses: actions/checkout@v3
- name: Set up Python 3.8
uses: actions/setup-python@v4
with:
python-version: 3.8

- name: Get full Python version
id: full-python-version
run: echo "version=$(python -c "import sys; print('-'.join(str(v) for v in sys.version_info))")" >> $GITHUB_OUTPUT
shell: bash

- name: Bootstrap poetry
run: curl -sL https://install.python-poetry.org | python - -y
shell: bash

- name: Update PATH
run: echo "$HOME/.local/bin" >> $GITHUB_PATH
shell: bash

- name: Configure poetry
run: poetry config virtualenvs.in-project true
shell: bash

- name: Set up cache
uses: actions/cache@v3
id: cache
with:
path: .venv
key: venv-${{ runner.os }}-${{ steps.full-python-version.outputs.version }}-${{ inputs.working-directory }}-${{ hashFiles('**/poetry.lock') }}

- name: Ensure cache is healthy
if: steps.cache.outputs.cache-hit == 'true'
run: timeout 10s poetry run pip --version || rm -rf .venv
shell: bash

- name: Install Dependencies
run: poetry install
shell: bash
16 changes: 0 additions & 16 deletions .github/workflows/ruff.yml

This file was deleted.

38 changes: 38 additions & 0 deletions .github/workflows/stability.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
name: Code Stability

on:
push:
branches:
- main
pull_request:
branches:
- main

concurrency:
group: stability-${{ github.head_ref || github.ref }}
cancel-in-progress: true

jobs:
stability:
name: Code Stability
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v3
- name: Build Python
uses: ./.github/actions

- name: Install tools
run: poetry install --only dev

- id: ruff
if: always()
run: poetry run ruff --format=github surrealdb/

- id: Black
if: always()
run: poetry run black surrealdb/ --check --verbose --diff --color

- id: mypy
if: always()
run: poetry run mypy surrealdb/
52 changes: 50 additions & 2 deletions poetry.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

9 changes: 8 additions & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ websockets = "^10.4"
pre-commit = ">=2.20.0"
black = ">=22.8.0"
ruff = ">=0.0.245"
mypy = ">=1.2.0"

[build-system]
requires = ["poetry-core>=1.0.0"]
Expand Down Expand Up @@ -73,7 +74,7 @@ ignore = [
"D104", # Missing docstring in public package
"D107", # Missing docstring in __init__
"D205", # 1 blank line required between summary line and description
"D212", # Multi-line docstring summary should start at the first line
"D212", # Multi-line docstring summary should start at the first line
"N805", # First argument of a method should be named self
"N818", # Exception name ... should be named with an Error suffix
"UP035" # Typing deprecations
Expand Down Expand Up @@ -108,3 +109,9 @@ convention = "google"

[tool.ruff.pyupgrade]
keep-runtime-typing = true

[tool.mypy]
python_version = 3.8
pretty = true
show_traceback = true
color_output = true
49 changes: 26 additions & 23 deletions surrealdb/http.py
Original file line number Diff line number Diff line change
Expand Up @@ -99,14 +99,14 @@ async def __aexit__(
traceback: Optional[TracebackType] = None,
) -> None:
"""Disconnect from the http client when exiting the context manager."""
await self.disconnect()
await self.close()

async def connect(self) -> None:
"""Connects to a local or remote database endpoint."""
"""Connect to a local or remote database endpoint."""
await self._http.__aenter__()

async def close(self) -> None:
"""Closes the persistent connection to the database."""
"""Close the persistent connection to the database."""
await self._http.aclose()

async def _request(
Expand All @@ -132,36 +132,41 @@ async def _request(
# Missing method - authenticate
# Missing method - let
# Missing method - merge
#TODO fix signup and signin methods

# TODO fix signup and signin methods
# TODO: Review type: ignore comments.

async def signup(self, vars: Dict[str, Any]) -> str:
"""Signs this connection up to a specific authentication scope.
"""Sign this connection up to a specific authentication scope.

Args:
vars: Variables used in a signup query.

Examples:
await db.signup({"user": "bob", "pass": "123456"})
"""
response = await self._request(method="POST", uri="/signup", data=json.dumps(vars))
return response
response = await self._request(
method="POST", uri="/signup", data=json.dumps(vars)
)
return response # type: ignore

async def signin(self, vars: Dict[str, Any]) -> str:
"""Signs this connection in to a specific authentication scope.
"""Sign this connection in to a specific authentication scope.

Args:
vars: Variables used in a signin query.

Examples:
await db.signin({"user": "root", "pass": "root"})
"""
response = await self._request(method="POST", uri="/signin", data=json.dumps(vars))
return response
response = await self._request(
method="POST", uri="/signin", data=json.dumps(vars)
)
return response # type: ignore

async def query(
self, sql: str, vars: Optional[Dict[str, Any]] = None
) -> List[Dict[str, Any]]:
"""Runs a set of SurrealQL statements against the database.
"""Run a set of SurrealQL statements against the database.

Args:
sql: Specifies the SurrealQL statements.
Expand All @@ -181,10 +186,10 @@ async def query(
result[1]['result']
"""
response = await self._request(method="POST", uri="/sql", data=sql, params=vars)
return response
return response # type: ignore

async def select(self, thing: str) -> List[Dict[str, Any]]:
"""Selects all records in a table (or other entity),
"""Select all records in a table (or other entity),
or a specific record, in the database.

This function will run the following query in the database:
Expand All @@ -210,7 +215,7 @@ async def select(self, thing: str) -> List[Dict[str, Any]]:
)
if not response and record_id is not None:
raise SurrealException(f"Key {record_id} not found in table {table}")
return response[0]['result']
return response[0]["result"] # type: ignore

async def create(self, thing: str, data: Optional[Dict[str, Any]] = None) -> str:
"""Create a record in the database.
Expand Down Expand Up @@ -243,11 +248,10 @@ async def create(self, thing: str, data: Optional[Dict[str, Any]] = None) -> str
)
if not response and record_id is not None:
raise SurrealException(f"Key {record_id} not found in table {table}")
return response[0]['result']

return response[0]["result"] # type: ignore

async def update(self, thing: str, data: Any) -> Dict[str, Any]:
"""Updates all records in a table, or a specific record, in the database.
"""Update all records in a table, or a specific record, in the database.

This function replaces the current document / record data with the
specified data.
Expand Down Expand Up @@ -278,10 +282,10 @@ async def update(self, thing: str, data: Any) -> Dict[str, Any]:
uri=f"/key/{table}/{record_id}" if record_id else f"/key/{table}",
data=json.dumps(data, ensure_ascii=False),
)
return response[0]['result']
return response[0]["result"] # type: ignore

async def patch(self, thing: str, data: Any) -> Dict[str, Any]:
"""Applies JSON Patch changes to all records, or a specific record, in the database.
"""Apply JSON Patch changes to all records, or a specific record, in the database.

This function patches the current document / record data with
the specified JSON Patch data.
Expand Down Expand Up @@ -311,10 +315,10 @@ async def patch(self, thing: str, data: Any) -> Dict[str, Any]:
uri=f"/key/{table}/{record_id}" if record_id else f"/key/{table}",
data=json.dumps(data, ensure_ascii=False),
)
return response[0]['result']
return response[0]["result"] # type: ignore

async def delete(self, thing: str) -> None:
"""Deletes all records in a table, or a specific record, from the database.
"""Delete all records in a table, or a specific record, from the database.

This function will run the following query in the database:
delete * from $thing
Expand All @@ -333,4 +337,3 @@ async def delete(self, thing: str) -> None:
method="DELETE",
uri=f"/key/{table}/{record_id}" if record_id else f"/key/{table}",
)
return response
Ce11an marked this conversation as resolved.
Show resolved Hide resolved
Loading