rust-postgres/postgres-native-tls/src/test.rs

108 lines
2.9 KiB
Rust
Raw Normal View History

2018-10-15 00:44:46 +00:00
use native_tls::{self, Certificate};
use tokio::net::TcpStream;
2019-03-05 05:26:10 +00:00
use tokio_postgres::tls::TlsConnect;
2019-08-03 04:03:54 +00:00
use futures::{FutureExt, TryStreamExt};
2018-10-15 00:44:46 +00:00
2019-01-17 02:30:04 +00:00
#[cfg(feature = "runtime")]
use crate::MakeTlsConnector;
use crate::TlsConnector;
2018-10-15 00:44:46 +00:00
2019-08-03 04:03:54 +00:00
async fn smoke_test<T>(s: &str, tls: T)
where
T: TlsConnect<TcpStream>,
T::Stream: 'static + Send,
{
2019-08-03 04:03:54 +00:00
let stream = TcpStream::connect(&"127.0.0.1:5433".parse().unwrap())
.await
.unwrap();
2018-10-15 00:44:46 +00:00
2018-12-30 05:00:58 +00:00
let builder = s.parse::<tokio_postgres::Config>().unwrap();
2019-08-03 04:03:54 +00:00
let (mut client, connection) = builder.connect_raw(stream, tls).await.unwrap();
2019-08-03 04:03:54 +00:00
let connection = connection.map(|r| r.unwrap());
tokio::spawn(connection);
2018-10-15 00:44:46 +00:00
2019-08-03 04:03:54 +00:00
let stmt = client.prepare("SELECT $1::INT4").await.unwrap();
let rows = client
.query(&stmt, &[&1i32])
.try_collect::<Vec<_>>()
.await
.unwrap();
2018-10-15 00:44:46 +00:00
2019-08-03 04:03:54 +00:00
assert_eq!(rows.len(), 1);
assert_eq!(rows[0].get::<_, i32>(0), 1);
2018-10-15 00:44:46 +00:00
}
2019-08-03 04:03:54 +00:00
#[tokio::test]
async fn require() {
2018-10-15 00:44:46 +00:00
let connector = native_tls::TlsConnector::builder()
.add_root_certificate(
Certificate::from_pem(include_bytes!("../../test/server.crt")).unwrap(),
2018-12-09 01:53:30 +00:00
)
.build()
2018-10-15 00:44:46 +00:00
.unwrap();
smoke_test(
2019-01-13 22:53:19 +00:00
"user=ssl_user dbname=postgres sslmode=require",
2019-01-17 02:30:04 +00:00
TlsConnector::new(connector, "localhost"),
2019-08-03 04:03:54 +00:00
).await;
2018-10-15 00:44:46 +00:00
}
2019-08-03 04:03:54 +00:00
#[tokio::test]
async fn prefer() {
2018-10-15 00:44:46 +00:00
let connector = native_tls::TlsConnector::builder()
.add_root_certificate(
Certificate::from_pem(include_bytes!("../../test/server.crt")).unwrap(),
2018-12-09 01:53:30 +00:00
)
.build()
2018-10-15 00:44:46 +00:00
.unwrap();
smoke_test(
"user=ssl_user dbname=postgres",
2019-01-17 02:30:04 +00:00
TlsConnector::new(connector, "localhost"),
2019-08-03 04:03:54 +00:00
).await;
2018-10-15 00:44:46 +00:00
}
2019-08-03 04:03:54 +00:00
#[tokio::test]
async fn scram_user() {
2018-10-15 00:44:46 +00:00
let connector = native_tls::TlsConnector::builder()
.add_root_certificate(
Certificate::from_pem(include_bytes!("../../test/server.crt")).unwrap(),
2018-12-09 01:53:30 +00:00
)
.build()
2018-10-15 00:44:46 +00:00
.unwrap();
smoke_test(
2019-01-13 22:53:19 +00:00
"user=scram_user password=password dbname=postgres sslmode=require",
2019-01-17 02:30:04 +00:00
TlsConnector::new(connector, "localhost"),
2019-08-03 04:03:54 +00:00
).await;
2018-10-15 00:44:46 +00:00
}
2019-01-17 02:30:04 +00:00
2019-08-03 04:03:54 +00:00
#[tokio::test]
2019-01-17 02:30:04 +00:00
#[cfg(feature = "runtime")]
2019-08-03 04:03:54 +00:00
async fn runtime() {
2019-01-17 02:30:04 +00:00
let connector = native_tls::TlsConnector::builder()
.add_root_certificate(
Certificate::from_pem(include_bytes!("../../test/server.crt")).unwrap(),
)
.build()
.unwrap();
let connector = MakeTlsConnector::new(connector);
2019-08-03 04:03:54 +00:00
let (mut client, connection) = tokio_postgres::connect(
2019-01-17 02:30:04 +00:00
"host=localhost port=5433 user=postgres sslmode=require",
connector,
2019-08-03 04:03:54 +00:00
)
.await
.unwrap();
let connection = connection.map(|r| r.unwrap());
tokio::spawn(connection);
let stmt = client.prepare("SELECT $1::INT4").await.unwrap();
let rows = client
.query(&stmt, &[&1i32])
.try_collect::<Vec<_>>()
.await
.unwrap();
2019-01-17 02:30:04 +00:00
2019-08-03 04:03:54 +00:00
assert_eq!(rows.len(), 1);
assert_eq!(rows[0].get::<_, i32>(0), 1);
2019-01-17 02:30:04 +00:00
}