KONFLUX demo test
Prerequisites for running the build scenario against your own cluster
- Fork https://github.com/redhat-appstudio-qe/hacbs-test-project and https://github.com/redhat-appstudio-qe/strategy-configs to your GitHub org (specified in
MY_GITHUB_ORG
env var)
- Make sure the cluster you are about to run this test against is public (i.e. hosted on a public cloud provider)
Description
This test simulates typical user scenario.
Test Steps
-
Setup
-
Test Scenario
- The application was created successfully
- The Component (default) Build finished successfully
- Snapshot was created and integration test finished successfully
Default build with Integration test
- Setup
- Create a user namespace
- Create a managed namespace used by release service for validating and releasing the built image
- Create required resources in managed-namespace
- Secret with container image registry credentials (used for pushing the image to container registry)
- Service account that mounts the secret, including required roles and rolebindings
- PVC for the release pipeline
- Secret with cosign-public-key (used for validating the built image by EC)
- Release plan for the targeted application and (user) namespace
- Release strategy, Release plan admission
- Enterprise contract policy
- Create a new branch in a java project on GitHub (that is used as a git source of a component) that will be used as a base branch for PaC pull request (so we don't pollute default branch -
main
)
- Create JBSConfig and related secret in user's (dev) namespace that will trigger jvm-build-service to deploy a jvm-cache to the dev namespace, which will be used for caching java dependencies during build
- Test scenario
- The application and component were created successfully
- Verify that the initial PaC pull request was created in the component's repo (this will also trigger the default build pipelinerun)
- After merging the PR, there should be another build pipelinerun triggered in user namespace
- Make sure the pipelinerun completes successfully
- Make sure that the resulting SBOM file can be pulled from the container registry (where also the image was pushed) and it is saved in expected format
- Make sure that integration test pipelinerun is created and completes successfully
- The release pipeline should succeed and the release should be marked as successful
- Make sure JVM build service is used for rebuilding java component's dependencies and that all related dependency builds complete successfully
Steps to run 'konflux-demos':
- Follow the instructions from the Readme scripts to install AppStudio in e2e mode
- Run the e2e suite:
./bin/e2e-appstudio --ginkgo.label-filter="konflux"
Test Generator
The test specs in konflux-demo-suite are generated dynamically using ginkgo specs.
If you want to test your own Component (repository), all you need to do is to update the TestScenarios
variable in scenarios.go
Run tests with private component
Red Hat AppStudio E2E framework now supports creating components from private quay.io images and GitHub repositories.
Environments
Variable |
Required |
Explanation |
Default Value |
QUAY_OAUTH_USER |
yes |
A quay.io username used to push/build containers |
'' |
QUAY_OAUTH_TOKEN |
yes |
A quay.io token used to push/build containers. Note: the token and username must be a robot account with access to your repository |
'' |
Setup configuration for private repositories
- Define in your configuration for the application and the component
Example of a test scenario for GitHub private repository:
var ApplicationSpecs = []ApplicationSpec{
{
Name: "nodejs private component test",
ApplicationName: "nodejs-private-app",
ComponentSpec: ComponentSpec{
{
Name: "nodejs-private-comp",
Private: true,
Language: "JavaScript",
GitSourceUrl: "https://github.com/redhat-appstudio-qe-bot/nodejs-health-check.git",
},
},
},
}
- Run the e2e tests