From a21779658cfe06ad7b38de34d6dd55839eafd442 Mon Sep 17 00:00:00 2001 From: xsanm Date: Thu, 28 Sep 2023 13:31:51 +0200 Subject: [PATCH] [Commtest] add mock olm accounts, configure creating authenticated device Summary: To properly test WebSocket one device is not enough. We should send message from one device and receive it on another. Adding two more, generated via local `olm`. Depends on D9311 Test Plan: Run tests and make sure new credentials works. Reviewers: michal, bartek, varun, jon Reviewed By: michal, bartek Subscribers: ashoat, tomek Differential Revision: https://phab.comm.dev/D9312 --- services/commtest/src/identity/device.rs | 11 +++-- services/commtest/src/identity/mod.rs | 1 + .../src/identity/olm_account_infos.rs | 48 +++++++++++++++++++ services/commtest/tests/grpc_client_test.rs | 2 +- .../tests/identity_access_tokens_tests.rs | 4 +- .../tests/identity_keyserver_tests.rs | 2 +- .../tests/identity_one_time_key_tests.rs | 2 +- .../commtest/tests/identity_prekey_tests.rs | 2 +- .../tests/identity_tunnelbroker_tests.rs | 8 ++-- .../tests/tunnelbroker_integration_tests.rs | 4 +- 10 files changed, 69 insertions(+), 15 deletions(-) create mode 100644 services/commtest/src/identity/olm_account_infos.rs diff --git a/services/commtest/src/identity/device.rs b/services/commtest/src/identity/device.rs index 20e29abb42..122581a4cf 100644 --- a/services/commtest/src/identity/device.rs +++ b/services/commtest/src/identity/device.rs @@ -3,6 +3,9 @@ use rand::{distributions::Alphanumeric, Rng}; mod proto { tonic::include_proto!("identity.client"); } +use crate::identity::olm_account_infos::{ + ClientPublicKeys, DEFAULT_CLIENT_KEYS, +}; use proto as client; use proto::{ identity_client_service_client::IdentityClientServiceClient, DeviceKeyUpload, @@ -16,7 +19,7 @@ pub struct DeviceInfo { pub access_token: String, } -pub async fn create_device() -> DeviceInfo { +pub async fn create_device(keys: Option<&ClientPublicKeys>) -> DeviceInfo { let password = "pass"; let username: String = rand::thread_rng() .sample_iter(&Alphanumeric) @@ -25,9 +28,11 @@ pub async fn create_device() -> DeviceInfo { .collect(); // TODO: Generate dynamic valid olm account info - let example_payload = r#"{\"notificationIdentityPublicKeys\":{\"curve25519\":\"DYmV8VdkjwG/VtC8C53morogNJhpTPT/4jzW0/cxzQo\",\"ed25519\":\"D0BV2Y7Qm36VUtjwyQTJJWYAycN7aMSJmhEsRJpW2mk\"},\"primaryIdentityPublicKeys\":{\"curve25519\":\"Y4ZIqzpE1nv83kKGfvFP6rifya0itRg2hifqYtsISnk\",\"ed25519\":\"cSlL+VLLJDgtKSPlIwoCZg0h0EmHlQoJC08uV/O+jvg\"}}"#; + let keys = keys.unwrap_or_else(|| &DEFAULT_CLIENT_KEYS); + let example_payload = + serde_json::to_string(&keys).expect("Failed to serialize example payload"); // The ed25519 value from the olm payload - let device_id = r#"cSlL+VLLJDgtKSPlIwoCZg0h0EmHlQoJC08uV/O+jvg"#; + let device_id = &keys.primary_identity_public_keys.ed25519; let mut client_registration = Registration::new(); let opaque_registration_request = diff --git a/services/commtest/src/identity/mod.rs b/services/commtest/src/identity/mod.rs index 5458924147..2563814b21 100644 --- a/services/commtest/src/identity/mod.rs +++ b/services/commtest/src/identity/mod.rs @@ -1 +1,2 @@ pub mod device; +pub mod olm_account_infos; diff --git a/services/commtest/src/identity/olm_account_infos.rs b/services/commtest/src/identity/olm_account_infos.rs new file mode 100644 index 0000000000..c233e2739b --- /dev/null +++ b/services/commtest/src/identity/olm_account_infos.rs @@ -0,0 +1,48 @@ +use lazy_static::lazy_static; +use serde::{Deserialize, Serialize}; + +#[derive(Serialize, Deserialize, Debug, Clone)] +pub struct IdentityPublicKeys { + pub ed25519: String, + pub curve25519: String, +} + +#[derive(Serialize, Deserialize, Debug, Clone)] +#[serde(rename_all = "camelCase")] +pub struct ClientPublicKeys { + pub primary_identity_public_keys: IdentityPublicKeys, + pub notification_identity_public_keys: IdentityPublicKeys, +} + +lazy_static! { + pub static ref DEFAULT_CLIENT_KEYS: ClientPublicKeys = ClientPublicKeys { + primary_identity_public_keys: IdentityPublicKeys { + ed25519: "cSlL+VLLJDgtKSPlIwoCZg0h0EmHlQoJC08uV/O+jvg".to_string(), + curve25519: "Y4ZIqzpE1nv83kKGfvFP6rifya0itRg2hifqYtsISnk".to_string(), + }, + notification_identity_public_keys: IdentityPublicKeys { + ed25519: "D0BV2Y7Qm36VUtjwyQTJJWYAycN7aMSJmhEsRJpW2mk".to_string(), + curve25519: "DYmV8VdkjwG/VtC8C53morogNJhpTPT/4jzW0/cxzQo".to_string(), + } + }; + pub static ref MOCK_CLIENT_KEYS_1: ClientPublicKeys = ClientPublicKeys { + primary_identity_public_keys: IdentityPublicKeys { + ed25519: "lbp5cS9fH5NnWIJbZ57wGBzDBGvmjoq6gMBHsIyXfJ4".to_string(), + curve25519: "x74rEeVzfTcjm+B2yLN/wgfvHEzEtphQ/JeQfIrzPzQ".to_string(), + }, + notification_identity_public_keys: IdentityPublicKeys { + ed25519: "+mi3TltiSK2883cm0TK2mkSKPcQb+WVfshltTSVgA2Y".to_string(), + curve25519: "GI8V9FwOYIqxB2TzQN31nXKR8y3/B3k+ZOCgxkTlUlI".to_string(), + }, + }; + pub static ref MOCK_CLIENT_KEYS_2: ClientPublicKeys = ClientPublicKeys { + primary_identity_public_keys: IdentityPublicKeys { + ed25519: "ZXx1ADCFxFm6P+UmVhX0A1tuqUoBU7lYjig/gMzSEJI".to_string(), + curve25519: "zHfP5eeD3slrgidtNRknHw3NKtJ7hA+vinaT3ACIhRA".to_string(), + }, + notification_identity_public_keys: IdentityPublicKeys { + ed25519: "TqzVFQLnJvt9JfMVU54d6InEd/wQV3DCplBuj5axTlU".to_string(), + curve25519: "nRVVaf+Iz2MfEFtQtzrvV/EmTivqKpOeHlCt9OWYUxM".to_string(), + }, + }; +} diff --git a/services/commtest/tests/grpc_client_test.rs b/services/commtest/tests/grpc_client_test.rs index d73f20872b..4bd0d83221 100644 --- a/services/commtest/tests/grpc_client_test.rs +++ b/services/commtest/tests/grpc_client_test.rs @@ -3,7 +3,7 @@ use commtest::identity::device::create_device; #[tokio::test] async fn verify_access_token() { use grpc_clients::identity::unauthenticated::client::verify_user_access_token; - let device_info = create_device().await; + let device_info = create_device(None).await; let token_valid = verify_user_access_token( "http://127.0.0.1:50054", diff --git a/services/commtest/tests/identity_access_tokens_tests.rs b/services/commtest/tests/identity_access_tokens_tests.rs index ca64f6f38c..14a9deca4b 100644 --- a/services/commtest/tests/identity_access_tokens_tests.rs +++ b/services/commtest/tests/identity_access_tokens_tests.rs @@ -11,7 +11,7 @@ use proto::{UploadOneTimeKeysRequest, VerifyUserAccessTokenRequest}; #[tokio::test] async fn verify_access_token() { - let device_info = create_device().await; + let device_info = create_device(None).await; let mut identity_client = IdentityClientServiceClient::connect("http://127.0.0.1:50054") @@ -34,7 +34,7 @@ async fn verify_access_token() { #[tokio::test] async fn upload_one_time_keys() { - let device_info = create_device().await; + let device_info = create_device(None).await; let mut identity_client = IdentityClientServiceClient::connect("http://127.0.0.1:50054") diff --git a/services/commtest/tests/identity_keyserver_tests.rs b/services/commtest/tests/identity_keyserver_tests.rs index 5e3ec51679..47b647d511 100644 --- a/services/commtest/tests/identity_keyserver_tests.rs +++ b/services/commtest/tests/identity_keyserver_tests.rs @@ -13,7 +13,7 @@ use tonic::{transport::Endpoint, Request}; #[tokio::test] async fn set_prekey() { - let device_info = create_device().await; + let device_info = create_device(None).await; let channel = Endpoint::from_static("http://[::1]:50054") .connect() diff --git a/services/commtest/tests/identity_one_time_key_tests.rs b/services/commtest/tests/identity_one_time_key_tests.rs index c4171ce649..54933449d9 100644 --- a/services/commtest/tests/identity_one_time_key_tests.rs +++ b/services/commtest/tests/identity_one_time_key_tests.rs @@ -10,7 +10,7 @@ use commtest::identity::device::create_device; #[tokio::test] async fn verify_access_token() { - let device_info = create_device().await; + let device_info = create_device(None).await; let mut identity_client = IdentityClientServiceClient::connect("http://127.0.0.1:50054") diff --git a/services/commtest/tests/identity_prekey_tests.rs b/services/commtest/tests/identity_prekey_tests.rs index 9a3497896a..1e2560748f 100644 --- a/services/commtest/tests/identity_prekey_tests.rs +++ b/services/commtest/tests/identity_prekey_tests.rs @@ -13,7 +13,7 @@ use tonic::{transport::Endpoint, Request}; #[tokio::test] async fn set_prekey() { - let device_info = create_device().await; + let device_info = create_device(None).await; let channel = Endpoint::from_static("http://[::1]:50054") .connect() diff --git a/services/commtest/tests/identity_tunnelbroker_tests.rs b/services/commtest/tests/identity_tunnelbroker_tests.rs index 3a05ae3294..b96f879cac 100644 --- a/services/commtest/tests/identity_tunnelbroker_tests.rs +++ b/services/commtest/tests/identity_tunnelbroker_tests.rs @@ -17,7 +17,7 @@ use tunnelbroker_messages::RefreshKeyRequest; #[tokio::test] #[should_panic] async fn test_tunnelbroker_invalid_auth() { - let mut device_info = create_device().await; + let mut device_info = create_device(None).await; device_info.access_token = "".to_string(); let mut socket = create_socket(&device_info).await; @@ -30,7 +30,7 @@ async fn test_tunnelbroker_invalid_auth() { #[tokio::test] async fn test_tunnelbroker_valid_auth() { - let device_info = create_device().await; + let device_info = create_device(None).await; let mut socket = create_socket(&device_info).await; socket @@ -42,7 +42,7 @@ async fn test_tunnelbroker_valid_auth() { #[tokio::test] async fn test_refresh_keys_request_upon_depletion() { - let device_info = create_device().await; + let device_info = create_device(None).await; let mut identity_client = IdentityClientServiceClient::connect("http://127.0.0.1:50054") @@ -95,7 +95,7 @@ async fn test_refresh_keys_request_upon_depletion() { // from Tunnelbroker to refresh keys // Create session as a keyserver - let device_info = create_device().await; + let device_info = create_device(None).await; let mut socket = create_socket(&device_info).await; // Have keyserver receive any websocket messages diff --git a/services/commtest/tests/tunnelbroker_integration_tests.rs b/services/commtest/tests/tunnelbroker_integration_tests.rs index 766b67f56c..45a0f24464 100644 --- a/services/commtest/tests/tunnelbroker_integration_tests.rs +++ b/services/commtest/tests/tunnelbroker_integration_tests.rs @@ -11,7 +11,7 @@ use tunnelbroker_messages::RefreshKeyRequest; #[tokio::test] async fn send_refresh_request() { // Create session as a keyserver - let device_info = create_device().await; + let device_info = create_device(None).await; let mut socket = create_socket(&device_info).await; // Send request for keyserver to refresh keys (identity service) @@ -51,7 +51,7 @@ async fn send_refresh_request() { /// then recalled once a device connects #[tokio::test] async fn persist_messages() { - let device_info = create_device().await; + let device_info = create_device(None).await; // Send request for keyserver to refresh keys (identity service) let mut tunnelbroker_client =