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

Notification-based block pinning #13157

Merged
Changes from 1 commit
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
d5c1427
Worker
skunert Dec 22, 2022
6131598
Reorganize and unpin onnotification drop
skunert Jan 6, 2023
ccdf8ed
Pin in state-db, pass block number
skunert Jan 9, 2023
0443235
Pin blocks in blockchain db
skunert Jan 10, 2023
c1a25dc
Switch to reference counted LRU
skunert Jan 10, 2023
9d824d4
Merge branch 'master' into skunert/notification-based-pinning
skunert Jan 10, 2023
2f7f943
Disable pinning when we keep all blocks
skunert Jan 11, 2023
65caa1a
Fix pinning hint for state-db
skunert Jan 12, 2023
cc000a3
Remove pinning from backend layer
skunert Jan 12, 2023
8a22325
Improve readability
skunert Jan 12, 2023
d3d208a
Add justifications to test
skunert Jan 12, 2023
bc2d40c
Fix justification behaviour
skunert Jan 12, 2023
da7a855
Remove debug prints
skunert Jan 12, 2023
7daf11c
Convert channels to tracing_unbounded
skunert Jan 16, 2023
2fb995c
Add comments to the test
skunert Jan 16, 2023
7a072dd
Documentation and Cleanup
skunert Jan 16, 2023
92e3928
Move task start to client
skunert Jan 16, 2023
3ec854e
Simplify cache
skunert Jan 16, 2023
d5e2b1d
Improve test, remove unwanted log
skunert Jan 16, 2023
03051ca
Add tracing logs, remove expect for block number
skunert Jan 16, 2023
c4434bb
Cleanup
skunert Jan 16, 2023
347c80a
Add conversion method for unpin handle to Finalitynotification
skunert Jan 17, 2023
1198568
Revert unwanted changes
skunert Jan 17, 2023
363f01a
Improve naming
skunert Jan 17, 2023
b220553
Make clippy happy
skunert Jan 17, 2023
10dfdf7
Fix docs
skunert Jan 17, 2023
e2ff001
Merge branch 'master' into skunert/notification-based-pinning
skunert Jan 17, 2023
c4608da
Use `NumberFor` instead of u64 in API
skunert Jan 17, 2023
68cc76f
Hand over weak reference to unpin worker task
skunert Jan 17, 2023
fe2d4cc
Unwanted
skunert Jan 17, 2023
f5d6b08
&Hash -> Hash
skunert Jan 17, 2023
946e06a
Remove number from interface, rename `_unpin_handle`, LOG_TARGET
skunert Jan 18, 2023
a48e44b
Move RwLock one layer up
skunert Jan 18, 2023
4014c16
Apply code style suggestions
skunert Jan 18, 2023
d547fc2
Improve comments
skunert Jan 18, 2023
de6aa36
Replace lru crate by schnellru
skunert Jan 18, 2023
81f7493
Merge remote-tracking branch 'origin' into skunert/notification-based…
skunert Jan 19, 2023
6fa6d5c
Only insert values for pinned items + better docs
skunert Jan 19, 2023
a177b50
Apply suggestions from code review
skunert Jan 19, 2023
cbd0868
Improve comments, log target and test
skunert Jan 19, 2023
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 comments to the test
  • Loading branch information
skunert committed Jan 16, 2023
commit 2fb995cda7fdde0f7b4b63b04ce9d5b0bb84676a
14 changes: 8 additions & 6 deletions client/db/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4252,10 +4252,12 @@ pub(crate) mod tests {

prev_hash = hash;
}

// Block 1 gets pinned three times
backend.pin_block(&blocks[1], 1).unwrap();
backend.pin_block(&blocks[1], 1).unwrap();

// Finalize all blocks. This will trigger pruning.
let mut op = backend.begin_operation().unwrap();
backend.begin_state_operation(&mut op, blocks[4]).unwrap();
for i in 1..5 {
Expand All @@ -4265,8 +4267,8 @@ pub(crate) mod tests {
backend.commit_operation(op).unwrap();

let bc = backend.blockchain();
// Block 0, 1, 2, 3 are pinned and pruning is delayed,
// while block 4 is never delayed for pruning as it is finalized.
// Block 0, 1, 2, 3 are pinned, so all values should be cached.
// Block 4 is inside the pruning window, its value is in db.
assert_eq!(Some(vec![0.into()]), bc.body(blocks[0]).unwrap());

assert_eq!(Some(vec![1.into()]), bc.body(blocks[1]).unwrap());
Expand All @@ -4293,21 +4295,21 @@ pub(crate) mod tests {
bc.justifications(blocks[4]).unwrap()
);

// Unpin all blocks.
// Unpin all blocks. Values should be removed from cache.
for block in &blocks {
backend.unpin_block(&block);
}

assert!(bc.body(blocks[0]).unwrap().is_none());
// Block 1 was pinned twice, we expect it to be in-memory
// Block 1 was pinned twice, we expect it to be still cached
assert!(bc.body(blocks[1]).unwrap().is_some());
assert!(bc.justifications(blocks[1]).unwrap().is_some());
assert!(bc.body(blocks[2]).unwrap().is_none());
assert!(bc.justifications(blocks[2]).unwrap().is_none());
assert!(bc.body(blocks[3]).unwrap().is_none());
assert!(bc.justifications(blocks[3]).unwrap().is_none());

// After these unpins, block 1 should be removed
// After these unpins, block 1 should also be removed
backend.unpin_block(&blocks[1]);
assert!(bc.body(blocks[1]).unwrap().is_some());
assert!(bc.justifications(blocks[1]).unwrap().is_some());
Expand Down Expand Up @@ -4352,7 +4354,7 @@ pub(crate) mod tests {
assert!(bc.body(blocks[4]).unwrap().is_none());
assert!(bc.justifications(blocks[4]).unwrap().is_none());

// Test that appended justifications are transferred correctly to the in-memory cache.
// Append a justification to block 5.
backend.append_justification(blocks[5], ([0, 0, 0, 1], vec![42])).unwrap();

let hash =
Expand Down