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

feat: ⏫ upgrade to Polkadot SDK stable2407 #222

Merged
merged 71 commits into from
Oct 11, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
71 commits
Select commit Hold shift + click to select a range
2eff08b
refactor: :art: moved runtime apis into their own file
TDemeco Sep 27, 2024
303feb3
fix: :arrow_up: fix upgrade to polkadot-sdk v1.10.0
TDemeco Sep 27, 2024
e5ba5bd
Merge branch 'main' into update/polkadot-sdk-1.10.0
TDemeco Sep 27, 2024
3e4328d
fix: :bug: add removed runtime api `get_worst_case_scenario_slashable…
TDemeco Sep 27, 2024
3605611
fix: :bug: add missing generic in storage providers runtime api
TDemeco Sep 27, 2024
3659377
chore: :label: run typegen
TDemeco Sep 27, 2024
c1219f1
style: :rotating_light: run cargo fmt
TDemeco Sep 27, 2024
5ac0258
fix: :art: fix cargo clippy
TDemeco Sep 28, 2024
e82a113
Merge branch 'main' into update/polkadot-sdk-1.10.0
TDemeco Sep 28, 2024
91ae601
fix: :ambulance: fix mocked relay chain randomness
TDemeco Sep 28, 2024
97c0b64
style: :rotating_light: run cargo fmt
TDemeco Sep 28, 2024
787d1df
chore: :rotating_light: temporary remove unused import (until v1.13.0)
TDemeco Sep 28, 2024
9653a4e
Merge branch 'main' into update/polkadot-sdk-1.10.0
TDemeco Sep 28, 2024
6fb8bd4
fix: :adhesive_bandage: update `query_earliest_file_volunteer_tick` r…
TDemeco Sep 28, 2024
cde6b90
fix: :ambulance: fix issues with merge from main
TDemeco Sep 28, 2024
570e548
style: :rotating_light: run cargo fmt
TDemeco Sep 28, 2024
9bb33cc
feat: :package: initial update to polkadot sdk v1.11.0
TDemeco Sep 30, 2024
e28f09b
feat: :arrow_up: finish upgrade to polkadot sdk v1.11.0
TDemeco Sep 30, 2024
2947b01
Merge branch 'main' into update/polkadot-sdk-1.10.0
TDemeco Sep 30, 2024
5c07140
chore: :label: run typegen
TDemeco Sep 30, 2024
f86f2c1
Merge branch 'update/polkadot-sdk-1.10.0' into update/polkadot-sdk-1.…
TDemeco Sep 30, 2024
f4964fc
chore: :label: run typegen
TDemeco Sep 30, 2024
f85735d
fix: :white_check_mark: fix node tests after rebenchmark of balances …
TDemeco Oct 1, 2024
b7090b5
feat: :arrow_up: update to Polkadot SDK v1.12.0
TDemeco Oct 3, 2024
889fa3c
feat: :arrow_up: update to Polkadot SDK v1.13.0
TDemeco Oct 4, 2024
9587713
fix: :arrow_up: finish upgrading to Polkadot SDK v1.13.0
TDemeco Oct 4, 2024
5142fdd
Merge branch 'main' into update/polkadot-sdk-v1.13.0
TDemeco Oct 4, 2024
4eb7f24
fix: :bug: add missing imports (and run typegen)
TDemeco Oct 4, 2024
73a343f
fix: :arrow_down: rollback polkadotjs api dependencies
TDemeco Oct 4, 2024
090bfa6
chore: :label: rerun pnpm typegen
TDemeco Oct 4, 2024
ff67efb
feat: :construction: start upgrade to Polkadot SDK 1.14.0
TDemeco Oct 7, 2024
b857c6d
fix: :rotating_light: format and lint
TDemeco Oct 7, 2024
c6157a0
fix: :rotating_light: remove trailing whitespace
TDemeco Oct 7, 2024
91d7b73
Merge branch 'update/polkadot-sdk-v1.13.0' into update/polkadot-sdk-v…
TDemeco Oct 7, 2024
550ccd0
feat: :arrow_up: upgrade to Polkadot SDK v1.14.0
TDemeco Oct 7, 2024
d2b13b2
Merge branch 'main' into update/polkadot-sdk-v1.14.0
TDemeco Oct 7, 2024
830357a
Merge branch 'main' into update/polkadot-sdk-v1.14.0
TDemeco Oct 7, 2024
3ff32ca
chore: :label: run typegen
TDemeco Oct 7, 2024
79435a7
fix: :rotating_light: run cargo fmt
TDemeco Oct 7, 2024
9c320c8
docs: :fire: remove wrong license docs
TDemeco Oct 7, 2024
a9e2dc9
feat: :arrow_up: update Polkadot SDK to stable2407
TDemeco Oct 7, 2024
a6fc3b1
Merge branch 'main' into update/polkadot-sdk-stable2407
TDemeco Oct 7, 2024
5c6a849
chore: :label: run typegen
TDemeco Oct 7, 2024
23ad7e9
Merge branch 'main' into update/polkadot-sdk-stable2407
TDemeco Oct 8, 2024
7b55ca3
chore: :label: run typegen
TDemeco Oct 8, 2024
db2fb69
fix: :white_check_mark: fix bsp-threshold test
TDemeco Oct 8, 2024
b59cf44
fix: :green_heart: try to fix tests in CI
TDemeco Oct 8, 2024
39439f7
fix: :white_check_mark: try again to fix the integration tests in the CI
TDemeco Oct 8, 2024
be86ef7
test: :test_tube: fix batch file confirm storing test
TDemeco Oct 9, 2024
d099669
fix: :white_check_mark: remove unused imports from volunteer test
TDemeco Oct 9, 2024
3224437
fix: :white_check_mark: add wait for file in file storage success and…
TDemeco Oct 9, 2024
70dde30
fix: :white_check_mark: wait more time for bsp volunteering
TDemeco Oct 9, 2024
c9744a3
test: :test_tube: fix a few issues
TDemeco Oct 9, 2024
e2d8a3f
fix: :white_check_mark: maybe (hopefully) finish fixing tests
TDemeco Oct 9, 2024
cc9d406
fix: :white_check_mark: fix new bsps not catching up to the tip of th…
TDemeco Oct 9, 2024
ad40421
test: :white_check_mark: disconnect api
TDemeco Oct 9, 2024
a225b39
test: :bug: fix timeout bug
TDemeco Oct 10, 2024
77b8978
test: :white_check_mark: add initialization wait + fix single bsp ini…
TDemeco Oct 10, 2024
31bed63
chore: :rotating_light: removed unused variables
TDemeco Oct 10, 2024
fb316e5
test: :bug: initialised bsp net now correctly waits for bsp to store …
TDemeco Oct 10, 2024
200cf20
test: :bug: add missing wait for chain tip sync on test
TDemeco Oct 10, 2024
be63330
fix: :adhesive_bandage: Remove sleeps from single tests, in favour of…
ffarall Oct 10, 2024
5b48a67
fix: :rotating_light: Fix TS typecheck
ffarall Oct 10, 2024
a9c766c
fix: :bug: Wait for sync in onboard tests
ffarall Oct 10, 2024
cf60ca1
fix: :rotating_light: Remove unused `sleep` import
ffarall Oct 10, 2024
065235e
test: :white_check_mark: Remove second sealBlock after file deletion …
ffarall Oct 10, 2024
6dbd4a6
fix: :bug: Make blockchain service check pending forest root writes w…
ffarall Oct 10, 2024
7d6feb6
test: :white_check_mark: add `bspFileDeletionCompleted` wait using po…
TDemeco Oct 10, 2024
4e7f5e7
test: :white_check_mark: Fix volunteer test which after recent optims…
ffarall Oct 10, 2024
30c56ea
fix: :fire: remove leftover condition from payment stream deletion
TDemeco Oct 10, 2024
26fc867
fix: :bug: Delete payment stream when executing stop storing for inso…
ffarall Oct 10, 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
5,505 changes: 2,509 additions & 2,996 deletions Cargo.lock

Large diffs are not rendered by default.

206 changes: 103 additions & 103 deletions Cargo.toml

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion api-augment/storagehub.json

Large diffs are not rendered by default.

23 changes: 23 additions & 0 deletions client/blockchain-service/src/commands.rs
Original file line number Diff line number Diff line change
Expand Up @@ -183,6 +183,10 @@ pub enum BlockchainServiceCommand {
callback:
tokio::sync::oneshot::Sender<Result<MainStorageProviderId, QueryMspIdOfBucketIdError>>,
},
ReleaseForestRootWriteLock {
forest_root_write_tx: tokio::sync::oneshot::Sender<()>,
callback: tokio::sync::oneshot::Sender<Result<()>>,
},
}

/// Interface for interacting with the BlockchainService actor.
Expand Down Expand Up @@ -361,6 +365,12 @@ pub trait BlockchainServiceInterface {
&self,
bucket_id: BucketId,
) -> Result<MainStorageProviderId, QueryMspIdOfBucketIdError>;

/// Helper function to release the forest root write lock.
async fn release_forest_root_write_lock(
&self,
forest_root_write_tx: tokio::sync::oneshot::Sender<()>,
) -> Result<()>;
}

/// Implement the BlockchainServiceInterface for the ActorHandle<BlockchainService>.
Expand Down Expand Up @@ -807,4 +817,17 @@ impl BlockchainServiceInterface for ActorHandle<BlockchainService> {
self.send(message).await;
rx.await.expect("Failed to receive response from BlockchainService. Probably means BlockchainService has crashed.")
}

async fn release_forest_root_write_lock(
&self,
forest_root_write_tx: tokio::sync::oneshot::Sender<()>,
) -> Result<()> {
let (callback, rx) = tokio::sync::oneshot::channel();
let message = BlockchainServiceCommand::ReleaseForestRootWriteLock {
forest_root_write_tx,
callback,
};
self.send(message).await;
rx.await.expect("Failed to receive response from BlockchainService. Probably means BlockchainService has crashed.")
}
}
25 changes: 25 additions & 0 deletions client/blockchain-service/src/handler.rs
Original file line number Diff line number Diff line change
Expand Up @@ -888,6 +888,31 @@ impl Actor for BlockchainService {
}
}
}
BlockchainServiceCommand::ReleaseForestRootWriteLock {
forest_root_write_tx,
callback,
} => {
// Release the forest root write "lock".
let forest_root_write_result = forest_root_write_tx.send(()).map_err(|e| {
error!(target: LOG_TARGET, "CRITICAL❗️❗️ This is a bug! Failed to release forest root write lock. This is a critical bug. Please report it to the StorageHub team. \nError while sending the release message: {:?}", e);
anyhow!(
"CRITICAL❗️❗️ This is a bug! Failed to release forest root write lock. This is a critical bug. Please report it to the StorageHub team."
)
});

// Check if there are any pending requests to use the forest root write lock.
// If so, we give them the lock right away.
if forest_root_write_result.is_ok() {
self.check_pending_forest_root_writes();
}

match callback.send(forest_root_write_result) {
Ok(_) => {}
Err(e) => {
error!(target: LOG_TARGET, "Failed to send forest write lock release result: {:?}", e);
}
}
}
}
}
}
Expand Down
1 change: 1 addition & 0 deletions client/blockchain-service/src/utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -544,6 +544,7 @@ impl BlockchainService {
.pending_confirm_storing_request_deque()
.pop_front()
{
trace!(target: LOG_TARGET, "Processing confirm storing request for file [{:?}]", request.file_key);
confirm_storing_requests.push(request);
} else {
break;
Expand Down
11 changes: 3 additions & 8 deletions node/src/service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,6 @@ use sc_network::{
config::IncomingRequest, service::traits::NetworkService, NetworkBackend, NetworkBlock,
ProtocolName,
};
use sc_network_sync::SyncingService;
use sc_service::{Configuration, PartialComponents, RpcHandlers, TFullBackend, TaskManager};
use sc_telemetry::{Telemetry, TelemetryHandle, TelemetryWorker, TelemetryWorkerHandle};
use sc_transaction_pool_api::OffchainTransactionPoolFactory;
Expand Down Expand Up @@ -914,7 +913,6 @@ where
&task_manager,
relay_chain_interface.clone(),
transaction_pool,
sync_service.clone(),
params.keystore_container.keystore(),
relay_chain_slot_duration,
para_id,
Expand Down Expand Up @@ -966,7 +964,6 @@ fn start_consensus(
task_manager: &TaskManager,
relay_chain_interface: Arc<dyn RelayChainInterface>,
transaction_pool: Arc<sc_transaction_pool::FullPool<Block, ParachainClient>>,
sync_oracle: Arc<SyncingService<Block>>,
keystore: KeystorePtr,
relay_chain_slot_duration: Duration,
para_id: ParaId,
Expand Down Expand Up @@ -1008,7 +1005,6 @@ fn start_consensus(
.ok()
.map(|c| ValidationCode::from(c).hash())
},
sync_oracle,
keystore,
collator_key,
para_id,
Expand All @@ -1020,10 +1016,9 @@ fn start_consensus(
reinitialize: false,
};

let fut =
aura::run::<Block, sp_consensus_aura::sr25519::AuthorityPair, _, _, _, _, _, _, _, _, _>(
params,
);
let fut = aura::run::<Block, sp_consensus_aura::sr25519::AuthorityPair, _, _, _, _, _, _, _, _>(
params,
);
task_manager
.spawn_essential_handle()
.spawn("aura", None, fut);
Expand Down
15 changes: 5 additions & 10 deletions node/src/tasks/bsp_charge_fees.rs
Original file line number Diff line number Diff line change
Expand Up @@ -346,16 +346,11 @@ where
}
}

// Release the forest root write "lock".
let forest_root_write_result = forest_root_write_tx.send(());
if forest_root_write_result.is_err() {
error!(target: LOG_TARGET, "CRITICAL❗️❗️ This is a bug! Failed to release forest root write lock. This is a critical bug. Please report it to the StorageHub team.");
return Err(anyhow!(
"CRITICAL❗️❗️ This is a bug! Failed to release forest root write lock."
));
}

Ok(())
// Release the forest root write "lock" and finish the task.
self.storage_hub_handler
.blockchain
.release_forest_root_write_lock(forest_root_write_tx)
.await
}
}

Expand Down
15 changes: 5 additions & 10 deletions node/src/tasks/bsp_submit_proof.rs
Original file line number Diff line number Diff line change
Expand Up @@ -295,16 +295,11 @@ where
self.check_provider_root(event.data.provider_id).await?;
}

// Release the forest root write "lock".
let forest_root_write_result = forest_root_write_tx.send(());
if forest_root_write_result.is_err() {
error!(target: LOG_TARGET, "CRITICAL❗️❗️ This is a bug! Failed to release forest root write lock. This is a critical bug. Please report it to the StorageHub team.");
return Err(anyhow!(
"CRITICAL❗️❗️ This is a bug! Failed to release forest root write lock."
));
}

Ok(())
// Release the forest root write "lock" and finish the task.
self.storage_hub_handler
.blockchain
.release_forest_root_write_lock(forest_root_write_tx)
.await
}
}

Expand Down
15 changes: 5 additions & 10 deletions node/src/tasks/bsp_upload_file.rs
Original file line number Diff line number Diff line change
Expand Up @@ -402,16 +402,11 @@ where
.insert_files_metadata(file_metadatas.as_slice())?;
}

// Release the forest root write "lock".
let forest_root_write_result = forest_root_write_tx.send(());
if forest_root_write_result.is_err() {
error!(target: LOG_TARGET, "CRITICAL❗️❗️ This is a bug! Failed to release forest root write lock. This is a critical bug. Please report it to the StorageHub team.");
return Err(anyhow!(
"CRITICAL❗️❗️ This is a bug! Failed to release forest root write lock."
));
}

Ok(())
// Release the forest root write "lock" and finish the task.
self.storage_hub_handler
.blockchain
.release_forest_root_write_lock(forest_root_write_tx)
.await
}
}

Expand Down
8 changes: 5 additions & 3 deletions node/src/tasks/msp_upload_file.rs
Original file line number Diff line number Diff line change
Expand Up @@ -566,9 +566,11 @@ where
.watch_for_success(&self.storage_hub_handler.blockchain)
.await?;

let _ = forest_root_write_tx.send(());

Ok(())
// Release the forest root write "lock" and finish the task.
self.storage_hub_handler
.blockchain
.release_forest_root_write_lock(forest_root_write_tx)
.await
}
}

Expand Down
24 changes: 24 additions & 0 deletions pallets/file-system/src/utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@
}};
// Handle boolean type
($condition:expr, $error_msg:expr, $error_type:path, bool) => {{
if !$condition {

Check warning on line 71 in pallets/file-system/src/utils.rs

View workflow job for this annotation

GitHub Actions / Check lint with clippy

the use of negated comparison operators on partially ordered types produces code that is hard to read and refactor, please consider using the `partial_cmp` method instead, to make it clear that the two values could be incomparable

Check warning on line 71 in pallets/file-system/src/utils.rs

View workflow job for this annotation

GitHub Actions / Check lint with clippy

the use of negated comparison operators on partially ordered types produces code that is hard to read and refactor, please consider using the `partial_cmp` method instead, to make it clear that the two values could be incomparable
#[cfg(test)]
unreachable!($error_msg);

Expand Down Expand Up @@ -1734,6 +1734,18 @@
// Update root of the BSP.
<T::Providers as shp_traits::MutateProvidersInterface>::update_root(sp_id, new_root)?;

// Delete payment stream between this BSP and this user (also charge it for all the owed funds
// of all files that were stored by this BSP).
if <T::PaymentStreams as PaymentStreamsInterface>::get_dynamic_rate_payment_stream_info(
&sp_id, &owner,
)
.is_some()
{
<T::PaymentStreams as PaymentStreamsInterface>::delete_dynamic_rate_payment_stream(
&sp_id, &owner,
)?;
}

new_root
} else {
// If the Provider is a MSP, the proof is verified against the Bucket's root.
Expand Down Expand Up @@ -1780,6 +1792,18 @@
bucket_id, new_root,
)?;

// Delete payment stream between this MSP and this user (also charge it for all the owed funds
// of all files that were stored by this MSP).
if <T::PaymentStreams as PaymentStreamsInterface>::get_fixed_rate_payment_stream_info(
&sp_id, &owner,
)
.is_some()
{
<T::PaymentStreams as PaymentStreamsInterface>::delete_fixed_rate_payment_stream(
&sp_id, &owner,
)?;
}

new_root
};

Expand Down
Loading
Loading