rustis 0.19.3

Redis async driver for Rust
Documentation
use crate::{
    Result,
    commands::{GenericCommands, HashCommands, SetCommands},
    tests::get_test_client,
};
use serial_test::serial;
use std::collections::{BTreeMap, BTreeSet, HashMap, HashSet};

#[cfg_attr(feature = "tokio-runtime", tokio::test)]
#[cfg_attr(feature = "async-std-runtime", async_std::test)]
#[serial]
async fn key_value_collection() -> Result<()> {
    let client = get_test_client().await?;

    client.del("key").await?;
    let items = ("field1", "value1");
    let len = client.hset("key", items).await?;
    assert_eq!(1, len);

    client.del("key").await?;
    let items = HashMap::from([("field1", "value1"), ("field2", "value2")]);
    let len = client.hset("key", items).await?;
    assert_eq!(2, len);

    client.del("key").await?;
    let items = BTreeMap::from([("field1", "value1"), ("field2", "value2")]);
    let len = client.hset("key", items).await?;
    assert_eq!(2, len);

    client.del("key").await?;
    let items = vec![("field1", "value1"), ("field2", "value2")];
    let len = client.hset("key", items).await?;
    assert_eq!(2, len);

    client.del("key").await?;
    let items = [("field1", "value1"), ("field2", "value2")];
    let len = client.hset("key", items).await?;
    assert_eq!(2, len);

    client.del("key").await?;
    let items = [("field1", "value1"), ("field2", "value2")];
    let len = client.hset("key", items.as_slice()).await?;
    assert_eq!(2, len);

    client.close().await?;

    Ok(())
}

#[cfg_attr(feature = "tokio-runtime", tokio::test)]
#[cfg_attr(feature = "async-std-runtime", async_std::test)]
#[serial]
async fn set_collection() -> Result<()> {
    let client = get_test_client().await?;

    client.del("key").await?;
    let items = "member1";
    let len = client.sadd("key", items).await?;
    assert_eq!(1, len);

    client.del("key").await?;
    let items = ["member1", "member2"];
    let len = client.sadd("key", items).await?;
    assert_eq!(2, len);

    client.del("key").await?;
    let items = ["member1", "member2"];
    let len = client.sadd("key", items.as_slice()).await?;
    assert_eq!(2, len);

    client.del("key").await?;
    let items = vec!["member1", "member2"];
    let len = client.sadd("key", items).await?;
    assert_eq!(2, len);

    client.del("key").await?;
    let items = HashSet::from(["member1", "member2"]);
    let len = client.sadd("key", items).await?;
    assert_eq!(2, len);

    client.del("key").await?;
    let items = BTreeSet::from(["member1", "member2"]);
    let len = client.sadd("key", items).await?;
    assert_eq!(2, len);

    client.close().await?;

    Ok(())
}