Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

zombienet: warp-sync integration test added #12675

Merged
merged 59 commits into from
Dec 7, 2022
Merged
Show file tree
Hide file tree
Changes from 39 commits
Commits
Show all changes
59 commits
Select commit Hold shift + click to select a range
2acfdeb
zombienet: warp-sync integration test added
michalkucharczyk Nov 10, 2022
7c0c9e2
spelling
michalkucharczyk Nov 10, 2022
11ac063
Readme corrected
michalkucharczyk Nov 10, 2022
a843ca1
dir name updated
michalkucharczyk Nov 10, 2022
fa8350c
Check second phase of warp sync
michalkucharczyk Nov 11, 2022
d7a2a75
zombienet pipeline enable + naive test network
michalkucharczyk Nov 14, 2022
0ad17cf
zombienet stage added
michalkucharczyk Nov 14, 2022
eb0f65b
paritypr/substrate-debug image added for zombienet testing
michalkucharczyk Nov 14, 2022
20a109d
debugs added
michalkucharczyk Nov 14, 2022
4e63baa
debugs added
michalkucharczyk Nov 14, 2022
9180782
buildah problem fixed
michalkucharczyk Nov 15, 2022
0e7923f
rollback
michalkucharczyk Nov 15, 2022
df0087c
runner tag
michalkucharczyk Nov 15, 2022
1c52738
test name corrected
michalkucharczyk Nov 15, 2022
05f403f
dir renamed (regex problem)
michalkucharczyk Nov 15, 2022
4307c5d
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
michalkucharczyk Nov 15, 2022
9e1ba5b
common code clean up
michalkucharczyk Nov 15, 2022
e27fbc5
common code clean up
michalkucharczyk Nov 15, 2022
e2867b4
fix
michalkucharczyk Nov 15, 2022
0649849
warp sync test improvements
michalkucharczyk Nov 16, 2022
4d10841
full sha used
michalkucharczyk Nov 16, 2022
cb99176
disable tracing for nodes
michalkucharczyk Nov 16, 2022
37b2167
COMMON_USER -> DOCKERIO_USER
michalkucharczyk Nov 16, 2022
8f1cbe4
refs reworked
michalkucharczyk Nov 16, 2022
8f5f607
paritypr/substrate image used
michalkucharczyk Nov 16, 2022
80de118
DOCKERIO -> DOCKER
michalkucharczyk Nov 16, 2022
6ac5d72
generate-ws-db toml cleanup
michalkucharczyk Nov 16, 2022
5391f96
improvements
michalkucharczyk Nov 18, 2022
c7a33fc
fix
michalkucharczyk Nov 18, 2022
cc7dc23
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
Nov 18, 2022
698e3f9
raw chain spec used
michalkucharczyk Nov 22, 2022
d9bec53
zombienet v1.3.18 used
michalkucharczyk Nov 22, 2022
9dab437
zombienet: warp sync test enabled
michalkucharczyk Nov 21, 2022
97e8817
chain-spec path corrected
michalkucharczyk Nov 21, 2022
49ebf53
log parsing improved
michalkucharczyk Nov 21, 2022
6eacafb
warp sync test: removed validators
michalkucharczyk Nov 22, 2022
ea2cf67
fix
michalkucharczyk Nov 22, 2022
740cd1d
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
michalkucharczyk Nov 22, 2022
d24ce71
review remarks applied
michalkucharczyk Nov 22, 2022
d802895
dir test name changed: 0000_block_building -> 0000-block-building
michalkucharczyk Nov 23, 2022
4d92172
transaction finalized test added
michalkucharczyk Nov 23, 2022
f0ce356
transaction finalized test: error handling improved
michalkucharczyk Nov 23, 2022
84dbbce
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
Nov 24, 2022
b0866fc
trigger CI job
michalkucharczyk Nov 25, 2022
5fa03d7
trigger CI job
michalkucharczyk Nov 25, 2022
84e1d78
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
Nov 25, 2022
39538a8
trigger CI job
michalkucharczyk Nov 25, 2022
6bfc470
trigger CI job
michalkucharczyk Nov 26, 2022
c85fa51
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
Nov 26, 2022
5268d83
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
Nov 30, 2022
9d00ccf
Explicitly touch `version.rs` to invalidate the related cache
rcny Dec 1, 2022
847a7a9
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
Dec 2, 2022
4674c12
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
Dec 5, 2022
c8b8194
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
Dec 5, 2022
e5e7165
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
Dec 5, 2022
60185e8
zombienet add logs as artifacts
pepoviola Dec 5, 2022
d7f5835
Revert "Explicitly touch `version.rs` to invalidate the related cache"
michalkucharczyk Dec 7, 2022
f4ec3a9
Merge remote-tracking branch 'origin/master' into mku-basic-warp-sync…
michalkucharczyk Dec 7, 2022
827a058
file naming changed
michalkucharczyk Dec 7, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 18 additions & 0 deletions .gitlab-ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ stages:
- test
- build
- publish
- zombienet
- deploy
- notify

Expand All @@ -51,6 +52,7 @@ variables:
BUILDAH_IMAGE: "quay.io/buildah/stable:v1.27"
RUSTY_CACHIER_SINGLE_BRANCH: master
RUSTY_CACHIER_DONT_OPERATE_ON_MAIN_BRANCH: "true"
ZOMBIENET_IMAGE: "docker.io/paritytech/zombienet:v1.3.18"

default:
retry:
Expand Down Expand Up @@ -183,14 +185,28 @@ default:
- frame/contracts/**/*
- primitives/sandbox/**/*

.publish-refs:
rules:
- if: $CI_PIPELINE_SOURCE == "pipeline"
when: never
- if: $CI_PIPELINE_SOURCE == "web"
- if: $CI_PIPELINE_SOURCE == "schedule"
- if: $CI_COMMIT_REF_NAME == "master"
- if: $CI_COMMIT_REF_NAME =~ /^v[0-9]+\.[0-9]+.*$/ # i.e. v1.0, v2.1rc1

.build-refs:
michalkucharczyk marked this conversation as resolved.
Show resolved Hide resolved
# publish-refs + PRs
rules:
- if: $CI_PIPELINE_SOURCE == "pipeline"
when: never
- if: $CI_PIPELINE_SOURCE == "web"
- if: $CI_PIPELINE_SOURCE == "schedule"
- if: $CI_COMMIT_REF_NAME == "master"
- if: $CI_COMMIT_REF_NAME =~ /^v[0-9]+\.[0-9]+.*$/ # i.e. v1.0, v2.1rc1
- if: $CI_COMMIT_REF_NAME =~ /^[0-9]+$/ # PRs

.zombienet-refs:
extends: .build-refs

.nightly-pipeline:
rules:
Expand Down Expand Up @@ -222,6 +238,8 @@ include:
- scripts/ci/gitlab/pipeline/build.yml
# publish jobs
- scripts/ci/gitlab/pipeline/publish.yml
# zombienet jobs
- scripts/ci/gitlab/pipeline/zombienet.yml

#### stage: deploy

Expand Down
3 changes: 2 additions & 1 deletion scripts/ci/docker/subkey.Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,11 @@ FROM docker.io/library/ubuntu:20.04
# metadata
ARG VCS_REF
ARG BUILD_DATE
ARG IMAGE_NAME

LABEL io.parity.image.authors="devops-team@parity.io" \
io.parity.image.vendor="Parity Technologies" \
io.parity.image.title="parity/subkey" \
io.parity.image.title="${IMAGE_NAME}" \
io.parity.image.description="Subkey: key generating utility for Substrate." \
io.parity.image.source="/~https://github.com/paritytech/substrate/blob/${VCS_REF}/scripts/ci/docker/subkey.Dockerfile" \
io.parity.image.revision="${VCS_REF}" \
Expand Down
3 changes: 2 additions & 1 deletion scripts/ci/docker/substrate.Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,11 @@ FROM docker.io/library/ubuntu:20.04
# metadata
ARG VCS_REF
ARG BUILD_DATE
ARG IMAGE_NAME

LABEL io.parity.image.authors="devops-team@parity.io" \
io.parity.image.vendor="Parity Technologies" \
io.parity.image.title="parity/substrate" \
io.parity.image.title="${IMAGE_NAME}" \
io.parity.image.description="Substrate: The platform for blockchain innovators." \
io.parity.image.source="/~https://github.com/paritytech/substrate/blob/${VCS_REF}/scripts/ci/docker/Dockerfile" \
io.parity.image.revision="${VCS_REF}" \
Expand Down
2 changes: 1 addition & 1 deletion scripts/ci/gitlab/pipeline/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ build-linux-substrate:
extends:
- .collect-artifacts
- .docker-env
- .build-refs
- .publish-refs
variables:
# this variable gets overriden by "rusty-cachier environment inject", use the value as default
CARGO_TARGET_DIR: "$CI_PROJECT_DIR/target"
Expand Down
51 changes: 42 additions & 9 deletions scripts/ci/gitlab/pipeline/publish.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,32 +2,33 @@
# This file is part of .gitlab-ci.yml
# Here are all jobs that are executed during "publish" stage

.build-push-docker-image:
.build-push-docker-image-common:
extends:
- .build-refs
- .kubernetes-env
stage: publish
variables:
CI_IMAGE: $BUILDAH_IMAGE
GIT_STRATEGY: none
DOCKERFILE: $PRODUCT.Dockerfile
IMAGE_NAME: docker.io/parity/$PRODUCT
IMAGE_NAME: docker.io/$IMAGE_PATH
before_script:
- cd ./artifacts/$PRODUCT/
- VERSION="$(cat ./VERSION)"
- echo "${PRODUCT} version = ${VERSION}"
- test -z "${VERSION}" && exit 1
script:
- test "$Docker_Hub_User_Parity" -a "$Docker_Hub_Pass_Parity" ||
- test "$DOCKER_USER" -a "$DOCKER_PASS" ||
( echo "no docker credentials provided"; exit 1 )
- buildah bud
--format=docker
--build-arg VCS_REF="${CI_COMMIT_SHA}"
--build-arg BUILD_DATE="$(date -u '+%Y-%m-%dT%H:%M:%SZ')"
--build-arg IMAGE_NAME="${IMAGE_PATH}"
--tag "$IMAGE_NAME:$VERSION"
--tag "$IMAGE_NAME:latest"
--file "$DOCKERFILE" .
- echo "$Docker_Hub_Pass_Parity" |
buildah login --username "$Docker_Hub_User_Parity" --password-stdin docker.io
- echo "$DOCKER_PASS" |
buildah login --username "$DOCKER_USER" --password-stdin docker.io
- buildah info
- buildah push --format=v2s2 "$IMAGE_NAME:$VERSION"
- buildah push --format=v2s2 "$IMAGE_NAME:latest"
Expand All @@ -38,17 +39,49 @@
- echo "SUBSTRATE_IMAGE_TAG=${IMAGE_TAG}" | tee -a ./artifacts/$PRODUCT/build.env
- cat ./artifacts/$PRODUCT/build.env

.build-push-docker-image:
extends:
- .publish-refs
- .build-push-docker-image-common
variables:
IMAGE_PATH: parity/$PRODUCT
DOCKER_USER: $Docker_Hub_User_Parity
DOCKER_PASS: $Docker_Hub_Pass_Parity


# publish image to docker.io/paritypr, (e.g. for later use in zombienet testing)
.build-push-image-temporary:
extends:
- .build-refs
- .build-push-docker-image-common
variables:
IMAGE_PATH: paritypr/$PRODUCT
DOCKER_USER: $PARITYPR_USER
DOCKER_PASS: $PARITYPR_PASS

publish-docker-substrate:
stage: publish
extends: .build-push-docker-image
needs:
- job: build-linux-substrate
artifacts: true
variables:
PRODUCT: substrate

publish-docker-substrate-temporary:
extends: .build-push-image-temporary
needs:
- job: build-linux-substrate
artifacts: true
variables:
PRODUCT: substrate
artifacts:
reports:
# this artifact is used in zombienet-tests job
# https://docs.gitlab.com/ee/ci/multi_project_pipelines.html#with-variable-inheritance
dotenv: ./artifacts/$PRODUCT/build.env
expire_in: 24h

publish-docker-subkey:
stage: publish
extends: .build-push-docker-image
needs:
- job: build-subkey-linux
Expand All @@ -59,7 +92,7 @@ publish-docker-subkey:
publish-s3-release:
stage: publish
extends:
- .build-refs
- .publish-refs
- .kubernetes-env
needs:
- job: build-linux-substrate
Expand Down
43 changes: 43 additions & 0 deletions scripts/ci/gitlab/pipeline/zombienet.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
# This file is part of .gitlab-ci.yml
# Here are all jobs that are executed during "zombienet" stage

# common settings for all zombienet jobs
.zombienet-common:
before_script:
- echo "Zombie-net Tests Config"
- echo "${ZOMBIENET_IMAGE}"
- echo "${SUBSTRATE_IMAGE_NAME} ${SUBSTRATE_IMAGE_TAG}"
- echo "${GH_DIR}"
- export DEBUG=zombie,zombie::network-node
- export ZOMBIENET_INTEGRATION_TEST_IMAGE=${SUBSTRATE_IMAGE_NAME}:${SUBSTRATE_IMAGE_TAG}
- echo "${ZOMBIENET_INTEGRATION_TEST_IMAGE}"
stage: zombienet
image: "${ZOMBIENET_IMAGE}"
needs:
- job: publish-docker-substrate-temporary
extends:
- .kubernetes-env
- .zombienet-refs
variables:
GH_DIR: "/~https://github.com/paritytech/substrate/tree/${CI_COMMIT_SHA}/zombienet"
allow_failure: true
retry: 2
tags:
- zombienet-polkadot-integration-test

zombienet-0000-block-building:
extends:
- .zombienet-common
script:
- /home/nonroot/zombie-net/scripts/ci/run-test-env-manager.sh
--github-remote-dir="${GH_DIR}/0000_block_building"
--test="0000-block-building.zndsl"


zombienet-0001-basic-warp-sync:
extends:
- .zombienet-common
script:
- /home/nonroot/zombie-net/scripts/ci/run-test-env-manager.sh
--github-remote-dir="${GH_DIR}/0001-basic-warp-sync"
--test="0001-test-warp-sync.zndsl"
15 changes: 15 additions & 0 deletions zombienet/0000_block_building/0000-block-building.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
[settings]
michalkucharczyk marked this conversation as resolved.
Show resolved Hide resolved
enable_tracing = false

[relaychain]
default_image = "{{ZOMBIENET_INTEGRATION_TEST_IMAGE}}"
default_command = "substrate"
chain = "local"

[[relaychain.nodes]]
name = "alice"
validator = true

[[relaychain.nodes]]
name = "bob"
validator = true
18 changes: 18 additions & 0 deletions zombienet/0000_block_building/0000-block-building.zndsl
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
Description: Block building
Network: ./0000-block-building.toml
Creds: config

alice: is up
bob: is up

alice: reports node_roles is 4
bob: reports node_roles is 4

alice: reports peers count is at least 1
bob: reports peers count is at least 1

alice: reports block height is at least 5 within 20 seconds
bob: reports block height is at least 5 within 20 seconds

alice: count of log lines containing "error" is 0 within 2 seconds
bob: count of log lines containing "error" is 0 within 2 seconds
101 changes: 101 additions & 0 deletions zombienet/0001-basic-warp-sync/0001-README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
# Test design
The `warp-sync` test works on predefined database which is stored in the cloud and
fetched by the test. `alice` and `bob` nodes are spun up using this database snapshot in full node mode.

As `warp-sync` requires at least 3 peers, the test spawns the `charlie` full node which uses the same database snapshot.

The `dave` node executed with `--sync warp` syncs database with the rest of the network.

# How to prepare database
Database was prepared using the following zombienet file (`0001-generate-warp-sync-database.toml`):
```
[relaychain]
default_image = "docker.io/parity/substrate:master"
default_command = "substrate"

chain = "gen-db"

chain_spec_path = "0001-chain-spec.json"

[[relaychain.nodes]]
name = "alice"
validator = true

[[relaychain.nodes]]
name = "bob"
validator = true
```

The zombienet shall be executed with the following command, and run for some period of time to allow for few grandpa eras.
```
./zombienet-linux spawn --dir ./db-test-gen --provider native 0001-generate-warp-sync-database.toml
```

Once the zombienet is stopped, the database snapshot
(`{alice,bob}/data/chains/local_testnet/db/` dirs) was created using the following
commands:
```bash
mkdir -p db-snapshot/{alice,bob}/data/chains/local_testnet/db/
cp -r db-test-gen/alice/data/chains/local_testnet/db/full db-snapshot/alice/data/chains/local_testnet/db/
cp -r db-test-gen/bob/data/chains/local_testnet/db/full db-snapshot/bob/data/chains/local_testnet/db/
```

The file format should be `tar.gz`. File shall contain `local_testnet` folder and its subfolders, e.g.:
```
$ tar tzf chains.tgz | head
local_testnet/
local_testnet/db/
local_testnet/db/full/
...
local_testnet/db/full/000469.log
```

Sample command to prepare archive:
```
tar -C db-snapshot/alice/data/chains/ -czf chains.tgz local_testnet
```

Also refer to: [zombienet#578](/~https://github.com/paritytech/zombienet/issues/578)

The `raw` chain-spec shall also be saved: `db-test-gen/gen-db-raw.json`.

# Where to upload database
The access to this [bucket](https://console.cloud.google.com/storage/browser/zombienet-db-snaps/) is required.

Sample public path is: `https://storage.googleapis.com/zombienet-db-snaps/substrate/0001-basic-warp-sync/chains-0bb3f0be2ce41b5615b224215bcc8363aa0416a6.tgz`.

The database file path should be `substrate/XXXX-test-name/file-SHA1SUM.tgz`, where `SHA1SUM` is a `sha1sum` of the file.

# Chain spec
Chain spec was simply built with:
```
substrate build-spec --chain=local > chain-spec.json
```

Please note that `0001-chain-spec.json` committed into repository is `raw` version produced by `zombienet` during database snapshot generation. Zombienet applies some modifications to plain versions of chain-spec.

# Run the test
Test can be run with the following command:
```
zombienet-linux test --dir db-snapshot --provider native 0001-test-warp-sync.zndsl
```

*NOTE*: currently blocked by: [zombienet#578](/~https://github.com/paritytech/zombienet/issues/578)


# Save some time hack
Substrate can be patched to reduce the grandpa session period.
```
diff --git a/bin/node/runtime/src/constants.rs b/bin/node/runtime/src/constants.rs
index 23fb13cfb0..89f8646291 100644
--- a/bin/node/runtime/src/constants.rs
+++ b/bin/node/runtime/src/constants.rs
@@ -63,7 +63,7 @@ pub mod time {

// NOTE: Currently it is not possible to change the epoch duration after the chain has started.
// Attempting to do so will brick block production.
- pub const EPOCH_DURATION_IN_BLOCKS: BlockNumber = 10 * MINUTES;
+ pub const EPOCH_DURATION_IN_BLOCKS: BlockNumber = 1 * MINUTES / 2;
pub const EPOCH_DURATION_IN_SLOTS: u64 = {
const SLOT_FILL_RATE: f64 = MILLISECS_PER_BLOCK as f64 / SLOT_DURATION as f64
```
Loading