Skip to content

Commit

Permalink
Merge branch 'main' into jp-3737
Browse files Browse the repository at this point in the history
  • Loading branch information
drlaw1558 committed Oct 16, 2024
2 parents 22878e6 + dfe1d6d commit 495655d
Show file tree
Hide file tree
Showing 21 changed files with 919 additions and 138 deletions.
1 change: 1 addition & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -45,3 +45,4 @@ jobs:
envs: |
- linux: py311-jwst-cov-xdist
- linux: py311-romancal-cov-xdist
coverage: codecov
36 changes: 15 additions & 21 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,8 @@ repos:
- id: check-symlinks
- id: debug-statements
- id: detect-private-key
- id: end-of-file-fixer
- id: trailing-whitespace
# - id: end-of-file-fixer
# - id: trailing-whitespace

- repo: https://github.com/pre-commit/pygrep-hooks
rev: v1.10.0
Expand All @@ -22,26 +22,26 @@ repos:
- id: rst-inline-touching-normal
- id: text-unicode-replacement-char

- repo: https://github.com/codespell-project/codespell
rev: v2.2.5
hooks:
- id: codespell
args: ["--write-changes"]
additional_dependencies:
- tomli
# - repo: https://github.com/codespell-project/codespell
# rev: v2.2.5
# hooks:
# - id: codespell
# args: ["--write-changes"]
# additional_dependencies:
# - tomli

- repo: https://github.com/astral-sh/ruff-pre-commit
rev: "v0.1.5"
hooks:
- id: ruff
args: ["--fix", "--show-fixes"]
- id: ruff-format
# - id: ruff-format

- repo: https://github.com/MarcoGorelli/cython-lint
rev: v0.15.0
hooks:
- id: cython-lint
- id: double-quote-cython-strings
# - id: double-quote-cython-strings

- repo: https://github.com/pycqa/isort
rev: 5.12.0
Expand All @@ -57,13 +57,7 @@ repos:
additional_dependencies:
- black==22.12.0

- repo: https://github.com/pre-commit/mirrors-prettier
rev: "v3.0.1"
hooks:
- id: prettier

- repo: https://github.com/scientific-python/cookie
rev: 2023.10.27
hooks:
- id: sp-repo-review
additional_dependencies: ["repo-review[cli]"]
# - repo: https://github.com/pre-commit/mirrors-prettier
# rev: "v3.0.1"
# hooks:
# - id: prettier
1 change: 1 addition & 0 deletions changes/292.apichange.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Add `outlier_detection` median calculators from jwst.
1 change: 1 addition & 0 deletions changes/297.general.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Update downstream tests for jwst and romancal to fix pytest configurations.
6 changes: 6 additions & 0 deletions changes/298.general.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
Changed the default `ramp fitting` CI test algorithm to ``OLS_C``. This also revealed
a bug in control flow that allowed for the CHARGELOSS recalculation in error, which
resulted in a crash while attempting to dereference a ``NULL`` pointer. Further, when
creating the optional results product, the object creation was changed to `PyArray_ZEROS`
to ensure invalid data was set to zero. The use of `PyArray_EMPTY` does not initialize
memory, so junk data could be in used array elements.
1 change: 1 addition & 0 deletions changes/299.general.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Add infrastructure for testing memory usage
4 changes: 4 additions & 0 deletions changes/303.general.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
Preparing ramp fitting for the upgrade to python 3.13. In python 3.13, the C-API
function ``PyLong_AsLong`` raises an exception if the object passed to it is
``NoneType``. There are two integer attributes for the ``RampData`` class that
can be ``NoneType``, so a check for ``NoneType`` for these attributes was added.
1 change: 1 addition & 0 deletions changes/305.bugfix.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Fix `IntEnum` saturation flag issue with numpy 2+ for romancal.
1 change: 1 addition & 0 deletions docs/stcal/outlier_detection/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,5 @@ Outlier Detection Utils

description.rst

.. automodapi:: stcal.outlier_detection.median
.. automodapi:: stcal.outlier_detection.utils
59 changes: 29 additions & 30 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,11 @@ norecursedirs = [
]
filterwarnings = [
"error::ResourceWarning",
# Files left open by tests can trigger ResourceWarnings during test
# teardown which otherwise would be converted back into a warning
# by pytest. Turn these PytestUnraisableExceptionWarnings back
# into errors
"error::pytest.PytestUnraisableExceptionWarning",
]
markers = [
"soctests",
Expand All @@ -115,57 +120,59 @@ src = [
]

[tool.ruff.lint]
extend-select = [
"F", # Pyflakes (part of default flake8)
"W", "E", # pycodestyle (part of default flake8)
"I", # isort (import sorting)
select = [
#"F", # Pyflakes (part of default flake8)
#"W", "E", # pycodestyle (part of default flake8)
#"I", # isort (import sorting)
# "N", # pep8-naming
"D", # pydocstyle (docstring style guide)
"UP", # pyupgrade (upgrade code to modern python)
#"D", # pydocstyle (docstring style guide)
#"UP", # pyupgrade (upgrade code to modern python)
"YTT", # flake8-2020 (system version info)
"ANN", # flake8-annotations (best practices for type annotations)
"S", # flake8-bandit (security checks)
#"S", # flake8-bandit (security checks)
"BLE", # flake8-blind-except (prevent blind except statements)
"B", # flake8-bugbear (prevent common gotcha bugs)
#"B", # flake8-bugbear (prevent common gotcha bugs)
"A", # flake8-builtins (prevent shadowing of builtins)
"C4", # flake8-comprehensions (best practices for comprehensions)
"T10", # flake8-debugger (prevent debugger statements in code)
"EM", # flake8-errormessages (best practices for error messages)
#"EM", # flake8-errormessages (best practices for error messages)
"FA", # flake8-future-annotations (correct usage future annotations)
"ISC", # flake8-implicit-str-concat (prevent implicit string concat)
"ICN", # flake8-import-conventions (enforce import conventions)
"G", # flake8-logging-format (best practices for logging)
#"G", # flake8-logging-format (best practices for logging)
"INP", # flake8-no-pep420 (prevent use of PEP420, i.e. implicit name spaces)
"PIE", # flake8-pie (misc suggested improvement linting)
#"PIE", # flake8-pie (misc suggested improvement linting)
# "T20", # flake8-print (prevent print statements in code)
"PT", # flake8-pytest-style (best practices for pytest)
"Q", # flake8-quotes (best practices for quotes)
#"PT", # flake8-pytest-style (best practices for pytest)
#"Q", # flake8-quotes (best practices for quotes)
"RSE", # flake8-raise (best practices for raising exceptions)
"RET", # flake8-return (best practices for return statements)
"SLF", # flake8-self (prevent private member access)
#"RET", # flake8-return (best practices for return statements)
#"SLF", # flake8-self (prevent private member access)
"SLOT", # flake8-slots (require __slots__ for immutable classes)
"SIM", # flake8-simplify (suggest simplifications to code where possible)
#"SIM", # flake8-simplify (suggest simplifications to code where possible)
"TID", # flake8-tidy-imports (prevent banned api and best import practices)
"TCH", # flake8-type-checking (move type checking imports into type checking blocks)
"INT", # flake8-gettext (when to use printf style strings)
# "ARG", # flake8-unused-arguments (prevent unused arguments)
"PTH", # flake8-use-pathlib (prefer pathlib over os.path)
#"PTH", # flake8-use-pathlib (prefer pathlib over os.path)
# "ERA", # eradicate (remove commented out code)
"PGH", # pygrep (simple grep checks)
"PL", # pylint (general linting, flake8 alternative)
"TRY", # tryceratops (linting for try/except blocks)
#"PL", # pylint (general linting, flake8 alternative)
#"TRY", # tryceratops (linting for try/except blocks)
"FLY", # flynt (f-string conversion where possible)
"NPY", # NumPy-specific checks (recommendations from NumPy)
"PERF", # Perflint (performance linting)
#"NPY", # NumPy-specific checks (recommendations from NumPy)
#"PERF", # Perflint (performance linting)
"LOG",
"RUF", # ruff specific checks
#"RUF", # ruff specific checks
]
ignore = [
"ISC001", # interferes with formatter
"PLR0912", # Too many branches
"PLR0913", # Too many arguments
"PLR0915", # Too many statements
"PLR2004", # Magic value used in comparison
"ANN101", # Missing type annotation for self in method
"ANN102", # Missing type annotation for cls in classmethod

# Pydocstyle (to fix over time
"D100", # Undocumented public module
Expand Down Expand Up @@ -229,14 +236,6 @@ line_length = 110
[tool.codespell]
skip = "*.pdf,*.fits,*.asdf,.tox,build,./tags,.git,docs/_build"

[tool.repo-review]
ignore = [
"GH200", # Use dependabot
"PC140", # add MyPy to pre-commit
"PC901", # custom pre-comit.ci message
"MY100", # Use MyPy
]

[tool.cibuildwheel.macos]
archs = [
"x86_64",
Expand Down
Loading

0 comments on commit 495655d

Please sign in to comment.