Skip to content

Commit

Permalink
ci(mypy): add mypy check and adjust code for types
Browse files Browse the repository at this point in the history
  • Loading branch information
d33bs committed Sep 15, 2024
1 parent 37cf141 commit 75b5d1e
Show file tree
Hide file tree
Showing 8 changed files with 121 additions and 17 deletions.
22 changes: 22 additions & 0 deletions .github/workflows/integration-test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,28 @@ jobs:
uses: pre-commit/[email protected]
with:
extra_args: --all-files
python-type-checks:
# This job is used to check Python types
name: Python type checks
# Avoid fail-fast to retain output
strategy:
fail-fast: false
runs-on: ubuntu-22.04
if: github.event_name != 'schedule'
steps:
- name: Checkout repo
uses: actions/checkout@v4
- name: Setup python, and check pre-commit cache
uses: ./.github/actions/setup-env
with:
python-version: ${{ env.TARGET_PYTHON_VERSION }}
cache-pre-commit: false
cache-venv: true
setup-poetry: true
install-deps: true
- name: Run mypy
run: |
poetry run mypy .
integration-test:
name: Pytest (Python ${{ matrix.python-version }} on ${{ matrix.os }})
# Runs pytest on all tested versions of python and OSes
Expand Down
74 changes: 66 additions & 8 deletions poetry.lock

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

1 change: 1 addition & 0 deletions pycytominer/aggregate.py
Original file line number Diff line number Diff line change
Expand Up @@ -128,5 +128,6 @@ def aggregate(
compression_options=compression_options,
float_format=float_format,
)
return None
else:
return population_df
4 changes: 2 additions & 2 deletions pycytominer/cyto_utils/DeepProfiler_processing.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,8 @@
import pandas as pd
import warnings

from pycytominer import aggregate, normalize
from pycytominer.cyto_utils import (
from .pycytominer import aggregate, normalize
from .pycytominer.cyto_utils import (
load_npz_features,
load_npz_locations,
infer_cp_features,
Expand Down
10 changes: 6 additions & 4 deletions pycytominer/cyto_utils/cells.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@

import numpy as np
import pandas as pd
from pycytominer import aggregate, annotate, normalize
from pycytominer.cyto_utils import (
from .pycytominer import aggregate, annotate, normalize
from .pycytominer.cyto_utils import (
aggregate_fields_count,
aggregate_image_features,
assert_linking_cols_complete,
Expand Down Expand Up @@ -714,7 +714,7 @@ def merge_single_cells(
"""

# Load the single cell dataframe by merging on the specific linking columns
sc_df = ""
left_compartment_loaded = False
linking_check_cols = []
merge_suffix_rename = []
for left_compartment in self.compartment_linking_cols:
Expand All @@ -737,7 +737,7 @@ def merge_single_cells(
left_compartment
]

if isinstance(sc_df, str):
if not left_compartment_loaded:
sc_df = self.load_compartment(compartment=left_compartment)

if compute_subsample:
Expand All @@ -752,6 +752,8 @@ def merge_single_cells(
sc_df, how="left", on=subset_logic_df.columns.tolist()
).reindex(sc_df.columns, axis="columns")

left_compartment_loaded = True

sc_df = sc_df.merge(
self.load_compartment(compartment=right_compartment),
left_on=[*self.merge_cols, left_link_col],
Expand Down
2 changes: 1 addition & 1 deletion pycytominer/cyto_utils/collate.py
Original file line number Diff line number Diff line change
Expand Up @@ -131,7 +131,7 @@ def collate(
with sqlite3.connect(cache_backend_file, isolation_level=None) as connection:
cursor = connection.cursor()
if column:
if print:
if printtoscreen:
print(f"Adding a Metadata_Plate column based on column {column}")
cursor.execute("ALTER TABLE Image ADD COLUMN Metadata_Plate TEXT;")
cursor.execute(f"UPDATE image SET Metadata_Plate ={column};")
Expand Down
12 changes: 10 additions & 2 deletions pycytominer/cyto_utils/output.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,10 +12,10 @@
def output(
df: pd.DataFrame,
output_filename: str,
output_type: str = "csv",
output_type: Optional[str] = "csv",
sep: str = ",",
float_format: Optional[str] = None,
compression_options: Union[str, Dict] = {"method": "gzip", "mtime": 1},
compression_options: Optional[Union[str, Dict]] = {"method": "gzip", "mtime": 1},
**kwargs,
):
"""Given an output file and compression options, write file to disk
Expand Down Expand Up @@ -79,6 +79,14 @@ def output(
)
"""

# ensure a default output type
if output_type is None:
output_type = "csv"

# ensure default compression options
if compression_options is None:
compression_options = {"method": "gzip", "mtime": 1}

if output_type == "csv":
compression_options = set_compression_method(compression=compression_options)

Expand Down
13 changes: 13 additions & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ pytest-cov = "^4.1.0"
pre-commit = ">=3.3.2"
commitizen = "^3.12.0"
ruff = "^0.3.4"
mypy = "^1.11.2"

[tool.poetry.group.docs]
optional = true
Expand Down Expand Up @@ -177,6 +178,18 @@ preview = true
[tool.pytest.ini_options]
testpaths = "tests"

[tool.mypy]
# ignores optionally added type packages
ignore_missing_imports = true
# ignores redefinition of variable labels to new types
allow_redefinition = true
exclude = [
# ignore notebook-based walkthroughs
"walkthroughs",
# ignore tests dir
"tests"
]

[build-system]
requires = ["poetry-core>=1.7.0", "poetry-dynamic-versioning>=1.1.0"]
build-backend = "poetry_dynamic_versioning.backend"
Expand Down

0 comments on commit 75b5d1e

Please sign in to comment.