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 64 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.

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
166 changes: 83 additions & 83 deletions test/package.json
Original file line number Diff line number Diff line change
@@ -1,85 +1,85 @@
{
"name": "@storagehub/test",
"version": "0.1.0",
"description": "Test package for storagehub",
"main": "index.js",
"type": "module",
"engines": {
"node": "22.x.x"
},
"scripts": {
"bundle-types": "cd ../types-bundle && pnpm i && pnpm build && pnpm fmt:fix && cd ../test",
"typegen": "pnpm bundle-types && cd ../api-augment && pnpm scrape && pnpm generate:all && pnpm build && pnpm fmt:fix; cd ../test",
"fmt": "biome format .",
"fmt:fix": "biome format . --write",
"lint": "biome lint .",
"typecheck": "tsc --noEmit",
"crossbuild:mac": "DOCKER_DEFAULT_PLATFORM=linux/amd64 pnpm tsx scripts/crossBuildMac.ts",
"docker:build": "DOCKER_DEFAULT_PLATFORM=linux/amd64 pnpm tsx scripts/buildLocalDocker.ts",
"docker:start": "docker compose -f ../docker/local-node-compose.yml -p sh_dev_node up -d",
"docker:start:latest": "docker compose -f ../docker/latest-node-compose.yml -p sh_dev_node up -d",
"docker:stop": "docker compose -f ../docker/local-node-compose.yml -p sh_dev_node down",
"docker:stop:latest": "docker compose -f ../docker/latest-node-compose.yml -p sh_dev_node down",
"docker:start:bspnet": "NOISY=0 ROCKSDB=0 pnpm tsx scripts/bspNetBootstrap.ts",
"docker:stop:bspnet": "docker compose -f ../docker/local-dev-bsp-compose.yml down --remove-orphans && docker volume prune -f",
"docker:start:fullNet": "NOISY=0 ROCKSDB=0 pnpm tsx scripts/fullNetBootstrap.ts",
"docker:stop:fullNet": "docker compose -f ../docker/local-dev-full-compose.yml down --remove-orphans && docker volume prune -f",
"docker:start:bspnet:rocksdb": "NOISY=0 ROCKSDB=1 pnpm tsx scripts/bspNetBootstrap.ts",
"docker:stop:bspnet:rocksdb": "docker compose -f ../docker/local-dev-bsp-rocksdb-compose.yml down --remove-orphans && docker volume prune -f",
"docker:start:fullNet:rocksdb": "NOISY=0 ROCKSDB=1 pnpm tsx scripts/fullNetBootstrap.ts",
"docker:stop:fullNet:rocksdb": "docker compose -f ../docker/local-dev-full-rocksdb-compose.yml down --remove-orphans && docker volume prune -f",
"docker:start:noisynet": "NOISY=1 ROCKSDB=0 pnpm tsx scripts/bspNetBootstrap.ts",
"docker:stop:noisynet": "docker compose -f ../docker/noisy-bsp-compose.yml down --remove-orphans && docker volume prune -f",
"zombie:run:latest": "SH_IMAGE=docker.io/moonsonglabs/storage-hub:latest pnpm zombienet spawn configs/simple.toml",
"zombie:run:local": "DOCKER_BUILDKIT=0 SH_IMAGE=storage-hub:local pnpm zombienet spawn configs/simple.toml",
"zombie:run:native": "pnpm tsx scripts/downloadPolkadot.ts 1.9.0 && pnpm zombienet spawn configs/simpleNative.toml",
"zombie:run:full": "SH_IMAGE=docker.io/moonsonglabs/storage-hub:latest pnpm zombienet spawn configs/fullNetwork.toml",
"zombie:run:full:native": "pnpm tsx scripts/downloadPolkadot.ts 1.9.0 && pnpm zombienet spawn configs/fullNetworkNative.toml",
"zombie:setup:native": "pnpm tsx scripts/fullNetworkSetup.ts",
"zombie:test:native": "pnpm tsx scripts/downloadPolkadot.ts 1.9.0 && pnpm zombienet test --provider native configs/simpleNative.zndsl",
"zombie:test:local": "SH_IMAGE=storage-hub:local pnpm zombienet test configs/simple.zndsl",
"zombie:test:latest": "SH_IMAGE=docker.io/moonsonglabs/storage-hub:latest pnpm zombienet test configs/simple.zndsl",
"test:full": "node --no-deprecation --import tsx --test ./suites/zombie/**.spec.ts",
"test:bspnet": "NODE_OPTIONS='--no-deprecation' pnpm tsx scripts/checkRunning.ts && node --no-deprecation --test-concurrency 1 --import tsx --test ./suites/integration/bsp/**.test.ts",
"test:bspnet:only": "NODE_OPTIONS='--no-deprecation' pnpm tsx scripts/checkRunning.ts && node --no-deprecation --import tsx --test-concurrency 1 --test --test-only ./suites/integration/bsp/**.test.ts",
"test:user": "NODE_OPTIONS='--no-deprecation' pnpm tsx scripts/checkRunning.ts && node --no-deprecation --test-concurrency 1 --import tsx --test ./suites/integration/user/**.test.ts",
"test:user:only": "NODE_OPTIONS='--no-deprecation' pnpm tsx scripts/checkRunning.ts && node --no-deprecation --test-concurrency 1 --import tsx --test --test-only ./suites/integration/user/**.test.ts",
"test:node": "node --no-deprecation --import tsx --test ./suites/solo-node/**/**.test.ts",
"test:node:only": "node --no-deprecation --import tsx --test --test-only ./suites/solo-node/**/**.test.ts",
"test:node:single": "node --no-deprecation --import tsx --test --test-name-pattern=$FILTER ./suites/solo-node/**/**.test.ts"
},
"keywords": [],
"author": "",
"license": "ISC",
"dependencies": {
"@polkadot/api": "12.4.2",
"@polkadot/api-augment": "12.4.2",
"@polkadot/keyring": "13.0.2",
"@polkadot/types": "12.4.2",
"@polkadot/util": "13.0.2",
"@polkadot/util-crypto": "13.0.2",
"@polkadot/wasm-crypto": "7.3.2",
"@reporters/github": "1.7.0",
"@storagehub/api-augment": "workspace:*",
"@storagehub/types-bundle": "workspace:*",
"@zombienet/cli": "1.3.109",
"@zombienet/utils": "0.0.25",
"docker-compose": "0.24.8",
"dockerode": "4.0.2",
"dotenv": "16.4.5",
"inquirer": "10.2.0",
"json-bigint": "^1.0.0",
"testcontainers": "10.13.0",
"tiny-invariant": "^1.3.3",
"tsx": "4.19.0",
"yaml": "^2.5.1"
},
"devDependencies": {
"@biomejs/biome": "1.8.3",
"@types/dockerode": "3.3.31",
"@types/inquirer": "9.0.7",
"@types/json-bigint": "1.0.4",
"@types/node": "22.5.2",
"typescript": "5.5.4"
}
"name": "@storagehub/test",
"version": "0.1.0",
"description": "Test package for storagehub",
"main": "index.js",
"type": "module",
"engines": {
"node": "22.x.x"
},
"scripts": {
"bundle-types": "cd ../types-bundle && pnpm i && pnpm build && pnpm fmt:fix && cd ../test",
"typegen": "pnpm bundle-types && cd ../api-augment && pnpm scrape && pnpm generate:all && pnpm build && pnpm fmt:fix; cd ../test",
"fmt": "biome format .",
"fmt:fix": "biome format . --write",
"lint": "biome lint .",
"typecheck": "tsc --noEmit",
"crossbuild:mac": "DOCKER_DEFAULT_PLATFORM=linux/amd64 pnpm tsx scripts/crossBuildMac.ts",
"docker:build": "DOCKER_DEFAULT_PLATFORM=linux/amd64 pnpm tsx scripts/buildLocalDocker.ts",
"docker:start": "docker compose -f ../docker/local-node-compose.yml -p sh_dev_node up -d",
"docker:start:latest": "docker compose -f ../docker/latest-node-compose.yml -p sh_dev_node up -d",
"docker:stop": "docker compose -f ../docker/local-node-compose.yml -p sh_dev_node down",
"docker:stop:latest": "docker compose -f ../docker/latest-node-compose.yml -p sh_dev_node down",
"docker:start:bspnet": "NOISY=0 ROCKSDB=0 pnpm tsx scripts/bspNetBootstrap.ts",
"docker:stop:bspnet": "docker compose -f ../docker/local-dev-bsp-compose.yml down --remove-orphans && docker volume prune -f",
"docker:start:fullNet": "NOISY=0 ROCKSDB=0 pnpm tsx scripts/fullNetBootstrap.ts",
"docker:stop:fullNet": "docker compose -f ../docker/local-dev-full-compose.yml down --remove-orphans && docker volume prune -f",
"docker:start:bspnet:rocksdb": "NOISY=0 ROCKSDB=1 pnpm tsx scripts/bspNetBootstrap.ts",
"docker:stop:bspnet:rocksdb": "docker compose -f ../docker/local-dev-bsp-rocksdb-compose.yml down --remove-orphans && docker volume prune -f",
"docker:start:fullNet:rocksdb": "NOISY=0 ROCKSDB=1 pnpm tsx scripts/fullNetBootstrap.ts",
"docker:stop:fullNet:rocksdb": "docker compose -f ../docker/local-dev-full-rocksdb-compose.yml down --remove-orphans && docker volume prune -f",
"docker:start:noisynet": "NOISY=1 ROCKSDB=0 pnpm tsx scripts/bspNetBootstrap.ts",
"docker:stop:noisynet": "docker compose -f ../docker/noisy-bsp-compose.yml down --remove-orphans && docker volume prune -f",
"zombie:run:latest": "SH_IMAGE=docker.io/moonsonglabs/storage-hub:latest pnpm zombienet spawn configs/simple.toml",
"zombie:run:local": "DOCKER_BUILDKIT=0 SH_IMAGE=storage-hub:local pnpm zombienet spawn configs/simple.toml",
"zombie:run:native": "pnpm tsx scripts/downloadPolkadot.ts 1.9.0 && pnpm zombienet spawn configs/simpleNative.toml",
"zombie:run:full": "SH_IMAGE=docker.io/moonsonglabs/storage-hub:latest pnpm zombienet spawn configs/fullNetwork.toml",
"zombie:run:full:native": "pnpm tsx scripts/downloadPolkadot.ts 1.9.0 && pnpm zombienet spawn configs/fullNetworkNative.toml",
"zombie:setup:native": "pnpm tsx scripts/fullNetworkSetup.ts",
"zombie:test:native": "pnpm tsx scripts/downloadPolkadot.ts 1.9.0 && pnpm zombienet test --provider native configs/simpleNative.zndsl",
"zombie:test:local": "SH_IMAGE=storage-hub:local pnpm zombienet test configs/simple.zndsl",
"zombie:test:latest": "SH_IMAGE=docker.io/moonsonglabs/storage-hub:latest pnpm zombienet test configs/simple.zndsl",
"test:full": "node --no-deprecation --import tsx --test ./suites/zombie/**.spec.ts",
"test:bspnet": "NODE_OPTIONS='--no-deprecation' pnpm tsx scripts/checkRunning.ts && node --no-deprecation --test-concurrency 1 --import tsx --test ./suites/integration/bsp/**.test.ts",
"test:bspnet:only": "NODE_OPTIONS='--no-deprecation' pnpm tsx scripts/checkRunning.ts && node --no-deprecation --import tsx --test-concurrency 1 --test --test-only ./suites/integration/bsp/**.test.ts",
"test:user": "NODE_OPTIONS='--no-deprecation' pnpm tsx scripts/checkRunning.ts && node --no-deprecation --test-concurrency 1 --import tsx --test ./suites/integration/user/**.test.ts",
"test:user:only": "NODE_OPTIONS='--no-deprecation' pnpm tsx scripts/checkRunning.ts && node --no-deprecation --test-concurrency 1 --import tsx --test --test-only ./suites/integration/user/**.test.ts",
"test:node": "node --no-deprecation --import tsx --test ./suites/solo-node/**/**.test.ts",
"test:node:only": "node --no-deprecation --import tsx --test --test-only ./suites/solo-node/**/**.test.ts",
"test:node:single": "node --no-deprecation --import tsx --test --test-name-pattern=$FILTER ./suites/solo-node/**/**.test.ts"
},
"keywords": [],
"author": "",
"license": "ISC",
"dependencies": {
"@polkadot/api": "12.4.2",
"@polkadot/api-augment": "12.4.2",
"@polkadot/keyring": "13.0.2",
"@polkadot/types": "12.4.2",
"@polkadot/util": "13.0.2",
"@polkadot/util-crypto": "13.0.2",
"@polkadot/wasm-crypto": "7.3.2",
"@reporters/github": "1.7.0",
"@storagehub/api-augment": "workspace:*",
"@storagehub/types-bundle": "workspace:*",
"@zombienet/cli": "1.3.109",
"@zombienet/utils": "0.0.25",
"docker-compose": "0.24.8",
"dockerode": "4.0.2",
"dotenv": "16.4.5",
"inquirer": "10.2.0",
"json-bigint": "^1.0.0",
"testcontainers": "10.13.0",
"tiny-invariant": "^1.3.3",
"tsx": "4.19.0",
"yaml": "^2.5.1"
},
"devDependencies": {
"@biomejs/biome": "1.8.3",
"@types/dockerode": "3.3.31",
"@types/inquirer": "9.0.7",
"@types/json-bigint": "1.0.4",
"@types/node": "22.5.2",
"typescript": "5.5.4"
}
}
28 changes: 13 additions & 15 deletions test/suites/integration/bsp/automatic-tipping.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,35 +5,33 @@ describeBspNet(
"BSP Automatic Tipping",
{ extrinsicRetryTimeout: 2 },
({ before, it, createUserApi }) => {
let api: EnrichedBspApi;
let userApi: EnrichedBspApi;

before(async () => {
api = await createUserApi();
userApi = await createUserApi();
});

it("Confirm storing failure results in increased tip", async () => {
await api.file.newStorageRequest("res/whatsup.jpg", "test/whatsup.jpg", "nothingmuch-2");
await api.wait.bspVolunteer();
// Make a storage request and wait for the bsp to volunteer
await userApi.file.newStorageRequest("res/whatsup.jpg", "test/whatsup.jpg", "nothingmuch-2");
await userApi.wait.bspVolunteer(1);

await sleep(1000); // wait for the bsp to download the files
// Wait for the bsp to send the first confirm storing extrinsic (after it has stored the file)
await userApi.wait.bspStoredInTxPool();

await api.assert.extrinsicPresent({
method: "bspConfirmStoring",
module: "fileSystem",
checkTxPool: true,
assertLength: 1
});

await sleep(6000); // wait for the bsp to send all confirm retries
// Wait for the bsp to send all the confirm retries
await sleep(6000);
await userApi.wait.bspStoredInTxPool(4);

const confirmStoringPendingMatches = await api.assert.extrinsicPresent({
// We get the confirm storing pending extrinsics to get their extrinsic index
const confirmStoringPendingMatches = await userApi.assert.extrinsicPresent({
method: "bspConfirmStoring",
module: "fileSystem",
checkTxPool: true,
assertLength: 4
});

const txPool = await api.rpc.author.pendingExtrinsics();
const txPool = await userApi.rpc.author.pendingExtrinsics();

const confirmStoringPendingExts = confirmStoringPendingMatches.map(
(match) => txPool[match.extIndex]
Expand Down
Loading
Loading