Skip to content

Commit

Permalink
tests: add integration test for preparing query
Browse files Browse the repository at this point in the history
  • Loading branch information
sylwiaszunejko committed Sep 1, 2023
1 parent 15c2db6 commit ec03218
Show file tree
Hide file tree
Showing 2 changed files with 111 additions and 0 deletions.
1 change: 1 addition & 0 deletions scylla/tests/integration/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,4 +5,5 @@ mod lwt_optimisation;
mod new_session;
mod retries;
mod shards;
mod silent_prepare_query;
pub(crate) mod utils;
110 changes: 110 additions & 0 deletions scylla/tests/integration/silent_prepare_query.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
use crate::utils::test_with_3_node_cluster;
use scylla::transport::session::Session;
use scylla::SessionBuilder;
use scylla::{query::Query, test_utils::unique_keyspace_name};
use scylla_proxy::{
Condition, ProxyError, Reaction, RequestOpcode, RequestReaction, RequestRule, ShardAwareness,
WorkerError,
};
use std::sync::Arc;
use std::time::Duration;

#[tokio::test]
#[ntest::timeout(30000)]
#[cfg(not(scylla_cloud_tests))]
async fn test_prepare_query_with_values() {
// unprepared query with non empty values should be prepared
const TIMEOUT_PER_REQUEST: Duration = Duration::from_millis(1000);

let res = test_with_3_node_cluster(ShardAwareness::QueryNode, |proxy_uris, translation_map, mut running_proxy| async move {
// DB preparation phase
let session: Session = SessionBuilder::new()
.known_node(proxy_uris[0].as_str())
.address_translator(Arc::new(translation_map))
.build()
.await
.unwrap();

let ks = unique_keyspace_name();
session.query(format!("CREATE KEYSPACE IF NOT EXISTS {} WITH REPLICATION = {{'class' : 'NetworkTopologyStrategy', 'replication_factor' : 3}}", ks), &[]).await.unwrap();
session.use_keyspace(ks, false).await.unwrap();
session
.query("CREATE TABLE t (a int primary key)", &[])
.await
.unwrap();

let q = Query::from("INSERT INTO t (a) VALUES (?)");

let drop_unprepared_frame_rule = RequestRule(
Condition::RequestOpcode(RequestOpcode::Query)
.and(Condition::BodyContainsCaseSensitive(Box::new(*b"t"))),
RequestReaction::drop_frame(),
);

running_proxy.running_nodes[2]
.change_request_rules(Some(vec![drop_unprepared_frame_rule]));

tokio::select! {
_res = session.query(q, (0,)) => (),
_ = tokio::time::sleep(TIMEOUT_PER_REQUEST) => panic!("Rules did not work: no received response"),
};

running_proxy
}).await;

match res {
Ok(()) => (),
Err(ProxyError::Worker(WorkerError::DriverDisconnected(_))) => (),
Err(err) => panic!("{}", err),
}
}

#[tokio::test]
#[ntest::timeout(30000)]
#[cfg(not(scylla_cloud_tests))]
async fn test_query_with_no_values() {
// unprepared query with empty values should not be prepared
const TIMEOUT_PER_REQUEST: Duration = Duration::from_millis(1000);

let res = test_with_3_node_cluster(ShardAwareness::QueryNode, |proxy_uris, translation_map, mut running_proxy| async move {
// DB preparation phase
let session: Session = SessionBuilder::new()
.known_node(proxy_uris[0].as_str())
.address_translator(Arc::new(translation_map))
.build()
.await
.unwrap();

let ks = unique_keyspace_name();
session.query(format!("CREATE KEYSPACE IF NOT EXISTS {} WITH REPLICATION = {{'class' : 'NetworkTopologyStrategy', 'replication_factor' : 3}}", ks), &[]).await.unwrap();
session.use_keyspace(ks, false).await.unwrap();
session
.query("CREATE TABLE t (a int primary key)", &[])
.await
.unwrap();

let q = Query::from("INSERT INTO t (a) VALUES (1)");

let drop_prepared_frame_rule = RequestRule(
Condition::RequestOpcode(RequestOpcode::Prepare)
.and(Condition::BodyContainsCaseSensitive(Box::new(*b"t"))),
RequestReaction::drop_frame(),
);

running_proxy.running_nodes[2]
.change_request_rules(Some(vec![drop_prepared_frame_rule]));

tokio::select! {
_res = session.query(q, ()) => (),
_ = tokio::time::sleep(TIMEOUT_PER_REQUEST) => panic!("Rules did not work: no received response"),
};

running_proxy
}).await;

match res {
Ok(()) => (),
Err(ProxyError::Worker(WorkerError::DriverDisconnected(_))) => (),
Err(err) => panic!("{}", err),
}
}

0 comments on commit ec03218

Please sign in to comment.