Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Runtime: allow backing multiple candidates of same parachain on different cores #3231

Merged
merged 63 commits into from
Feb 23, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
63 commits
Select commit Hold shift + click to select a range
cab6ab9
Switch statement table from ParaId to CoreIndex
sandreim Feb 1, 2024
d2df658
cargo lock
sandreim Feb 2, 2024
4a8b8d5
add experimental feature
sandreim Feb 6, 2024
9244632
inject core_index from statements
sandreim Feb 6, 2024
22e017b
temporary provisioner fix
sandreim Feb 6, 2024
9dc8927
Support injected `CoreIndex`
sandreim Feb 6, 2024
574b06a
Merge branch 'master' of github.com:paritytech/polkadot-sdk into sand…
sandreim Feb 6, 2024
fbb7351
cargo lock
sandreim Feb 6, 2024
c6b833e
Merge branch 'sandreim/backing_multiple_cores_per_para' of github.com…
sandreim Feb 6, 2024
6c72918
It was damn hard to fix these tests
sandreim Feb 12, 2024
fc5c109
These tests were easy to fix
sandreim Feb 12, 2024
33351b4
Fix comment
sandreim Feb 12, 2024
0d994bf
clippy was angry
sandreim Feb 12, 2024
534c019
A bit refactor and add a test
sandreim Feb 12, 2024
10d86dd
taplo happy
sandreim Feb 12, 2024
d990a65
Merge branch 'sandreim/backing_multiple_cores_per_para' of github.com…
sandreim Feb 13, 2024
fbe1ad5
BackedCandidate: make all members private and provide an interface
sandreim Feb 13, 2024
e74f038
refactor based on new BackedCandidate
sandreim Feb 13, 2024
d898740
Fix all parachain runtime tests affected
sandreim Feb 13, 2024
9e40490
fix more broken test on node side
sandreim Feb 13, 2024
42f46a0
wip new test
sandreim Feb 14, 2024
222609c
review feedback
sandreim Feb 14, 2024
532d363
Merge branch 'sandreim/backing_multiple_cores_per_para' of github.com…
sandreim Feb 14, 2024
ccb2a88
ElasticScalingCoreIndex
sandreim Feb 14, 2024
a5ba157
finish filtering of candidates for elastic scaling
sandreim Feb 14, 2024
a02e896
remove log
sandreim Feb 14, 2024
dd34850
more feedback
sandreim Feb 14, 2024
838a846
Merge remote-tracking branch 'origin/master' into sandreim/backing_mu…
alindima Feb 19, 2024
ad98f18
use next up on available instead of occupied core index
alindima Feb 19, 2024
606d7c4
ElasticScalingCoreIndex -> ElasticScalingMVP
alindima Feb 19, 2024
6fb6b73
Merge remote-tracking branch 'origin/sandreim/backing_multiple_cores_…
alindima Feb 20, 2024
10f6486
rename ElasticScalingCoreIndex
alindima Feb 20, 2024
f9e178d
address some comments
alindima Feb 20, 2024
ec7b660
+1
alindima Feb 20, 2024
578850b
more comments
alindima Feb 20, 2024
362ff1e
add a backing test
alindima Feb 20, 2024
2385369
add rstest
alindima Feb 20, 2024
c793b89
small nits and typos
alindima Feb 20, 2024
8398bb1
Merge remote-tracking branch 'origin/master' into sandreim/backing_mu…
alindima Feb 20, 2024
27ec25b
Merge remote-tracking branch 'origin/sandreim/backing_multiple_cores_…
alindima Feb 20, 2024
9f70276
Merge remote-tracking branch 'origin/master' into sandreim/backing_mu…
alindima Feb 21, 2024
19c9a67
review comments
alindima Feb 21, 2024
d7b6ce8
add zombienet test
alindima Feb 21, 2024
afed2a8
fix existing unit tests
alindima Feb 21, 2024
7ea040d
add prdoc
alindima Feb 21, 2024
79f281b
fix clippy
alindima Feb 21, 2024
7521ed9
try fixing prdoc
alindima Feb 21, 2024
9c3dd5c
cache Validator->Group mapping
alindima Feb 21, 2024
0b0b6d1
Merge remote-tracking branch 'origin/sandreim/backing_multiple_cores_…
alindima Feb 21, 2024
7976e2f
lockfile
alindima Feb 21, 2024
4d6e797
add tests for backedcandidate functions
alindima Feb 21, 2024
4c36440
newlines
alindima Feb 22, 2024
af1cd82
use Arc to avoid cloning
alindima Feb 22, 2024
5cc5b8b
Merge branch 'sandreim/backing_multiple_cores_per_para' into sandreim…
alindima Feb 22, 2024
dc57adb
add check for parachain stall to zombienet test
alindima Feb 22, 2024
bb5968c
add more unit tests
alindima Feb 22, 2024
1ca7a70
Merge remote-tracking branch 'origin/master' into sandreim/runtime_co…
alindima Feb 22, 2024
eb345b0
fix clippy
alindima Feb 22, 2024
058c0c2
refactor
alindima Feb 22, 2024
d4c58bd
fix some bugs and add more unit tests
alindima Feb 23, 2024
cb41758
update some comments
alindima Feb 23, 2024
bffa4e9
review comments
alindima Feb 23, 2024
5d3a85d
fix unit test
alindima Feb 23, 2024
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
Prev Previous commit
Next Next commit
add zombienet test
  • Loading branch information
alindima committed Feb 21, 2024
commit d7b6ce8ce539d6e8f490ab0ff4a0d9a84e334f7a
8 changes: 8 additions & 0 deletions .gitlab/pipeline/zombienet/polkadot.yml
Original file line number Diff line number Diff line change
Expand Up @@ -158,6 +158,14 @@ zombienet-polkadot-functional-0011-async-backing-6-seconds-rate:
--local-dir="${LOCAL_DIR}/functional"
--test="0011-async-backing-6-seconds-rate.zndsl"

zombienet-polkadot-functional-0012-elastic-scaling-mvp:
extends:
- .zombienet-polkadot-common
script:
- /home/nonroot/zombie-net/scripts/ci/run-test-local-env-manager.sh
--local-dir="${LOCAL_DIR}/functional"
--test="0012-elastic-scaling-mvp.zndsl"

zombienet-polkadot-smoke-0001-parachains-smoke-test:
extends:
- .zombienet-polkadot-common
Expand Down
38 changes: 38 additions & 0 deletions polkadot/zombienet_tests/functional/0012-elastic-scaling-mvp.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
[settings]
timeout = 1000
bootnode = true

[relaychain.genesis.runtimeGenesis.patch.configuration.config]
max_validators_per_core = 2
needed_approvals = 4
coretime_cores = 2

[relaychain]
default_image = "{{ZOMBIENET_INTEGRATION_TEST_IMAGE}}"
chain = "rococo-local"
default_command = "polkadot"

[relaychain.default_resources]
limits = { memory = "4G", cpu = "2" }
requests = { memory = "2G", cpu = "1" }

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

[[relaychain.node_groups]]
name = "validator"
count = 3
args = [ "-lparachain=debug,runtime=debug"]

[[parachains]]
id = 2000
default_command = "polkadot-parachain"
add_to_genesis = false
register_para = true
onboard_as_parachain = false

[parachains.collator]
name = "collator2000"
command = "polkadot-parachain"
args = [ "-lparachain=debug" ]
27 changes: 27 additions & 0 deletions polkadot/zombienet_tests/functional/0012-elastic-scaling-mvp.zndsl
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
Description: Test that a paraid acquiring multiple cores does not brick itself if ElasticScalingMVP feature is enabled
Network: ./0012-elastic-scaling-mvp.toml
Creds: config

# Check authority status.
validator: reports node_roles is 4

validator: reports substrate_block_height{status="finalized"} is at least 10 within 100 seconds

# Ensure parachain was able to make progress.
validator: parachain 2000 block height is at least 10 within 200 seconds

# Register the second core assigned to this parachain.
alice: js-script ./0012-register-para.js return is 0 within 600 seconds

validator: reports substrate_block_height{status="finalized"} is at least 35 within 100 seconds

# Parachain will now be stalled
eskimor marked this conversation as resolved.
Show resolved Hide resolved

# Enable the ElasticScalingMVP node feature.
alice: js-script ./0012-enable-node-feature.js with "1" return is 0 within 600 seconds

# Wait two sessions for the config to be updated.
sleep 120 seconds
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It would be better to wait for the actual session change 😬 - If that is not possible right now, we should add that feature.


# Ensure parachain is now making progress.
validator: parachain 2000 block height is at least 30 within 200 seconds
37 changes: 37 additions & 0 deletions polkadot/zombienet_tests/functional/0012-enable-node-feature.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
async function run(nodeName, networkInfo, index) {
const { wsUri, userDefinedTypes } = networkInfo.nodesByName[nodeName];
const api = await zombie.connect(wsUri, userDefinedTypes);

await zombie.util.cryptoWaitReady();

// account to submit tx
const keyring = new zombie.Keyring({ type: "sr25519" });
const alice = keyring.addFromUri("//Alice");

await new Promise(async (resolve, reject) => {
const unsub = await api.tx.sudo
.sudo(api.tx.configuration.setNodeFeature(Number(index), true))
.signAndSend(alice, ({ status, isError }) => {
if (status.isInBlock) {
console.log(
`Transaction included at blockhash ${status.asInBlock}`,
);
} else if (status.isFinalized) {
console.log(
`Transaction finalized at blockHash ${status.asFinalized}`,
);
unsub();
return resolve();
} else if (isError) {
console.log(`Transaction error`);
reject(`Transaction error`);
}
});
});



return 0;
}

module.exports = { run };
37 changes: 37 additions & 0 deletions polkadot/zombienet_tests/functional/0012-register-para.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
async function run(nodeName, networkInfo, _jsArgs) {
const { wsUri, userDefinedTypes } = networkInfo.nodesByName[nodeName];
const api = await zombie.connect(wsUri, userDefinedTypes);

await zombie.util.cryptoWaitReady();

// account to submit tx
const keyring = new zombie.Keyring({ type: "sr25519" });
const alice = keyring.addFromUri("//Alice");

await new Promise(async (resolve, reject) => {
const unsub = await api.tx.sudo
.sudo(api.tx.coretime.assignCore(0, 35, [[{ task: 2000 }, 57600]], null))
.signAndSend(alice, ({ status, isError }) => {
if (status.isInBlock) {
console.log(
`Transaction included at blockhash ${status.asInBlock}`,
);
} else if (status.isFinalized) {
console.log(
`Transaction finalized at blockHash ${status.asFinalized}`,
);
unsub();
return resolve();
} else if (isError) {
console.log(`Transaction error`);
reject(`Transaction error`);
}
});
});



return 0;
}

module.exports = { run };
Loading