2018-06-27 04:00:26 +00:00
|
|
|
use futures::{Future, Stream};
|
|
|
|
use openssl::ssl::{SslConnector, SslMethod};
|
2018-11-27 06:45:14 +00:00
|
|
|
use tokio::net::TcpStream;
|
2018-06-27 04:00:26 +00:00
|
|
|
use tokio::runtime::current_thread::Runtime;
|
2018-11-27 06:45:14 +00:00
|
|
|
use tokio_postgres::{self, PreferTls, RequireTls, TlsMode};
|
2018-06-27 04:00:26 +00:00
|
|
|
|
2018-12-09 01:27:56 +00:00
|
|
|
use crate::TlsConnector;
|
2018-06-27 04:00:26 +00:00
|
|
|
|
2018-11-27 06:45:14 +00:00
|
|
|
fn smoke_test<T>(builder: &tokio_postgres::Builder, tls: T)
|
|
|
|
where
|
|
|
|
T: TlsMode<TcpStream>,
|
|
|
|
T::Stream: 'static,
|
|
|
|
{
|
2018-06-27 04:00:26 +00:00
|
|
|
let mut runtime = Runtime::new().unwrap();
|
|
|
|
|
2018-11-27 06:45:14 +00:00
|
|
|
let handshake = TcpStream::connect(&"127.0.0.1:5433".parse().unwrap())
|
|
|
|
.map_err(|e| panic!("{}", e))
|
2018-12-17 05:30:52 +00:00
|
|
|
.and_then(|s| builder.handshake(s, tls));
|
2018-06-27 04:00:26 +00:00
|
|
|
let (mut client, connection) = runtime.block_on(handshake).unwrap();
|
|
|
|
let connection = connection.map_err(|e| panic!("{}", e));
|
2018-11-27 06:45:14 +00:00
|
|
|
runtime.spawn(connection);
|
2018-06-27 04:00:26 +00:00
|
|
|
|
|
|
|
let prepare = client.prepare("SELECT 1::INT4");
|
|
|
|
let statement = runtime.block_on(prepare).unwrap();
|
|
|
|
let select = client.query(&statement, &[]).collect().map(|rows| {
|
|
|
|
assert_eq!(rows.len(), 1);
|
|
|
|
assert_eq!(rows[0].get::<_, i32>(0), 1);
|
|
|
|
});
|
|
|
|
runtime.block_on(select).unwrap();
|
|
|
|
|
|
|
|
drop(statement);
|
|
|
|
drop(client);
|
|
|
|
runtime.run().unwrap();
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn require() {
|
|
|
|
let mut builder = SslConnector::builder(SslMethod::tls()).unwrap();
|
|
|
|
builder.set_ca_file("../test/server.crt").unwrap();
|
2018-11-27 06:45:14 +00:00
|
|
|
let ctx = builder.build();
|
2018-06-27 04:00:26 +00:00
|
|
|
smoke_test(
|
2018-11-27 06:45:14 +00:00
|
|
|
tokio_postgres::Builder::new()
|
|
|
|
.user("ssl_user")
|
2018-12-14 05:16:40 +00:00
|
|
|
.dbname("postgres"),
|
2018-11-27 06:45:14 +00:00
|
|
|
RequireTls(TlsConnector::new(ctx.configure().unwrap(), "localhost")),
|
2018-06-27 04:00:26 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn prefer() {
|
|
|
|
let mut builder = SslConnector::builder(SslMethod::tls()).unwrap();
|
|
|
|
builder.set_ca_file("../test/server.crt").unwrap();
|
2018-11-27 06:45:14 +00:00
|
|
|
let ctx = builder.build();
|
2018-06-27 04:00:26 +00:00
|
|
|
smoke_test(
|
2018-11-27 06:45:14 +00:00
|
|
|
tokio_postgres::Builder::new()
|
|
|
|
.user("ssl_user")
|
2018-12-14 05:16:40 +00:00
|
|
|
.dbname("postgres"),
|
2018-11-27 06:45:14 +00:00
|
|
|
PreferTls(TlsConnector::new(ctx.configure().unwrap(), "localhost")),
|
2018-06-27 04:00:26 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn scram_user() {
|
|
|
|
let mut builder = SslConnector::builder(SslMethod::tls()).unwrap();
|
|
|
|
builder.set_ca_file("../test/server.crt").unwrap();
|
2018-11-27 06:45:14 +00:00
|
|
|
let ctx = builder.build();
|
2018-06-27 04:00:26 +00:00
|
|
|
smoke_test(
|
2018-11-27 06:45:14 +00:00
|
|
|
tokio_postgres::Builder::new()
|
|
|
|
.user("scram_user")
|
|
|
|
.password("password")
|
2018-12-14 05:16:40 +00:00
|
|
|
.dbname("postgres"),
|
2018-11-27 06:45:14 +00:00
|
|
|
RequireTls(TlsConnector::new(ctx.configure().unwrap(), "localhost")),
|
2018-06-27 04:00:26 +00:00
|
|
|
);
|
|
|
|
}
|