-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #7 from arnab39/danibene-add/dev_utils_without_black
Danibene add/dev utils without black
- Loading branch information
Showing
68 changed files
with
1,802 additions
and
540 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 |
---|---|---|
@@ -0,0 +1,28 @@ | ||
# .coveragerc to control coverage.py | ||
[run] | ||
branch = True | ||
source = equiadapt | ||
# omit = bad_file.py | ||
|
||
[paths] | ||
source = | ||
equiadapt/ | ||
*/site-packages/ | ||
|
||
[report] | ||
# Regexes for lines to exclude from consideration | ||
exclude_lines = | ||
# Have to re-enable the standard pragma | ||
pragma: no cover | ||
|
||
# Don't complain about missing debug-only code: | ||
def __repr__ | ||
if self\.debug | ||
|
||
# Don't complain if tests don't hit defensive assertion code: | ||
raise AssertionError | ||
raise NotImplementedError | ||
|
||
# Don't complain if non-runnable code isn't run: | ||
if 0: | ||
if __name__ == .__main__.: |
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,107 @@ | ||
# GitHub Actions configuration **EXAMPLE**, | ||
# MODIFY IT ACCORDING TO YOUR NEEDS! | ||
# Reference: https://docs.github.com/en/actions | ||
|
||
name: tests | ||
|
||
on: | ||
push: | ||
# Avoid using all the resources/limits available by checking only | ||
# relevant branches and tags. Other branches can be checked via PRs. | ||
branches: [main] | ||
tags: ['v[0-9]*', '[0-9]+.[0-9]+*'] # Match tags that resemble a version | ||
pull_request: # Run in every PR | ||
workflow_dispatch: # Allow manually triggering the workflow | ||
schedule: | ||
# Run roughly every 15 days at 00:00 UTC | ||
# (useful to check if updates on dependencies break the package) | ||
- cron: '0 0 1,16 * *' | ||
|
||
permissions: | ||
contents: read | ||
|
||
concurrency: | ||
group: >- | ||
${{ github.workflow }}-${{ github.ref_type }}- | ||
${{ github.event.pull_request.number || github.sha }} | ||
cancel-in-progress: true | ||
|
||
jobs: | ||
prepare: | ||
runs-on: ubuntu-latest | ||
outputs: | ||
wheel-distribution: ${{ steps.wheel-distribution.outputs.path }} | ||
steps: | ||
- uses: actions/checkout@v3 | ||
with: {fetch-depth: 0} # deep clone for setuptools-scm | ||
- uses: actions/setup-python@v4 | ||
id: setup-python | ||
with: {python-version: "3.10"} | ||
- name: Run static analysis and format checkers | ||
run: pipx run pre-commit run --all-files --show-diff-on-failure | ||
- name: Build package distribution files | ||
run: >- | ||
pipx run --python '${{ steps.setup-python.outputs.python-path }}' | ||
tox -e clean,build | ||
- name: Record the path of wheel distribution | ||
id: wheel-distribution | ||
run: echo "path=$(ls dist/*.whl)" >> $GITHUB_OUTPUT | ||
- name: Store the distribution files for use in other stages | ||
# `tests` and `publish` will use the same pre-built distributions, | ||
# so we make sure to release the exact same package that was tested | ||
uses: actions/upload-artifact@v3 | ||
with: | ||
name: python-distribution-files | ||
path: dist/ | ||
retention-days: 1 | ||
|
||
test: | ||
needs: prepare | ||
strategy: | ||
matrix: | ||
python: | ||
- "3.7" # oldest Python supported by PSF | ||
- "3.10" # newest Python that is stable | ||
platform: | ||
- ubuntu-latest | ||
# - macos-latest | ||
# - windows-latest | ||
runs-on: ${{ matrix.platform }} | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- uses: actions/setup-python@v4 | ||
id: setup-python | ||
with: | ||
python-version: ${{ matrix.python }} | ||
- name: Retrieve pre-built distribution files | ||
uses: actions/download-artifact@v3 | ||
with: {name: python-distribution-files, path: dist/} | ||
- name: Run tests | ||
run: >- | ||
pipx run --python '${{ steps.setup-python.outputs.python-path }}' | ||
tox --installpkg '${{ needs.prepare.outputs.wheel-distribution }}' | ||
-- -rFEx --durations 10 --color yes # pytest args | ||
- name: Generate coverage report | ||
run: pipx run coverage lcov -o coverage.lcov | ||
|
||
publish: | ||
if: ${{ github.event_name == 'push' && contains(github.ref, 'refs/tags/') }} | ||
runs-on: ubuntu-latest | ||
permissions: | ||
contents: write | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- uses: actions/setup-python@v4 | ||
with: {python-version: "3.10"} | ||
- name: Retrieve pre-built distribution files | ||
uses: actions/download-artifact@v3 | ||
with: {name: python-distribution-files, path: dist/} | ||
- name: Publish Package | ||
env: | ||
# TODO: Set your PYPI_TOKEN as a secret using GitHub UI | ||
# - https://pypi.org/help/#apitoken | ||
# - https://docs.github.com/en/actions/security-guides/encrypted-secrets | ||
TWINE_REPOSITORY: pypi | ||
TWINE_USERNAME: __token__ | ||
TWINE_PASSWORD: ${{ secrets.PYPI_TOKEN }} | ||
run: pipx run tox -e publish |
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 |
---|---|---|
@@ -0,0 +1,74 @@ | ||
exclude: '^docs/conf.py' | ||
|
||
repos: | ||
- repo: https://github.com/pre-commit/pre-commit-hooks | ||
rev: v4.5.0 | ||
hooks: | ||
- id: trailing-whitespace | ||
- id: check-added-large-files | ||
- id: check-ast | ||
# - id: check-json | ||
- id: check-merge-conflict | ||
- id: check-xml | ||
- id: check-yaml | ||
- id: debug-statements | ||
- id: end-of-file-fixer | ||
- id: requirements-txt-fixer | ||
- id: mixed-line-ending | ||
args: ['--fix=auto'] # replace 'auto' with 'lf' to enforce Linux/Mac line endings or 'crlf' for Windows | ||
|
||
## If you want to automatically "modernize" your Python code: | ||
# - repo: https://github.com/asottile/pyupgrade | ||
# rev: v3.7.0 | ||
# hooks: | ||
# - id: pyupgrade | ||
# args: ['--py37-plus'] | ||
|
||
## If you want to avoid flake8 errors due to unused vars or imports: | ||
# - repo: https://github.com/PyCQA/autoflake | ||
# rev: v2.1.1 | ||
# hooks: | ||
# - id: autoflake | ||
# args: [ | ||
# --in-place, | ||
# --remove-all-unused-imports, | ||
# --remove-unused-variables, | ||
# ] | ||
|
||
# - repo: https://github.com/PyCQA/isort | ||
# rev: 5.13.2 | ||
# hooks: | ||
# - id: isort | ||
|
||
# - repo: https://github.com/psf/black | ||
# rev: 24.2.0 | ||
# hooks: | ||
# - id: black | ||
# language_version: python3 | ||
|
||
## If like to embrace black styles even in the docs: | ||
# - repo: https://github.com/asottile/blacken-docs | ||
# rev: v1.13.0 | ||
# hooks: | ||
# - id: blacken-docs | ||
# additional_dependencies: [black] | ||
|
||
# - repo: https://github.com/PyCQA/flake8 | ||
# rev: 7.0.0 | ||
# hooks: | ||
# - id: flake8 | ||
## You can add flake8 plugins via `additional_dependencies`: | ||
# additional_dependencies: [flake8-bugbear] | ||
|
||
## Check for misspells in documentation files: | ||
# - repo: https://github.com/codespell-project/codespell | ||
# rev: v2.2.5 | ||
# hooks: | ||
# - id: codespell | ||
|
||
## Check for type errors with mypy: | ||
# - repo: https://github.com/pre-commit/mirrors-mypy | ||
# rev: 'v1.8.0' | ||
# hooks: | ||
# - id: mypy | ||
# args: [--disallow-untyped-defs, --ignore-missing-imports] |
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,27 @@ | ||
# Read the Docs configuration file | ||
# See https://docs.readthedocs.io/en/stable/config-file/v2.html for details | ||
|
||
# Required | ||
version: 2 | ||
|
||
# Build documentation in the docs/ directory with Sphinx | ||
sphinx: | ||
configuration: docs/conf.py | ||
|
||
# Build documentation with MkDocs | ||
#mkdocs: | ||
# configuration: mkdocs.yml | ||
|
||
# Optionally build your docs in additional formats such as PDF | ||
formats: | ||
|
||
build: | ||
os: ubuntu-22.04 | ||
tools: | ||
python: "3.11" | ||
|
||
python: | ||
install: | ||
- requirements: docs/requirements.txt | ||
- {path: ., method: pip} |
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,3 @@ | ||
# Contributors | ||
|
||
* Arnab Mondal [[email protected]](mailto:[email protected])s |
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,3 @@ | ||
# Changelog | ||
|
||
## Version 0.1 (development) |
Oops, something went wrong.