samsa 0.1.8

Rust-native Kafka/Redpanda protocol and client implementation.
Documentation
mod testsupport;

use random_word::Lang;
use samsa::prelude::redpanda::adminapi::{AdminAPI, TransformMetadataIn, TransformMetadataOut};
use samsa::prelude::Error;

#[tokio::test]
async fn it_returns_not_found_when_deleting_non_existing() -> Result<(), Box<Error>> {
    let (skip, urls) = testsupport::get_redpanda_admin_urls()?;
    if skip {
        return Ok(());
    }
    let client = AdminAPI::builder().urls(urls).build()?;
    let name = random_word::gen(Lang::En);
    let res = client.delete_wasm_transform(name).await;
    assert!(res.is_err());
    assert_eq!(res.err().unwrap(), Error::NotFound);
    Ok(())
}

#[tokio::test]
async fn it_can_write_then_read() -> Result<(), Error> {
    let (skip, urls) = testsupport::get_redpanda_admin_urls()?;
    if skip {
        return Ok(());
    }
    let (skip, topic) = testsupport::get_topic(file!())?;
    if skip {
        return Ok(());
    }
    let (skip, topic_2) = testsupport::get_topic_2(file!())?;
    if skip {
        return Ok(());
    }
    let client = AdminAPI::builder().urls(urls).build()?;

    // Create
    let name = random_word::gen(Lang::En);
    let transform_metadata = TransformMetadataIn {
        name: name.to_string(),
        input_topic: topic.clone(),
        output_topics: vec![topic_2],
        ..Default::default()
    };
    let contents = std::fs::read("testdata/redpanda-identity.wasm")
        .map_err(|err| Error::ArgError(err.to_string()))?;
    client
        .deploy_wasm_transform(transform_metadata, contents)
        .await?;

    // List
    let transforms: Vec<TransformMetadataOut> = client.list_wasm_transforms().await?;
    assert!(transforms.iter().any(|x| x.name == name));

    // Delete
    client.delete_wasm_transform(name).await?;

    // List
    let transforms: Vec<TransformMetadataOut> = client.list_wasm_transforms().await?;
    assert!(!transforms.iter().any(|x| x.name == name));

    Ok(())
}