-
Notifications
You must be signed in to change notification settings - Fork 18
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add feature flags for each protocol in shotover
- Loading branch information
Showing
29 changed files
with
550 additions
and
195 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -40,11 +40,13 @@ jobs: | |
- name: Install ubuntu packages | ||
run: shotover-proxy/build/install_ubuntu_packages.sh | ||
- name: Install cargo-hack | ||
run: cargo install cargo-hack --version 0.5.8 | ||
uses: taiki-e/install-action@v2 | ||
with: | ||
tool: [email protected] | ||
- name: Ensure that dev tools compiles and has no warnings with no features enabled | ||
run: cargo clippy --locked ${{ matrix.cargo_flags }} --all-targets -- -D warnings | ||
- name: Ensure that shotover-proxy compiles and has no warnings under every possible combination of features | ||
# some things to explicitly point out: | ||
# * clippy also reports rustc warnings and errors | ||
# * clippy --all-targets is not run so we only build the shotover_proxy executable without the tests/benches | ||
run: cargo hack --feature-powerset clippy --locked ${{ matrix.cargo_flags }} --package shotover-proxy -- -D warnings | ||
run: cargo hack --feature-powerset --at-least-one-of redis,cassandra,kafka,opensearch clippy --locked ${{ matrix.cargo_flags }} --package shotover-proxy -- -D warnings |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -40,14 +40,14 @@ jobs: | |
- name: Install cargo-hack | ||
uses: taiki-e/install-action@v2 | ||
with: | ||
tool: [email protected].4 | ||
tool: [email protected].16 | ||
- name: Ensure `cargo fmt --all` was run | ||
run: cargo fmt --all -- --check | ||
- name: Ensure that all crates compile and have no warnings under every possible combination of features | ||
# some things to explicitly point out: | ||
# * clippy also reports rustc warnings and errors | ||
# * clippy --all-targets causes clippy to run against tests and examples which it doesnt do by default. | ||
run: cargo hack --feature-powerset clippy --all-targets --locked -- -D warnings | ||
run: cargo hack --feature-powerset --at-least-one-of redis,cassandra,kafka,opensearch clippy --all-targets --locked -- -D warnings | ||
- name: Report disk usage | ||
run: | | ||
df -h | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
use redis::aio::Connection; | ||
use redis::Cmd; | ||
use std::time::Duration; | ||
use test_helpers::connection::redis_connection; | ||
use test_helpers::docker_compose::docker_compose; | ||
use test_helpers::shotover_process::{bin_path, BinProcess, EventMatcher, Level}; | ||
|
||
#[tokio::test(flavor = "multi_thread")] | ||
async fn test_custom_transform() { | ||
// Setup shotover and the redis server it connects to | ||
let _compose = docker_compose("config/docker-compose.yaml"); | ||
let shotover = shotover_proxy("config/topology.yaml").await; | ||
let mut connection = redis_connection::new_async("127.0.0.1", 6379).await; | ||
|
||
// Verify functionality of transform | ||
assert_ok( | ||
redis::cmd("SET").arg("foo").arg("some value"), | ||
&mut connection, | ||
) | ||
.await; | ||
assert_bytes( | ||
redis::cmd("GET").arg("foo"), | ||
&mut connection, | ||
b"Rewritten value", | ||
) | ||
.await; | ||
assert_bytes( | ||
redis::cmd("GET").arg("bar"), | ||
&mut connection, | ||
b"Rewritten value", | ||
) | ||
.await; | ||
|
||
// Shutdown shotover asserting that it encountered no errors | ||
shotover.shutdown_and_then_consume_events(&[]).await; | ||
} | ||
|
||
async fn shotover_proxy(topology_path: &str) -> BinProcess { | ||
let mut shotover = BinProcess::start_binary( | ||
bin_path!("custom-transforms-example"), | ||
"shotover", | ||
&["-t", topology_path, "--log-format", "json"], | ||
) | ||
.await; | ||
|
||
tokio::time::timeout( | ||
Duration::from_secs(30), | ||
shotover.wait_for( | ||
&EventMatcher::new() | ||
.with_level(Level::Info) | ||
.with_message("Shotover is now accepting inbound connections"), | ||
&[], | ||
), | ||
) | ||
.await | ||
.unwrap(); | ||
shotover | ||
} | ||
|
||
pub async fn assert_ok(cmd: &mut Cmd, connection: &mut Connection) { | ||
assert_eq!(cmd.query_async(connection).await, Ok("OK".to_string())); | ||
} | ||
|
||
pub async fn assert_bytes(cmd: &mut Cmd, connection: &mut Connection, value: &[u8]) { | ||
assert_eq!(cmd.query_async(connection).await, Ok(value.to_vec())); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,66 +1,2 @@ | ||
use redis::aio::Connection; | ||
use redis::Cmd; | ||
use std::time::Duration; | ||
use test_helpers::connection::redis_connection; | ||
use test_helpers::docker_compose::docker_compose; | ||
use test_helpers::shotover_process::{bin_path, BinProcess, EventMatcher, Level}; | ||
|
||
#[tokio::test(flavor = "multi_thread")] | ||
async fn test_custom_transform() { | ||
// Setup shotover and the redis server it connects to | ||
let _compose = docker_compose("config/docker-compose.yaml"); | ||
let shotover = shotover_proxy("config/topology.yaml").await; | ||
let mut connection = redis_connection::new_async("127.0.0.1", 6379).await; | ||
|
||
// Verify functionality of transform | ||
assert_ok( | ||
redis::cmd("SET").arg("foo").arg("some value"), | ||
&mut connection, | ||
) | ||
.await; | ||
assert_bytes( | ||
redis::cmd("GET").arg("foo"), | ||
&mut connection, | ||
b"Rewritten value", | ||
) | ||
.await; | ||
assert_bytes( | ||
redis::cmd("GET").arg("bar"), | ||
&mut connection, | ||
b"Rewritten value", | ||
) | ||
.await; | ||
|
||
// Shutdown shotover asserting that it encountered no errors | ||
shotover.shutdown_and_then_consume_events(&[]).await; | ||
} | ||
|
||
async fn shotover_proxy(topology_path: &str) -> BinProcess { | ||
let mut shotover = BinProcess::start_binary( | ||
bin_path!("custom-transforms-example"), | ||
"shotover", | ||
&["-t", topology_path, "--log-format", "json"], | ||
) | ||
.await; | ||
|
||
tokio::time::timeout( | ||
Duration::from_secs(30), | ||
shotover.wait_for( | ||
&EventMatcher::new() | ||
.with_level(Level::Info) | ||
.with_message("Shotover is now accepting inbound connections"), | ||
&[], | ||
), | ||
) | ||
.await | ||
.unwrap(); | ||
shotover | ||
} | ||
|
||
pub async fn assert_ok(cmd: &mut Cmd, connection: &mut Connection) { | ||
assert_eq!(cmd.query_async(connection).await, Ok("OK".to_string())); | ||
} | ||
|
||
pub async fn assert_bytes(cmd: &mut Cmd, connection: &mut Connection, value: &[u8]) { | ||
assert_eq!(cmd.query_async(connection).await, Ok(value.to_vec())); | ||
} | ||
#[cfg(feature = "redis")] | ||
mod redis; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.