This directory contains the release engineering scripts for Lix.
- FIXME: validation via misc tests in nixpkgs, among other things? What other validation do we need before we can actually release?
- Have a release post ready to go as a PR on the website repo.
- No release-blocker bugs.
The following process can be done either against the staging environment or the live environment.
For staging, the buckets are staging-releases
, staging-cache
, etc.
FIXME: obtainment of signing key for signing cache paths?
- Switch to the release branch you'd like to base your release off of
git switch -c releng/2.91.1 origin/release-2.91
-
Set the version and release name you are going to release in
version.json
.Note: Release names are only for major releases (one of the first two components changes).
See: https://wiki.lix.systems/books/lix-contributors/page/release-names
-
Commit the new
version.json
. -
Next, prepare the release.
python -m releng prepare
is used for this. -
Then we tag the release with
python -m releng tag
, which does:- Git HEAD is detached.
"official_release": true
is set inversion.json
, this is committed, and a release is tagged.- The tag is merged back into the last branch (either
main
for new releases orrelease-MAJOR
for maintenance releases) withgit merge -s ours VERSION
creating a history link but ignoring the tree of the release tag. - Git HEAD is once again detached onto the release tag.
-
Then, we build the release artifacts with
python -m releng build
:- Source tarball is generated with
git archive
, then checksummed. - Manifest for
nix upgrade-nix
is produced and put ins3://releases
at/manifest.nix
and/lix/lix-VERSION
. - Release is built:
hydraJobs.binaryTarball
jobs are built, and joined into a derivation that depends on all of them and adds checksum files. This and the sources go intos3://releases/lix/lix-VERSION
.
- Source tarball is generated with
-
At this point we have a
release/artifacts
andrelease/manual
directory which are ready to publish, and tags ready for publication. No keys are required to do this part. -
Next, we do the publication with
python -m releng upload
:- s3://releases/manifest.nix, changing the default version of Lix for
nix upgrade-nix
. - s3://releases/lix/lix-VERSION/ gets the following contents
- Binary tarballs
- Docs:
manual/
, primarily as an archive of old manuals - Docs as tarball in addition to web.
- Source tarball
- Docker image
- s3://docs/manual/lix/MAJOR
- s3://docs/manual/lix/stable
- The tag is uploaded to the remote repo.
- s3://releases/manifest.nix, changing the default version of Lix for
-
Manually build the installer using the scripts in the installer repo and upload.
FIXME: This currently requires a local Apple Macintosh® aarch64 computer, but we could possibly automate doing it from the aarch64-darwin builder.
-
Manually Push the main/release branch directly to gerrit.
-
If this is a new major release, branch-off to
release-MAJOR
and push that branch directly to gerrit as well (FIXME: special creds for doing this as a service account so we don't need to have the gerrit perms to shoot ourselves in the foot by default because pushing to main is bad?).FIXME: automate branch-off to
release-*
branch. -
Manually (FIXME?) switch back to the release branch, which now has the correct revision.
-
Deal with the external systems (see sections below).
-
Post!!
- Merge release blog post to lix-website.
- Toot about it! https://chaos.social/@lix_project
- Tweet about it! https://twitter.com/lixproject
After the release is created, we do some post-release validation for the Lix packaging in Nixpkgs. Most of these should probably be pre-release validation checks!
-
Build on 4 platforms (
{x86_64,aarch64}-{linux,darwin}
) -
Build with debuginfo: build the
lix.debug
attribute and check it is not an empty directory.FIXME(jade): this applies only to Linux right? I think separate debuginfo on macOS is just broken so we have no debuginfo on there.
-
Verify that manual is present in the
doc
output atshare/doc/nix/manual/
-
Verify that
:doc
in thenix repl
finds documentation forbuiltins
and Nixpkgslib.fix
-
Cross from
x86_64
→aarch64
(pkgsCross.aarch64-multiplatform.lixVersions.lix_2_91
) -
Cross from
x86_64
→riscv64
(pkgsCross.riscv64.lixVersions.lix_2_91
) -
Cross from
x86_64
→armv7l
(pkgsCross.armv7l-hf-multiplatform.lixVersions.lix_2_91
) -
Cross from
aarch64
→x86_64
(pkgsCross.gnu64.lixVersions.lix_2_91
fromaarch64-linux
) -
Static builds on
x86_64-linux
,aarch64-linux
,aarch64-darwin
(pkgs.pkgsStatic.lixVersions.lix_2_91
) -
Perform closure checks and verify that no unnecessary dependencies are included (compare to previous versions:
du -hs result/
andnix path-info -rsh result/
) -
Ensure that previous versions did not explode in size neither in functionality: use the same methodology as above for
lixVersions.lix_2_91
, etc, after the new release is packaged.
The installer is cross-built to several systems from a Mac using build-all.xsh
and upload-to-lix.xsh
in the installer repo (FIXME: currently at least; maybe this should be moved here?).
It installs a binary tarball (FIXME: it should be taught to substitute from cache instead) from some URL; this is the hydraJobs.binaryTarball
.
The default URLs differ by architecture and are configured here.
To automatically do the file changes for a new version, run python3 set_version.py NEW_VERSION
, and submit the result for review.
The website has various release-version dependent pieces.
You can update them with python3 update_version.py NEW_VERSION
, which will regenerate the affected page sources.
These need the release to have been done first as they need hashes for tarballs and such.
The NixOS module has underdeveloped releng in it.
Currently you have to do the whole branch-off dance manually to a release-VERSION
branch and update the tarball URLs to point to the release versions manually.
FIXME: this should be unified with the set_version.py
work in lix-installer
and probably all the releng kept in here, or kept elsewhere.
Related: https://git.lix.systems/lix-project/lix/issues/439
- releases.lix.systems (
s3://releases
):- Each release gets a directory: https://releases.lix.systems/lix/lix-2.90-beta.1
- Binary tarballs:
nix-2.90.0-beta.1-x86_64-linux.tar.xz
, fromhydraJobs.binaryTarball
- Manifest:
manifest.nix
, an attrset of the store paths by architecture.
- Binary tarballs:
- Manifest for
nix upgrade-nix
to the latest release at/manifest.nix
.
- Each release gets a directory: https://releases.lix.systems/lix/lix-2.90-beta.1
- cache.lix.systems (
s3://cache
):- Receives all artifacts for released versions of Lix; is a plain HTTP binary cache.
- install.lix.systems (
s3://install
):~ » aws s3 ls s3://install/lix/ PRE lix-2.90-beta.0/ PRE lix-2.90-beta.1/ PRE lix-2.90.0pre20240411/ PRE lix-2.90.0pre20240412/ 2024-05-05 18:59:11 6707344 lix-installer-aarch64-darwin 2024-05-05 18:59:16 7479768 lix-installer-aarch64-linux 2024-05-05 18:59:14 7982208 lix-installer-x86_64-darwin 2024-05-05 18:59:17 8978352 lix-installer-x86_64-linux ~ » aws s3 ls s3://install/lix/lix-2.90-beta.1/ 2024-05-05 18:59:01 6707344 lix-installer-aarch64-darwin 2024-05-05 18:59:06 7479768 lix-installer-aarch64-linux 2024-05-05 18:59:03 7982208 lix-installer-x86_64-darwin 2024-05-05 18:59:07 8978352 lix-installer-x86_64-linux