Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

14 changes: 14 additions & 0 deletions clippy.toml
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,20 @@ disallowed-methods = [
{ path = "aws_config::from_env", reason = "use the `mz_aws_config::defaults` function instead" },
{ path = "aws_config::load_from_env", reason = "use the `mz_aws_config::defaults` function instead" },
{ path = "aws_sdk_s3::Client::new", reason = "use the `mz_aws_util::s3::new_client` function instead" },
{ path = "tokio_postgres::Client::simple_query", reason = "use `mz_postgres_util::simple_query` with `Sql` instead" },
{ path = "tokio_postgres::Client::batch_execute", reason = "use `mz_postgres_util::batch_execute` with `Sql` instead" },
{ path = "tokio_postgres::Client::query", reason = "use `mz_postgres_util::query`/`query_prepared` wrappers instead" },
{ path = "tokio_postgres::Client::query_one", reason = "use `mz_postgres_util::query_one`/`query_one_prepared` wrappers instead" },
{ path = "tokio_postgres::Client::query_opt", reason = "use `mz_postgres_util::query_opt`/`query_opt_prepared` wrappers instead" },
{ path = "tokio_postgres::Client::execute", reason = "use `mz_postgres_util::execute`/`execute_prepared` wrappers instead" },
{ path = "tokio_postgres::Transaction::simple_query", reason = "use `Sql` wrappers from `mz_postgres_util` instead" },
{ path = "tokio_postgres::Transaction::batch_execute", reason = "use `Sql` wrappers from `mz_postgres_util` instead" },
{ path = "tokio_postgres::Transaction::query", reason = "use `mz_postgres_util::query`/`query_prepared` wrappers instead" },
{ path = "tokio_postgres::Transaction::query_one", reason = "use `mz_postgres_util::query_one`/`query_one_prepared` wrappers instead" },
{ path = "tokio_postgres::Transaction::query_opt", reason = "use `mz_postgres_util::query_opt`/`query_opt_prepared` wrappers instead" },
{ path = "tokio_postgres::Transaction::execute", reason = "use `mz_postgres_util::execute`/`execute_prepared` wrappers instead" },
{ path = "postgres::Client::simple_query", reason = "avoid direct string SQL; use `Sql` composition and wrappers where possible" },
{ path = "postgres::Client::batch_execute", reason = "avoid direct string SQL; use `Sql` composition and wrappers where possible" },

# Prevent access to Differential APIs that want to use the default trace or use a default name, or where we offer
# our own wrapper
Expand Down
86 changes: 47 additions & 39 deletions src/adapter/src/catalog.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2328,6 +2328,7 @@ mod tests {

use itertools::Itertools;
use mz_catalog::memory::objects::CatalogItem;
use mz_postgres_util::{query, sql};
use tokio_postgres::NoTls;
use tokio_postgres::types::Type;
use uuid::Uuid;
Expand Down Expand Up @@ -2877,39 +2878,43 @@ mod tests {
name: String,
}

let pg_proc: BTreeMap<_, _> = client
.query(
let pg_proc: BTreeMap<_, _> = query(
&client,
sql!(
"SELECT
p.oid,
proname,
proargtypes,
prorettype,
proretset
FROM pg_proc p
JOIN pg_namespace n ON p.pronamespace = n.oid",
&[],
)
.await
.expect("pg query failed")
.into_iter()
.map(|row| {
let oid: u32 = row.get("oid");
let pg_proc = PgProc {
name: row.get("proname"),
arg_oids: row.get("proargtypes"),
ret_oid: row.get("prorettype"),
ret_set: row.get("proretset"),
};
(oid, pg_proc)
})
.collect();
JOIN pg_namespace n ON p.pronamespace = n.oid"
),
&[],
)
.await
.expect("pg query failed")
.into_iter()
.map(|row| {
let oid: u32 = row.get("oid");
let pg_proc = PgProc {
name: row.get("proname"),
arg_oids: row.get("proargtypes"),
ret_oid: row.get("prorettype"),
ret_set: row.get("proretset"),
};
(oid, pg_proc)
})
.collect();

let pg_type: BTreeMap<_, _> = client
.query(
"SELECT oid, typname, typtype::text, typelem, typarray, typinput::oid, typreceive::oid as typreceive FROM pg_type",
&[],
)
.await
let pg_type: BTreeMap<_, _> = query(
&client,
sql!(
"SELECT oid, typname, typtype::text, typelem, typarray, typinput::oid, typreceive::oid as typreceive FROM pg_type"
),
&[],
)
.await
.expect("pg query failed")
.into_iter()
.map(|row| {
Expand All @@ -2926,20 +2931,23 @@ mod tests {
})
.collect();

let pg_oper: BTreeMap<_, _> = client
.query("SELECT oid, oprname, oprresult FROM pg_operator", &[])
.await
.expect("pg query failed")
.into_iter()
.map(|row| {
let oid: u32 = row.get("oid");
let pg_oper = PgOper {
name: row.get("oprname"),
oprresult: row.get("oprresult"),
};
(oid, pg_oper)
})
.collect();
let pg_oper: BTreeMap<_, _> = query(
&client,
sql!("SELECT oid, oprname, oprresult FROM pg_operator"),
&[],
)
.await
.expect("pg query failed")
.into_iter()
.map(|row| {
let oid: u32 = row.get("oid");
let pg_oper = PgOper {
name: row.get("oprname"),
oprresult: row.get("oprresult"),
};
(oid, pg_oper)
})
.collect();

let conn_catalog = catalog.for_system_session();
let resolve_type_oid = |item: &str| {
Expand Down
1 change: 1 addition & 0 deletions src/balancerd/tests/server.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@ use uuid::Uuid;

#[mz_ore::test(tokio::test(flavor = "multi_thread", worker_threads = 1))]
#[cfg_attr(miri, ignore)] // too slow
#[allow(clippy::disallowed_methods)]
async fn test_balancer() {
let ca = Ca::new_root("test ca").unwrap();
let (server_cert, server_key) = ca
Expand Down
1 change: 1 addition & 0 deletions src/environmentd/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,7 @@ mz-persist-client = { path = "../persist-client" }
mz-pgrepr = { path = "../pgrepr" }
mz-pgwire = { path = "../pgwire" }
mz-pgwire-common = { path = "../pgwire-common" }
mz-postgres-util = { path = "../postgres-util" }
mz-prof-http = { path = "../prof-http" }
mz-repr = { path = "../repr" }
mz-secrets = { path = "../secrets" }
Expand Down
Loading