-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Code refactor, cleanup and improvements
Features: - add documentation - switch to Hatch - move to Typer - add the ability to run Smyth outside of it's `python -m smyth` entrypoint (TOML config is not required in that case) - remove redundant code - fix configuration names (breaking changes!) - get rid of the process definition idea - use handler configs instead - add the ability to simulate `boto3.Lambda.invoke` - change the way subprocesses are handled - now those start with the application, immedietly showing if something is misconfigured - subprocess runner, target function is simplified - dispatch strategies are now functions (breaking changes!) - improve typing Internal improvements: - add code quality CI/CD - use Hatch in CI/CD - use Hatch for static-analysis with Ruff and MyPy Not done: - tests - resource leak warning
- Loading branch information
Showing
51 changed files
with
1,722 additions
and
1,315 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,53 +1,73 @@ | ||
name: Code Quality | ||
|
||
on: [push] | ||
on: | ||
push: | ||
|
||
jobs: | ||
coverage: | ||
name: Coverage | ||
format-check: | ||
name: Format Check | ||
runs-on: ubuntu-latest | ||
env: | ||
COVERAGE: 90 | ||
steps: | ||
- name: Checkout source code | ||
uses: actions/checkout@v4 | ||
- uses: actions/checkout@v4 | ||
|
||
- name: Set up Python 3.12 | ||
uses: actions/setup-python@v4 | ||
uses: actions/setup-python@v5 | ||
with: | ||
python-version-file: pyproject.toml | ||
|
||
- name: Install Poetry | ||
uses: snok/install-poetry@v1.3.4 | ||
with: | ||
version: 1.8.2 | ||
virtualenvs-create: true | ||
virtualenvs-in-project: true | ||
|
||
- name: Load cached venv | ||
id: cached-poetry-dependencies | ||
uses: actions/cache@v3 | ||
with: | ||
path: .venv | ||
key: venv-${{ runner.os }}-${{ steps.setup-python.outputs.python-version }}-1.7.1-${{ hashFiles('**/poetry.lock') }} | ||
- name: Install Hatch | ||
uses: pypa/hatch@257e27e51a6a5616ed08a39a408a21c35c9931bc | ||
|
||
- name: Install dependencies | ||
if: steps.cached-poetry-dependencies.outputs.cache-hit != 'true' | ||
run: poetry install --no-interaction --no-root | ||
- name: Run checks | ||
run: | | ||
hatch fmt --check | ||
type-check: | ||
name: Type Check | ||
needs: [format-check] | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- name: Install library | ||
run: poetry install --no-interaction | ||
- name: Set up Python 3.12 | ||
uses: actions/setup-python@v5 | ||
with: | ||
python-version-file: pyproject.toml | ||
|
||
# - name: Check coverage | ||
# run: poetry run pytest --cov=smyth --cov-fail-under=${{ env.COVERAGE }} src | ||
- name: Install Hatch | ||
uses: pypa/hatch@257e27e51a6a5616ed08a39a408a21c35c9931bc | ||
|
||
- name: mypy | ||
run: poetry run mypy src | ||
Ruff: | ||
name: Ruff | ||
- name: Run type checks | ||
run: | | ||
hatch run types:check | ||
unit-test: | ||
name: Unit Test | ||
needs: [format-check, type-check] | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
python-version: ["3.10", "3.11", "3.12"] | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Ruff Check | ||
uses: jpetrucciani/ruff-check@main | ||
- uses: actions/checkout@v4 | ||
|
||
- name: Set up Python ${{ matrix.python-version }} | ||
uses: actions/setup-python@v5 | ||
with: | ||
path: "." | ||
python-version: ${{ matrix.python-version }} | ||
|
||
- name: Install Hatch | ||
uses: pypa/hatch@257e27e51a6a5616ed08a39a408a21c35c9931bc | ||
|
||
- name: Run tests | ||
if: ${{ matrix.python-version != '3.12' }} | ||
run: | | ||
hatch test -i python=${{ matrix.python-version }} | ||
- name: Run tests with coverage | ||
if: ${{ matrix.python-version == '3.12' }} | ||
run: | | ||
hatch test --cover -i python=${{ matrix.python-version }} | ||
concurrency: | ||
group: ${{ github.workflow }}-${{ github.ref }} | ||
cancel-in-progress: ${{ !contains(github.ref, 'release/')}} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
name: Deploy documentation | ||
|
||
on: | ||
push: | ||
branches: | ||
- main | ||
|
||
jobs: | ||
docs-publish: | ||
name: publish documentation | ||
runs-on: ubuntu-latest | ||
permissions: | ||
contents: write | ||
steps: | ||
- name: Checkout source code | ||
uses: actions/checkout@v4 | ||
|
||
- name: Configure Git Credentials | ||
run: | | ||
git config user.name github-actions[bot] | ||
git config user.email 41898282+github-actions[bot]@users.noreply.github.com | ||
- name: Set up Python 3.12 | ||
uses: actions/setup-python@v5 | ||
with: | ||
python-version-file: pyproject.toml | ||
|
||
- name: Install Hatch | ||
uses: pypa/hatch@257e27e51a6a5616ed08a39a408a21c35c9931bc | ||
|
||
- name: Build documentation | ||
run: hatch run docs:deploy |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -27,3 +27,5 @@ __pycache__ | |
|
||
package | ||
*.zip | ||
.mypy_cache | ||
.coverage |
Oops, something went wrong.