use redis::{Client, ErrorKind, JsonAsyncCommands, RedisError, RedisResult};
use redis_macros::{FromRedisValue, Json, ToRedisArgs};
use serde::{Deserialize, Serialize};
#[derive(Debug, PartialEq, Serialize, Deserialize, FromRedisValue)]
enum Address {
Street(String),
Road(String),
}
#[derive(Debug, PartialEq, Serialize, Deserialize, FromRedisValue, ToRedisArgs)]
struct User {
id: u32,
name: String,
addresses: Vec<Address>,
}
#[tokio::main]
async fn main() -> RedisResult<()> {
let client = Client::open("redis://localhost:6379")?;
let mut con = client
.get_multiplexed_async_connection()
.await
.map_err(|_| {
RedisError::from((
ErrorKind::InvalidClientConfig,
"Cannot connect to localhost:6379. Try starting a redis-server process or container.",
))
})?;
let user = User {
id: 1,
name: "Ziggy".to_string(),
addresses: vec![
Address::Street("Downing".to_string()),
Address::Road("Abbey".to_string()),
],
};
let _: () = con.json_set("user_json", "$", &user).await?;
let stored_user: User = con.json_get("user_json", "$").await?;
assert_eq!(user, stored_user);
let stored_address: Address = con.json_get("user_json", "$.addresses[0]").await?;
assert_eq!(user.addresses[0], stored_address);
let Json(stored_name): Json<String> = con.json_get("user_json", "$.name").await?;
assert_eq!(user.name, stored_name);
let Json(stored_addresses): Json<Vec<Address>> =
con.json_get("user_json", "$.addresses").await?;
assert_eq!(user.addresses, stored_addresses);
Ok(())
}
#[test]
fn test_derive_redisjson() {
assert_eq!(main(), Ok(()));
}