[go: up one dir, main page]

postgres-derive 0.3.1

Deriving plugin support for Postgres enum, domain, and composite types
Documentation
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
use postgres::types::{FromSql, ToSql};
use postgres::Connection;
use std::fmt;

pub fn test_type<T, S>(conn: &Connection, sql_type: &str, checks: &[(T, S)])
    where T: PartialEq + FromSql + ToSql, S: fmt::Display
{
    for &(ref val, ref repr) in checks.iter() {
        let stmt = conn.prepare(&*format!("SELECT {}::{}", *repr, sql_type)).unwrap();
        let result = stmt.query(&[]).unwrap().iter().next().unwrap().get(0);
        assert_eq!(val, &result);

        let stmt = conn.prepare(&*format!("SELECT $1::{}", sql_type)).unwrap();
        let result = stmt.query(&[val]).unwrap().iter().next().unwrap().get(0);
        assert_eq!(val, &result);
    }
}