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

Inclusions struct unit tests #1518

Merged
merged 6 commits into from
Sep 13, 2023
Merged

Inclusions struct unit tests #1518

merged 6 commits into from
Sep 13, 2023

Conversation

Overkillus
Copy link
Contributor

In follow-up to #1432

Some additional unit tests for the inclusion struct used in the scraper.

@Overkillus Overkillus added T8-parachains_engineering T10-tests This PR/Issue is related to tests. labels Sep 12, 2023
@Overkillus Overkillus self-assigned this Sep 12, 2023
@Overkillus Overkillus marked this pull request as ready for review September 12, 2023 14:59
Copy link
Contributor

@BradleyOlson64 BradleyOlson64 left a comment

Choose a reason for hiding this comment

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

Very thorough 👍

Copy link
Contributor

@tdimitrov tdimitrov left a comment

Choose a reason for hiding this comment

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

Very good work @Overkillus! A few nits from me, most of them are a matter of personal test.

test_duplicate_insertion_same_height_different_blocks and inclusions_remove_with_empty_maps are great tests to have!

@Overkillus Overkillus merged commit f7c95c5 into master Sep 13, 2023
@Overkillus Overkillus deleted the mz-inclusion-tests branch September 13, 2023 10:46
Copy link
Member

@eskimor eskimor left a comment

Choose a reason for hiding this comment

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

A little late to the party. In general good coverage, but I would love to have pruning specifically tested for edge cases.

}

#[test]
fn inclusions_duplicate_insertion_same_height_and_block() {
Copy link
Member

Choose a reason for hiding this comment

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

I would be more interested if pruning works as expected for same height/same block/different block. As this was precisely what went wrong in the Kusama incident.

Ideally we would also test whether pruning still works as desired if the same candidate was included at different heights.

Overkillus added a commit that referenced this pull request Sep 14, 2023
In follow-up to #1518

Adding extra tests for inclusion pruning. Primarily focusing on various
cases surrounding candidates included in different forks (with different
relay parents).

All cases fall into a few buckets based on 3 degrees of freedom - number
of candidates, number of blocks (height), number of forks + extra case
for pruning multiple heights at once.

Added small tweak to the original pruning function to disregard stale
candidate duplicates which should keep the same behaviour.

---------

Co-authored-by: Tsvetomir Dimitrov <tsvetomir@parity.io>
bkchr pushed a commit that referenced this pull request Apr 10, 2024
* send messages using xcm pallet

* XcmBridge && XcmBridgeAdapter + (untested) config in RialtoParachain

* impl encode_send_xcm for the rest

* remove duplicate code

* some fixes

* cleanup

* some more tests

* cleanup

* cleanup

* send Rialto -> Millau messages using bridge-messages pallet

* fmt

* some clippy fixes

* more clippy
bkchr pushed a commit that referenced this pull request Apr 10, 2024
* Adjustments for the xcm messages sending logic

Signed-off-by: Serban Iorga <serban@parity.io>

* Deduplicate XCM destination

Signed-off-by: Serban Iorga <serban@parity.io>

* [send_message] small changes

Signed-off-by: Serban Iorga <serban@parity.io>

* Define CustomNetworkId

Right now we use some associations between Rialto, RialtoParachain and
Millau chains and chains defined in the NetworkId enum. But if we are
not carreful we might do mistakes like:
In Millau:
pub const ThisNetwork: NetworkId = Kusama;
pub const RialtoNetwork: NetworkId = Polkadot;
In Rialto:
pub const ThisNetwork: NetworkId = Kusama;
pub const MillauNetwork: NetworkId = Polkadot;

We're introducing CustomNetworkId to have a centralized mapping between
NetworkId chains and our custom chains.

Signed-off-by: Serban Iorga <serban@parity.io>

* Revert "Deduplicate XCM destination"

This reverts commit 3a0a950e1d7484e3ecac45f5c00b152f0485cd11.

Signed-off-by: Serban Iorga <serban@parity.io>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
T10-tests This PR/Issue is related to tests.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants