summaryrefslogtreecommitdiffhomepage
path: root/test
diff options
context:
space:
mode:
authorDavid Lönnhager <david.l@mullvad.net>2025-09-24 13:58:30 +0200
committerDavid Lönnhager <david.l@mullvad.net>2025-09-30 16:09:04 +0200
commitffa9bc85f446b21cf6017b979bb6602684033b04 (patch)
tree5798656cfce37aaf58e4657cd33caa278539922a /test
parent386b49ad7156570cfc437e1ff3b720f1f5cc9b39 (diff)
downloadmullvadvpn-ffa9bc85f446b21cf6017b979bb6602684033b04.tar.xz
mullvadvpn-ffa9bc85f446b21cf6017b979bb6602684033b04.zip
Add E2E test for LWO
Diffstat (limited to 'test')
-rw-r--r--test/test-manager/src/tests/tunnel.rs39
1 files changed, 39 insertions, 0 deletions
diff --git a/test/test-manager/src/tests/tunnel.rs b/test/test-manager/src/tests/tunnel.rs
index 3d6ac6432e..7cf23c1ef2 100644
--- a/test/test-manager/src/tests/tunnel.rs
+++ b/test/test-manager/src/tests/tunnel.rs
@@ -322,6 +322,45 @@ pub async fn test_wireguard_over_quic_ipvx(
Ok(())
}
+/// Use LWO obfuscation. This tests whether the daemon can connect using LWO.
+/// Note that this doesn't verify that the outgoing traffic does not look like WG
+#[duplicate_item(
+ VX test_wireguard_over_lwo_ipvx;
+ [ V4 ] [ test_wireguard_over_lwo_ipv4 ];
+ [ V6 ] [ test_wireguard_over_lwo_ipv6 ];
+)]
+#[test_function(skip)]
+pub async fn test_wireguard_over_lwo_ipvx(
+ _: TestContext,
+ rpc: ServiceClient,
+ mut mullvad_client: MullvadProxyClient,
+) -> anyhow::Result<()> {
+ let ip_version = IpVersion::VX;
+
+ log::info!("Enable LWO as obfuscation method");
+ let query = RelayQueryBuilder::wireguard()
+ .ip_version(ip_version)
+ .lwo()
+ .build();
+ apply_settings_from_relay_query(&mut mullvad_client, query).await?;
+
+ log::info!("Connect to WireGuard via LWO endpoint");
+ connect_and_wait(&mut mullvad_client).await?;
+
+ // Verify that the device has a Mullvad exit IP
+ let conncheck = geoip_lookup_with_retries(&rpc).await;
+ let mullvad_exit_ip = conncheck
+ .as_ref()
+ .is_ok_and(|am_i_mullvad| am_i_mullvad.mullvad_exit_ip);
+ ensure!(
+ mullvad_exit_ip,
+ "Device is either blocked ❌ or leaking 💦 - {:?}",
+ conncheck,
+ );
+
+ Ok(())
+}
+
/// Test whether bridge mode works. This fails if:
/// * No outgoing traffic to the bridge/entry relay is observed from the SUT.
/// * The conncheck reports an unexpected exit relay.