Release And Deployment
Modelwright releases are maintainer-controlled. A release is not ready because the version changed; it is ready only when package artifacts, documentation, benchmark claims, and publication gates have all been checked.
Current Alpha Target
The current alpha target is 0.1.0a6 with Git tag v0.1.0a6.
The alpha may claim full comparable-output validation for the 2020 FABLE Calculator benchmark:
281,741 comparable cached workbook outputs, 281,741 matches, and zero mismatches. It may also claim
the measured Phase 27 generated-runtime and generated-source-size improvements recorded in
planning/phase-27-performance-memory-hardening.md and the initial modelwright.wrappers
facade helpers for building analyst-facing wrappers around generated models. The 0.1.0a6 alpha
may additionally claim optional pandas-backed notebook helpers, a tracked Examples Gallery with
synthetic and compressed generated 2020 FABLE model examples, and real literate .ipynb notebooks
with stored outputs. It must not claim full-workbook conversion, a full spreadsheet UI, Excel-backed
recalculation equivalence, compact runtime IR production readiness, or stable public API compatibility.
Local Release Checks
Start from a clean checkout and bootstrap the repo-local development environment:
scripts/bootstrap_dev_env.sh
Run the normal local checks:
.venv/bin/python -m ruff check .
.venv/bin/python -m pytest -vv
.venv/bin/sphinx-build -b html docs _build/html -W -v
.venv/bin/python scripts/verify_docs_theme.py _build/html
Build and inspect package artifacts:
scripts/check_release_artifacts.sh
The artifact checker writes outputs under ignored tmp/release-checks/. It builds an sdist and
wheel, runs twine check, inspects artifact contents for private/generated files, installs the wheel
into a clean virtual environment, imports Modelwright, and smoke-tests the installed CLI.
Documentation Deployment Gate
The docs workflow builds Sphinx documentation and uploads the built HTML artifact to GitHub Pages.
The build must pass scripts/verify_docs_theme.py so the uploaded artifact uses the Sphinx Read the
Docs theme rather than a non-Sphinx fallback site.
After a release PR merges to main, verify the published GitHub Pages site from the workflow
deployment result. The deployed page should show the Read the Docs side navigation and should not look
like a plain project page.
TestPyPI Rehearsal
Use the Release GitHub Actions workflow with publish_target set to testpypi.
Requirements:
the
testpypienvironment must be configured by the maintainer;trusted publishing is preferred;
no API tokens should be committed to the repository;
the workflow must build artifacts before publishing them.
After TestPyPI publication, install the package from TestPyPI in a clean environment and run at least:
python -m pip install --index-url https://test.pypi.org/simple/ --extra-index-url https://pypi.org/simple/ modelwright==0.1.0a6
python -c "import modelwright; print(modelwright.__version__)"
modelwright --help
Real PyPI Publication
Real PyPI publication requires maintainer approval and the protected pypi environment.
Expected sequence:
Confirm
CHANGE_LOG.mdand release notes describe the actual alpha boundary.Confirm local and CI release artifact checks pass.
Confirm TestPyPI rehearsal passes or document the exact blocker.
Create the annotated tag, for example
v0.1.0a6.Run the
Releaseworkflow or push the tag, then approve the protected PyPI environment.Verify the package page, wheel install, import, CLI help, docs deployment, and GitHub release notes.
Rollback And Yanking
If a broken alpha reaches PyPI, do not reuse the same version. PyPI artifacts are immutable.
Use one of these responses:
yank the broken release on PyPI if installation should be discouraged but historical availability is still useful;
publish a new alpha such as
0.1.0a7after fixing the issue;update release notes and roadmap entries with the failure mode and mitigation.
Private Data Rules
Release artifacts must not include source workbooks, generated workbook clones, private evaluation
reports, local logs, credentials, or ignored tmp/ material.