-
-
Notifications
You must be signed in to change notification settings - Fork 14.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ISSUE_TEMPLATE: convert the build reproducibility issue template into…
… an YAML form Signed-off-by: Fernando Rodrigues <alpha@sigmasquadron.net>
- Loading branch information
1 parent
4ebc6f4
commit 707a334
Showing
2 changed files
with
180 additions
and
104 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
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,180 @@ | ||
name: "Unreproducible Package" | ||
description: "Report a package that does not produce a bit-by-bit reproducible result each time it is built." | ||
title: "Unreproducible Package: PACKAGENAME" | ||
labels: ["0.kind: enhancement", "6.topic: reproducible builds"] | ||
body: | ||
- type: "markdown" | ||
attributes: | ||
value: | | ||
<p align="center"> | ||
<a href="https://nixos.org"> | ||
<picture> | ||
<source media="(prefers-color-scheme: light)" srcset="https://raw.githubusercontent.com/NixOS/nixos-homepage/main/public/logo/nixos-hires.png"> | ||
<source media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/NixOS/nixos-artwork/master/logo/nixos-white.png"> | ||
<img src="https://raw.githubusercontent.com/NixOS/nixos-homepage/main/public/logo/nixos-hires.png" width="400px" alt="NixOS logo"> | ||
</picture> | ||
</a> | ||
</p> | ||
Welcome to Nixpkgs. Please replace the **`Unreproducible Package: PACKAGENAME`** template above with the correct package name (As seen in the [NixOS Package Search](https://search.nixos.org/packages)). | ||
> [!NOTE] | ||
> This form is for reporting unreproducible packages. For more information, see the [Reproducible Builds Status](https://reproducible.nixos.org/) page. | ||
> To report a package that fails to build entirely, please use the "Build Failure" form instead. | ||
--- | ||
- type: "dropdown" | ||
id: "version" | ||
attributes: | ||
label: "Nixpkgs Version" | ||
description: | | ||
What version of Nixpkgs are you using? | ||
> [!IMPORTANT] | ||
> If you are using an older or stable version, please update to the latest **unstable** version and check if the package is still unreproducible before continuing this report. | ||
options: | ||
- "Please select a version." | ||
- "- Unstable (25.05)" | ||
- "- Stable (24.11)" | ||
- "- Oldstable (24.05)" | ||
default: 0 | ||
validations: | ||
required: true | ||
- type: "textarea" | ||
id: "introduction" | ||
attributes: | ||
label: "Introduction" | ||
description: | | ||
This is a generic introduction to build reproducibility. | ||
Please replace **PACKAGENAME** below with the canonical package name of the package, as you have done for the title above. | ||
value: | | ||
Building **PACKAGENAME** multiple times does not yield bit-by-bit identical | ||
results, complicating the detection of Continuous Integration (CI) breaches. For | ||
more information on this issue, visit [reproducible-builds.org](https://reproducible-builds.org/). | ||
Fixing bit-by-bit reproducibility also has additional advantages, such as | ||
avoiding hard-to-reproduce bugs, making content-addressed storage more effective | ||
and reducing rebuilds in such systems. | ||
default: 0 | ||
validations: | ||
required: true | ||
- type: "textarea" | ||
id: "how-to-reproduce" | ||
attributes: | ||
label: "Steps to Reproduce" | ||
description: | | ||
This is a step-by-step instruction set meant for maintainers to debug the package that is failing to reproduce. You should also follow it to gather the `diffoscope` logs that will be needed below. | ||
Please replace **<package>** (including the greater than/lesser than signs) below with the canonical package name of the package, as you have done for the introduction and the title above. | ||
value: | | ||
### 1. Build the package | ||
This step will build the package. Specific arguments are passed to the command | ||
to keep the build artifacts so we can compare them in case of differences. | ||
Execute the following command: | ||
``` | ||
nix-build '<nixpkgs>' -A <package> && nix-build '<nixpkgs>' -A <package> --check --keep-failed | ||
``` | ||
Or using the new command line style: | ||
``` | ||
nix build nixpkgs#<package> && nix build nixpkgs#<package> --rebuild --keep-failed | ||
``` | ||
### 2. Compare the build artifacts | ||
If the previous command completes successfully, no differences were found and | ||
there's nothing to do, builds are reproducible. | ||
If it terminates with the error message `error: derivation '<X>' may not be | ||
deterministic: output '<Y>' differs from '<Z>'`, use `diffoscope` to investigate | ||
the discrepancies between the two build outputs. You may need to add the | ||
`--exclude-directory-metadata recursive` option to ignore files and directories | ||
metadata (*e.g. timestamp*) differences. | ||
``` | ||
nix run nixpkgs#diffoscopeMinimal -- --exclude-directory-metadata recursive <Y> <Z> | ||
``` | ||
### 3. Examine the build log | ||
To examine the build log, use: | ||
``` | ||
nix-store --read-log $(nix-instantiate '<nixpkgs>' -A <package>) | ||
``` | ||
Or with the new command line style: | ||
``` | ||
nix log $(nix path-info --derivation nixpkgs#<package>) | ||
``` | ||
validations: | ||
required: true | ||
- type: "textarea" | ||
id: "logs" | ||
attributes: | ||
label: "Diffoscope Log" | ||
description: | | ||
Please copy and paste the relevant `diffoscope` log output, gathered from the steps above. | ||
This will be automatically formatted into a `diff`, so no need for backticks. | ||
render: "diff" | ||
validations: | ||
required: true | ||
- type: "textarea" | ||
id: "additional-context" | ||
attributes: | ||
label: "Additional Context" | ||
description: "Add any other context about the problem here." | ||
placeholder: "This reproducibility issue only happens when the package has all of its optional features enabled." | ||
validations: | ||
required: false | ||
- type: "textarea" | ||
id: "maintainers" | ||
attributes: | ||
label: "Notify Maintainers" | ||
description: | | ||
Please mention the people who are in the `meta.maintainers` list of the offending package. This is done by prefixing the person's username with an '@' character. You can quickly go to the `meta` attribute set of a package by searching for it on the [NixOS Package Search](https://search.nixos.org/packages) and clicking the "📦 Source" button. | ||
Please note that the maintainer attribute name does not always match the maintainer's GitHub username. If that occurs, try looking in [`maintainers/maintainer-list.nix`](https://github.com/NixOS/nixpkgs/blob/master/maintainers/maintainer-list.nix) for the maintainer attribute name, and checking if the maintainer has a listed GitHub username. | ||
If in doubt, check `git blame` for whoever last touched the package. Please add the mentions above the `---` characters. | ||
value: | | ||
--- | ||
**Note for maintainers:** Please tag this issue in your pull request description. (i.e. `Resolves #ISSUE`.) | ||
validations: | ||
required: false | ||
- type: "checkboxes" | ||
id: "sanity-check" | ||
attributes: | ||
label: "I assert that this issue is relevant for Nixpkgs" | ||
description: | | ||
Please ensure that this bug report is not a [duplicate of an existing issue](https://github.com/NixOS/nixpkgs/issues), and that you have read the [NixOS Code of Conduct](https://github.com/NixOS/.github/blob/master/CODE_OF_CONDUCT.md) and agree to abide by it while communicating in any NixOS space. | ||
options: | ||
- label: "I assert that this is not a duplicate of any known issue." | ||
required: true | ||
- label: "I assert that I have read the Code of Conduct and agree to abide by it." | ||
required: true | ||
- type: "markdown" | ||
attributes: | ||
value: | | ||
# Thank you for helping improve Nixpkgs! | ||
--- | ||
- type: "textarea" | ||
id: "priorisation" | ||
attributes: | ||
label: "Is this issue important to you?" | ||
description: | | ||
**Please do not modify this text area!** | ||
This template helps Nixpkgs developers know which issues should be prioritised by allowing users to vote with a :+1: reaction. | ||
This is not a guarantee that highly-requested issues will be fixed first, but it helps us to figure out what's important to users. Please react on other users' issues if you find them important. | ||
value: | | ||
Add a :+1: [reaction] to [issues you find important]. | ||
[reaction]: https://github.blog/2016-03-10-add-reactions-to-pull-requests-issues-and-comments/ | ||
[issues you find important]: https://github.com/NixOS/nixpkgs/issues?q=is%3Aissue+is%3Aopen+sort%3Areactions-%2B1-desc |