From 811d711814326b6a9a5ffd6a5f7a3ceca5780bd2 Mon Sep 17 00:00:00 2001
From: tmpolaczyk <44604217+tmpolaczyk@users.noreply.github.com>
Date: Thu, 28 Sep 2023 12:39:12 +0200
Subject: [PATCH] Add extra consistency checks to pallet_configuration (#276)
---
pallets/configuration/src/lib.rs | 10 +++
pallets/configuration/src/tests.rs | 121 +++++++++++++++++------------
2 files changed, 83 insertions(+), 48 deletions(-)
diff --git a/pallets/configuration/src/lib.rs b/pallets/configuration/src/lib.rs
index b3bbf2651..eb77732d8 100644
--- a/pallets/configuration/src/lib.rs
+++ b/pallets/configuration/src/lib.rs
@@ -79,6 +79,10 @@ impl Default for HostConfiguration {
pub enum InconsistentError {
/// `max_orchestrator_collators` is lower than `min_orchestrator_collators`
MaxCollatorsLowerThanMinCollators,
+ /// `min_orchestrator_collators` must be at least 1
+ MinOrchestratorCollatorsTooLow,
+ /// `max_collators` must be at least 1
+ MaxCollatorsTooLow,
}
impl HostConfiguration {
@@ -88,6 +92,12 @@ impl HostConfiguration {
///
/// This function returns an error if the configuration is inconsistent.
pub fn check_consistency(&self) -> Result<(), InconsistentError> {
+ if self.max_collators < 1 {
+ return Err(InconsistentError::MaxCollatorsTooLow);
+ }
+ if self.min_orchestrator_collators < 1 {
+ return Err(InconsistentError::MinOrchestratorCollatorsTooLow);
+ }
if self.max_orchestrator_collators < self.min_orchestrator_collators {
return Err(InconsistentError::MaxCollatorsLowerThanMinCollators);
}
diff --git a/pallets/configuration/src/tests.rs b/pallets/configuration/src/tests.rs
index eccd99fe3..7e0926d02 100644
--- a/pallets/configuration/src/tests.rs
+++ b/pallets/configuration/src/tests.rs
@@ -15,8 +15,8 @@
// along with Tanssi. If not, see
use {
- crate::{mock::*, HostConfiguration, PendingConfigs},
- frame_support::{assert_ok, dispatch::GetDispatchInfo},
+ crate::{mock::*, Error, HostConfiguration, PendingConfigs},
+ frame_support::{assert_noop, assert_ok, dispatch::GetDispatchInfo},
sp_std::vec,
};
@@ -51,14 +51,14 @@ fn config_sets_default_values() {
#[test]
fn config_set_value() {
new_test_ext_with_genesis(HostConfiguration {
- max_collators: 0,
- min_orchestrator_collators: 0,
- max_orchestrator_collators: 0,
- collators_per_container: 0,
+ max_collators: 100,
+ min_orchestrator_collators: 2,
+ max_orchestrator_collators: 5,
+ collators_per_container: 2,
})
.execute_with(|| {
run_to_block(1);
- assert_eq!(Configuration::config().max_collators, 0);
+ assert_eq!(Configuration::config().max_collators, 100);
assert_ok!(
Configuration::set_max_collators(RuntimeOrigin::root(), 50),
()
@@ -70,23 +70,23 @@ fn config_set_value() {
2,
HostConfiguration {
max_collators: 50,
- min_orchestrator_collators: 0,
- max_orchestrator_collators: 0,
- collators_per_container: 0,
+ min_orchestrator_collators: 2,
+ max_orchestrator_collators: 5,
+ collators_per_container: 2,
}
)]
);
// The session delay is set to 2, and one session is 5 blocks,
// so the change should not happen until block 11
- assert_eq!(Configuration::config().max_collators, 0);
+ assert_eq!(Configuration::config().max_collators, 100);
run_to_block(2);
- assert_eq!(Configuration::config().max_collators, 0);
+ assert_eq!(Configuration::config().max_collators, 100);
// First block of session 1
run_to_block(6);
- assert_eq!(Configuration::config().max_collators, 0);
+ assert_eq!(Configuration::config().max_collators, 100);
run_to_block(10);
- assert_eq!(Configuration::config().max_collators, 0);
+ assert_eq!(Configuration::config().max_collators, 100);
// First block of session 2
run_to_block(11);
assert_eq!(Configuration::config().max_collators, 50);
@@ -96,16 +96,16 @@ fn config_set_value() {
#[test]
fn config_set_many_values_same_block() {
new_test_ext_with_genesis(HostConfiguration {
- max_collators: 0,
- min_orchestrator_collators: 0,
- max_orchestrator_collators: 0,
- collators_per_container: 0,
+ max_collators: 100,
+ min_orchestrator_collators: 2,
+ max_orchestrator_collators: 5,
+ collators_per_container: 2,
})
.execute_with(|| {
run_to_block(1);
- assert_eq!(Configuration::config().max_collators, 0);
- assert_eq!(Configuration::config().collators_per_container, 0);
- assert_eq!(Configuration::config().min_orchestrator_collators, 0);
+ assert_eq!(Configuration::config().max_collators, 100);
+ assert_eq!(Configuration::config().collators_per_container, 2);
+ assert_eq!(Configuration::config().min_orchestrator_collators, 2);
assert_ok!(
Configuration::set_max_collators(RuntimeOrigin::root(), 50),
()
@@ -135,9 +135,9 @@ fn config_set_many_values_same_block() {
// The session delay is set to 2, and one session is 5 blocks,
// so the change should not happen until block 11
run_to_block(10);
- assert_eq!(Configuration::config().max_collators, 0);
- assert_eq!(Configuration::config().collators_per_container, 0);
- assert_eq!(Configuration::config().min_orchestrator_collators, 0);
+ assert_eq!(Configuration::config().max_collators, 100);
+ assert_eq!(Configuration::config().collators_per_container, 2);
+ assert_eq!(Configuration::config().min_orchestrator_collators, 2);
// First block of session 2
run_to_block(11);
assert_eq!(Configuration::config().max_collators, 50);
@@ -149,16 +149,16 @@ fn config_set_many_values_same_block() {
#[test]
fn config_set_many_values_different_blocks() {
new_test_ext_with_genesis(HostConfiguration {
- max_collators: 0,
- min_orchestrator_collators: 0,
- max_orchestrator_collators: 0,
- collators_per_container: 0,
+ max_collators: 100,
+ min_orchestrator_collators: 2,
+ max_orchestrator_collators: 5,
+ collators_per_container: 2,
})
.execute_with(|| {
run_to_block(1);
- assert_eq!(Configuration::config().max_collators, 0);
- assert_eq!(Configuration::config().collators_per_container, 0);
- assert_eq!(Configuration::config().min_orchestrator_collators, 0);
+ assert_eq!(Configuration::config().max_collators, 100);
+ assert_eq!(Configuration::config().collators_per_container, 2);
+ assert_eq!(Configuration::config().min_orchestrator_collators, 2);
assert_ok!(
Configuration::set_max_collators(RuntimeOrigin::root(), 50),
()
@@ -190,9 +190,9 @@ fn config_set_many_values_different_blocks() {
// The session delay is set to 2, and one session is 5 blocks,
// so the change should not happen until block 11
run_to_block(10);
- assert_eq!(Configuration::config().max_collators, 0);
- assert_eq!(Configuration::config().min_orchestrator_collators, 0);
- assert_eq!(Configuration::config().collators_per_container, 0);
+ assert_eq!(Configuration::config().max_collators, 100);
+ assert_eq!(Configuration::config().min_orchestrator_collators, 2);
+ assert_eq!(Configuration::config().collators_per_container, 2);
// First block of session 2
run_to_block(11);
assert_eq!(Configuration::config().max_collators, 50);
@@ -204,16 +204,16 @@ fn config_set_many_values_different_blocks() {
#[test]
fn config_set_many_values_different_sessions() {
new_test_ext_with_genesis(HostConfiguration {
- max_collators: 0,
- min_orchestrator_collators: 0,
- max_orchestrator_collators: 0,
- collators_per_container: 0,
+ max_collators: 100,
+ min_orchestrator_collators: 2,
+ max_orchestrator_collators: 5,
+ collators_per_container: 2,
})
.execute_with(|| {
run_to_block(1);
- assert_eq!(Configuration::config().max_collators, 0);
- assert_eq!(Configuration::config().min_orchestrator_collators, 0);
- assert_eq!(Configuration::config().collators_per_container, 0);
+ assert_eq!(Configuration::config().max_collators, 100);
+ assert_eq!(Configuration::config().min_orchestrator_collators, 2);
+ assert_eq!(Configuration::config().collators_per_container, 2);
assert_ok!(
Configuration::set_max_collators(RuntimeOrigin::root(), 50),
()
@@ -223,9 +223,9 @@ fn config_set_many_values_different_sessions() {
Configuration::set_min_orchestrator_collators(RuntimeOrigin::root(), 20),
()
);
- assert_eq!(Configuration::config().max_collators, 0);
- assert_eq!(Configuration::config().min_orchestrator_collators, 0);
- assert_eq!(Configuration::config().collators_per_container, 0);
+ assert_eq!(Configuration::config().max_collators, 100);
+ assert_eq!(Configuration::config().min_orchestrator_collators, 2);
+ assert_eq!(Configuration::config().collators_per_container, 2);
run_to_block(11);
assert_ok!(
Configuration::set_collators_per_container(RuntimeOrigin::root(), 10),
@@ -241,7 +241,7 @@ fn config_set_many_values_different_sessions() {
max_collators: 50,
min_orchestrator_collators: 20,
max_orchestrator_collators: 20,
- collators_per_container: 0,
+ collators_per_container: 2,
}
),
(
@@ -257,12 +257,12 @@ fn config_set_many_values_different_sessions() {
);
assert_eq!(Configuration::config().max_collators, 50);
- assert_eq!(Configuration::config().min_orchestrator_collators, 0);
- assert_eq!(Configuration::config().collators_per_container, 0);
+ assert_eq!(Configuration::config().min_orchestrator_collators, 2);
+ assert_eq!(Configuration::config().collators_per_container, 2);
run_to_block(16);
assert_eq!(Configuration::config().max_collators, 50);
assert_eq!(Configuration::config().min_orchestrator_collators, 20);
- assert_eq!(Configuration::config().collators_per_container, 0);
+ assert_eq!(Configuration::config().collators_per_container, 2);
run_to_block(21);
assert_eq!(Configuration::config().max_collators, 50);
assert_eq!(Configuration::config().min_orchestrator_collators, 20);
@@ -270,6 +270,31 @@ fn config_set_many_values_different_sessions() {
});
}
+#[test]
+fn config_cannot_set_invalid_values() {
+ new_test_ext_with_genesis(HostConfiguration {
+ max_collators: 100,
+ min_orchestrator_collators: 2,
+ max_orchestrator_collators: 5,
+ collators_per_container: 2,
+ })
+ .execute_with(|| {
+ run_to_block(1);
+ assert_noop!(
+ Configuration::set_max_collators(RuntimeOrigin::root(), 0),
+ Error::::InvalidNewValue
+ );
+ assert_noop!(
+ Configuration::set_min_orchestrator_collators(RuntimeOrigin::root(), 0),
+ Error::::InvalidNewValue
+ );
+ assert_noop!(
+ Configuration::set_max_orchestrator_collators(RuntimeOrigin::root(), 0),
+ Error::::InvalidNewValue
+ );
+ });
+}
+
#[test]
fn weights_assigned_to_extrinsics_are_correct() {
new_test_ext().execute_with(|| {