For further details and next steps, please refer to our official announcement.
Welcome to Testkube - Your friendly cloud-native testing framework for Kubernetes
Website | Documentation | Twitter | Slack | Blog
Please note that as of Testkube 1.17, the Testkube Dashboard is no longer included with the Open-Source version of Testkube - read the announcement
The below documentation applies to Testkube 1.16 only
Go to Testkube Open Source for documentation on the current Testkube Open Source offering.
Dashboard to manage your Testkube cluster and monitor its real-time results.
The Dashboard is deployed as an application in the cluster. It runs in a browser, and it communicates with the Testkube API Server via Ingress Controller (either provided or bundled).
By default, Dashboard is installed in your cluster along with your Testkube system.
To use the bundled Dashboard, run testkube dashboard
command with
Testkube CLI, to forward the UI and API ports from the Kubernetes
cluster.
⚠️ Testkube Pro and Enterprise
This Dashboard works only for the Testkube Open Source installations. To manage the Testkube in Enterprise or Pro offering, use their corresponding dashboards:
- app.testkube.io for Testkube Pro
- Your Enterprise URL for Testkube Enterprise
✳️ Disable bundling dashboard
To disable Dashboard installation with the Testkube system, you may use
testkube-dashboard.enabled=false
value in the Helm chart.
To run the Testkube Dashboard for development:
- Install Node 20.x
- Fork the repository and clone it (or just clone it, if you are Testkube member or want to read it only)
- Install NPM dependencies
- Run
npm start
command
git clone [email protected]:kubeshop/testkube-dashboard.git && cd testkube-dashboard
npm install
npm start
To learn more about the Testkube Dashboard development and architecture, see the Contribution manual.
✳️ Environment variables
To configure your environment variables, either:
- create
.env
file in the repository, or- export the environment variables globally
You may use both build time and dynamic variables here.
Please note, that you may want to use Create React App's variables too, i.e.
BROWSER=none
to avoid opening the browser.
The Docker images for the Testkube Dashboard are deployed to the Docker Hub as kubeshop/testkube-dashboard.
To start Dashboard using Docker, run the image with the dynamic environment variables you would like to pass, i.e.:
docker run --rm \
-p 8080:8080 \
-e REACT_APP_API_SERVER_ENDPOINT=https://demo.testkube.io/results/v1 \
kubeshop/testkube-dashboard:latest
⚠️ Environment variables
To override the build time environment variables too, you need to build the Docker image on your own.
All the Dashboard is configured with the environment variables.
Part of them is included directly in the production build, while the rest may be modified for the running application.
The latest variables are listed in env.ts file, but for simplicity we keep them documented below too.
✳️ Deep-linking overrides
You may temporarily override the variables in the running application using the query string. The Dashboard seeks for query params starting with
~
and try to override any matching known variable.The query param name should be a variable name, but for simplicity it may omit
REACT_APP_
prefix and is case-insensitive. Short name from the tables above may be used.As an example, to change the API endpoint, you may use
https://demo.testkube.io?~api_server_endpoint=http://localhost:8088
.
The build time environments are loaded from process.env
during build time.
Name | Short Name | Description |
---|---|---|
REACT_APP_SENTRY_DSN |
sentry_dsn |
Sentry DSN for error reporting |
REACT_APP_GTM_ID |
gtm_id |
Google Tag Manager ID for telemetry |
REACT_APP_VERSION |
version |
Dashboard version used for reporting and displaying |
The dynamic variables are loaded from automatically generated env-config.js
file.
Name | Short Name | Description |
---|---|---|
REACT_APP_API_SERVER_ENDPOINT |
api_server_endpoint |
URL for the Testkube API Server |
REACT_APP_DISABLE_TELEMETRY |
disable_telemetry |
Force disabling telemetry in the Dashboard |
REACT_APP_DEBUG_TELEMETRY |
debug_telemetry |
Display debugging information about telemetry in the console log |
REACT_APP_CRD_OPERATOR_REVISION |
crd_operator_revision |
testkube-operator's branch for getting the JSON Schema for CRDs |
REACT_APP_ROUTE_BASENAME |
route_basename |
Basename for the application. Use only when your Dashboard is accessible via different path than / |
To build the Docker image of Testkube Dashboard locally, simply build the Dockerfile, optionally with the environment variables from above.
docker build \
--build-arg REACT_APP_API_SERVER_ENDPOINT=https://demo.testkube.io/results/v1 \
-t kubeshop/testkube-dashboard:latest .
✳️ Environment variables
When you are building images with
docker build
, you may either both set the build time variables, and set defaults for the dynamic variables.
To learn more about the Testkube Dashboard development and architecture, see the Contribution manual.
To learn more about what custom events we expose to Google Tag Manager, see Telemetry document.
- For the documentation of the Testkube system, see docs.testkube.io.
- To see the live demo, you may take a look at demo.testkube.io (some API endpoints are disabled there though, to avoid modifications)
Unleash the power of cloud native testing in Kubernetes with Testkube.