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

E2e refactor separate suites #592

Merged
merged 37 commits into from
Oct 15, 2024
Merged

Conversation

cam-schultz
Copy link
Contributor

@cam-schultz cam-schultz commented Oct 10, 2024

Why this should be merged

Following #591, updates the remaining validator manager e2e tests to use the full validator registration flow with the P-Chain.

How this works

  • Modifies native token staking, erc20 token staking, and PoA -> PoS migration e2e tests to send P-Chain txs and consume Warp messages signed by the P-Chain
  • Separates the top-level e2e suite into separate suites for teleporter, governance, and validator-manager. Each of these suites run in their own CI jobs.
  • Tears down the tmpnet network in between each validator-manager suite test since they modify the underlying network topology
  • Consolidates the validator-manager tests to reduce the overall e2e running time
    • erc20_delegation.go removed; delegation logic moved to erc20_token_staking.go
    • native_delegation.go removed; delegation logic moved to native_token_staking.go
    • poa_validator_manager.go removed; PoA owner checks moved to poa_to_pos.go

How this was tested

CI

How is this documented

N/A

@cam-schultz cam-schultz marked this pull request as ready for review October 10, 2024 20:51
@cam-schultz cam-schultz requested a review from a team as a code owner October 10, 2024 20:51
printUsage
}

valid_components="teleporter governance validator-manager"
Copy link
Contributor

Choose a reason for hiding this comment

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

If we just test for the existence of ./tests/local//$component/$component.test, then we don't have to maintain this list.

}

// Define the Teleporter before and after suite functions.
var _ = ginkgo.BeforeSuite(func() {
Copy link
Contributor

Choose a reason for hiding this comment

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

Is this setup the same for all the suites? Can we extract this function out somewhere common?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

The only difference is that governance and validator-manager suites omit setting up Teleporter. I'm open to suggestions, but IMO the set of network setup functions are sufficiently modular to cover our test cases.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Sorry - got my wires crossed. This WIP branch makes the change I described. With it, the governance and validator-manager suites have no dependency on the Teleporter contracts

@cam-schultz cam-schultz changed the base branch from acp-77-e2e to acp-77-updates October 14, 2024 19:50
Comment on lines 18 to 19
valid_components="teleporter governance validator-manager"

Copy link
Contributor

Choose a reason for hiding this comment

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

We still reference valid_components on line 21. We should probably just ls ./tests/local/ to give a list of valid components.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I just removed the variable containing valid components altogether to simplify things.

function printUsage() {
cat << EOF
Arguments:
--component <component> Component test suite to run. Must be a valid directory in tests/local/
Copy link
Contributor

Choose a reason for hiding this comment

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

Love the change to be able to only test the component that changed but should we still have the ability to run all of them easily?

I'm thinking it might be worthwhile locally and maybe on merge to master which would be a good sanity check and be rarer than each PR commit push

Copy link
Contributor Author

Choose a reason for hiding this comment

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

For CI, we should run the suites in parallel on separate runners in all scenarios for expediancy and isolation. The local use case makes sense though. I've modified the script to run all components by default if no argument is provided.

@cam-schultz cam-schultz requested a review from iansuvak October 15, 2024 15:00
@cam-schultz cam-schultz merged commit dac3220 into acp-77-updates Oct 15, 2024
14 checks passed
@cam-schultz cam-schultz deleted the e2e-refactor-separate-suites branch October 15, 2024 15:37
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

3 participants