mirror of
https://github.com/corda/corda.git
synced 2025-01-03 19:54:13 +00:00
92 lines
3.5 KiB
Markdown
92 lines
3.5 KiB
Markdown
# Compatibility Testing
|
|
|
|
We can build any release we want to test, be it for performance or for compatibility, using the approach outlined below. The test environment includes a driver that lets the nodes issue and pay to a random peer. This way, the notary is put under stress and all combinations of deployed versions are tested eventually.
|
|
|
|
We need to peak into the vaults to make sure the data is in good shape (TODO).
|
|
|
|
#### The tools
|
|
|
|
This package contains scripts and configuration files to
|
|
* build and publish the components of a Corda network,
|
|
* generate YAML files declaring a deployment for Kubernetes,
|
|
* deploy to a cluster, and
|
|
* remove the deployment.
|
|
|
|
#### Preparation
|
|
To run locally you need to have kubectl and docker-cli setup and pointing to a cluster and you need to know your namespace. However, we can move the tasks to team-city, so installing kubectl locally is not required any more.
|
|
|
|
|
|
#### Parameters
|
|
|
|
| Name | Description |
|
|
|------------------------|-------------------------------------------------------------------------------|
|
|
| revison | What to build, Git commit-ish, e.g. branch, tag, SHA1 |
|
|
| namespace | The kubernetes namespace to deploy to (TODO can be autogenerated) |
|
|
| storage-class | The storage class used to provision volumes via persistent volume claims |
|
|
| docker-registry | The docker registry to push and pull container images |
|
|
| kubernetes cluster | The kubernetes context to use |
|
|
|
|
#### Assumptions
|
|
|
|
- You (or the build environment) have access to a kubernetes cluster
|
|
- build environment has push access to docker registry
|
|
- kubernetes cluster has pull access to docker registry via `regsecret` secret (TODO: setup howto)
|
|
- storage can be provisioned (TODO: howto setup)
|
|
|
|
#### Build the container images from a git commit(-ish), e.g. branch-name, tag-name or SHA1.
|
|
|
|
```
|
|
./bin/build-and-publish/node.sh [<commit-ish>]
|
|
./bin/build-and-publish/cordapps.sh [<commit-ish>]
|
|
./bin/build-and-publish/doorman.sh [<commit-ish>]
|
|
./bin/build-and-publish/notary.sh [<commit-ish>]
|
|
./bin/build-and-publish/healthcheck.sh origin/thomas-compatibility-testing
|
|
```
|
|
|
|
The build is carried out in a new temporary git worktree that is removed after
|
|
successful builds.
|
|
|
|
This appends to a file `built/node-images.txt`. To build a couple of releases
|
|
you can specify the releases in a file (one per line) and use
|
|
```
|
|
for r in $(cat releases.txt); do ./bin/build-and-publish/node.sh $r; done
|
|
```
|
|
|
|
#### Generate the deployment config files using
|
|
```
|
|
python generate_config.py -n <namespace> -s <storage-class>
|
|
```
|
|
|
|
#### Deploy
|
|
You can either use `bin/start.sh` to boot and `bin/delete-all.sh` to tear down the network,
|
|
```
|
|
bin/start.sh
|
|
bin/delete-all.sh
|
|
```
|
|
|
|
or apply the config manually
|
|
```
|
|
kubectl apply -f config/<version>
|
|
kubectl scale statefulset <version> --replicas=1
|
|
```
|
|
|
|
### Notes
|
|
|
|
The notary jar is the same as the one of the regular node, but we currently include the
|
|
notary init script for the interaction with the doorman and we include the node.conf
|
|
in the container images. In the future we could use config maps for both the init
|
|
script and the node.conf.
|
|
|
|
|
|
### TODO
|
|
- extend the workload to test exercise notary changes and contract upgrades
|
|
- write the generate-config part in Kotlin
|
|
- design an write better tooling in Kotlin
|
|
- multi notary network
|
|
- generate distributed notary singular identity
|
|
- perhaps config maps support for config
|
|
- publish metrics from the load generators, e.g. error count
|
|
- investigate Helm
|
|
- add more databases
|
|
- use deployments
|