Skip to content

Commit

Permalink
Only use authenticated endpoints during EE integration testing (#3253)
Browse files Browse the repository at this point in the history
## Issue Addressed

Failures in our CI integration tests for Geth.

## Proposed Changes

Only connect to the authenticated execution endpoints during execution tests.
This is necessary now that it is impossible to connect to the `engine` api on an unauthenticated endpoint.
See ethereum/go-ethereum#24997

## Additional Info

As these tests break semi-regularly, I have kept logs enabled to ease future debugging.
I've also updated the Nethermind tests, although these weren't broken. This should future-proof us if Nethermind decides to follow suit with Geth
  • Loading branch information
macladson committed Jun 9, 2022
1 parent cfd26d2 commit 9c429d0
Show file tree
Hide file tree
Showing 4 changed files with 8 additions and 11 deletions.
6 changes: 0 additions & 6 deletions testing/execution_engine_integration/src/execution_engine.rs
Expand Up @@ -22,7 +22,6 @@ pub struct ExecutionEngine<E> {
engine: E,
#[allow(dead_code)]
datadir: TempDir,
http_port: u16,
http_auth_port: u16,
child: Child,
}
Expand All @@ -46,16 +45,11 @@ impl<E: GenericExecutionEngine> ExecutionEngine<E> {
Self {
engine,
datadir,
http_port,
http_auth_port,
child,
}
}

pub fn http_url(&self) -> SensitiveUrl {
SensitiveUrl::parse(&format!("http://127.0.0.1:{}", self.http_port)).unwrap()
}

pub fn http_auth_url(&self) -> SensitiveUrl {
SensitiveUrl::parse(&format!("http://127.0.0.1:{}", self.http_auth_port)).unwrap()
}
Expand Down
2 changes: 1 addition & 1 deletion testing/execution_engine_integration/src/main.rs
Expand Up @@ -15,7 +15,7 @@ use nethermind::NethermindEngine;
use test_rig::TestRig;

/// Set to `false` to send logs to the console during tests. Logs are useful when debugging.
const SUPPRESS_LOGS: bool = true;
const SUPPRESS_LOGS: bool = false;

fn main() {
if cfg!(windows) {
Expand Down
9 changes: 6 additions & 3 deletions testing/execution_engine_integration/src/nethermind.rs
Expand Up @@ -75,7 +75,7 @@ impl GenericExecutionEngine for NethermindEngine {

fn start_client(
datadir: &TempDir,
http_port: u16,
_http_port: u16,
http_auth_port: u16,
jwt_secret_path: PathBuf,
) -> Child {
Expand All @@ -89,11 +89,14 @@ impl GenericExecutionEngine for NethermindEngine {
.arg("--Merge.TerminalTotalDifficulty")
.arg("0")
.arg("--JsonRpc.AdditionalRpcUrls")
.arg(format!("http://localhost:{}|http;ws|net;eth;subscribe;engine;web3;client|no-auth,http://localhost:{}|http;ws|net;eth;subscribe;engine;web3;client", http_port, http_auth_port))
.arg(format!(
"http://localhost:{}|http;ws|net;eth;subscribe;engine;web3;client",
http_auth_port
))
.arg("--JsonRpc.EnabledModules")
.arg("net,eth,subscribe,web3,admin,engine")
.arg("--JsonRpc.Port")
.arg(http_port.to_string())
.arg(http_auth_port.to_string())
.arg("--Network.DiscoveryPort")
.arg(network_port.to_string())
.arg("--Network.P2PPort")
Expand Down
2 changes: 1 addition & 1 deletion testing/execution_engine_integration/src/test_rig.rs
Expand Up @@ -68,7 +68,7 @@ impl<E: GenericExecutionEngine> TestRig<E> {

let ee_b = {
let execution_engine = ExecutionEngine::new(generic_engine);
let urls = vec![execution_engine.http_url()];
let urls = vec![execution_engine.http_auth_url()];

let config = execution_layer::Config {
execution_endpoints: urls,
Expand Down

0 comments on commit 9c429d0

Please sign in to comment.