GitHub Action
sigstore-conformance
sigstore-conformance
is a conformance testing suite for Sigstore clients.
This suite provides a high-level view of client behaviour as a whole and sets out to answer questions such as:
- Does the client fail when given a signing certificate that isn't signed by the Fulcio root CA during the signing workflow?
- Does the client fail when given an invalid inclusion proof from Rekor during the verification workflow?
- Does the client fail when given an invalid signed certificate timestamp as part of the Fulcio response in the signing workflow?
- etc
An official Sigstore client specification is being worked on at the moment as
part of the Sigstore Architecture Documentation.
Once it's complete, sigstore-conformance
aims to be able to test a client's
adherence to the specification.
Some general testing principles for this suite are:
- Tests should be "workflow" focused. This testing suite is not about fuzzing every possible input to the client CLI or achieving code coverage.
- Tests should exercise the entire client end-to-end rather than individual subsystems in isolation. Tests should include all network interactions with Sigstore infrastructure such as Rekor, Fulcio, etc. These tests should run against Sigstore staging and production infrastructure as well as custom built mock services to test atypical scenarios.
Simply create a new workflow file at .github/workflows/conformance.yml
and add
the sigstore/sigstore-conformance
action to it.
jobs:
conformance:
permissions:
id-token: write
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: install
run: python -m pip install .
- uses: sigstore/[email protected]
with:
entrypoint: sigstore
The only required configuration is the entrypoint
parameter which provides a
command to invoke the client. sigstore-conformance
expects that the client
exposes a CLI that conforms to the protocol outlined here.
In the example above, the workflow is installing sigstore-python
and providing sigstore
as the entrypoint
since this is the command used to
invoke the client.
The workflow that uses this action must be at
.github/workflows/conformance.yml
. This is a current limitation of the test
suite and is required to reliably verify signing certificates.
The relevant job must have permission to request the OIDC token to authenticate
with. This can be done by adding a permission
setting within the job that
invokes the trailofbits/sigstore-conformance
action.
conformance:
permissions:
id-token: write
More information about permission settings can be found here.
In order to run this action in pull requests, there are some extra requirements that must be met.
-
Use the
pull_request_target
workflow trigger instead ofpull_request
. This gives pull requests access to the ambient OIDC credentials required to runsigstore-conformance
. The workflow trigger section of the configuration should look like this:on: pull_request_target: types: [labeled]
-
Create a pull request label called "safe to test". To mitigate the risk of third-party pull requests misusing these credentials, this action will only execute if the pull request has been vetted by a maintainer with write privileges and tagged with this label.
-
In your GitHub repository settings, set "Fork pull request workflows from outside collaborators" to "Require approval for all outside collaborators" (the default setting is to require approval for first-time collaborators). This is not strictly required for the action to function, however we strongly recommend enabling this setting as an extra safeguard to prevent the ambient OIDC credentials from being misused.
sigstore-conformance
is licensed under the Apache 2.0 License.
Everyone interacting with this project is expected to follow the sigstore Code of Conduct
Should you discover any security issues, please refer to sigstore's security process.