Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

integrate upstream #25

Merged
merged 171 commits into from
Aug 21, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
171 commits
Select commit Hold shift + click to select a range
b46ea89
Add hostaddr support
trungda Aug 26, 2022
faedb49
Merge branch 'master' into tdinh/hostaddr
trungda Aug 27, 2022
3c9315e
IpAddr + try hostaddr first
trungda Aug 27, 2022
e30bff6
also update postgres
trungda Aug 27, 2022
6c49a45
fmt
trungda Aug 27, 2022
42fef24
explicitly handle host being None
trungda Aug 28, 2022
9b34d74
add negative test
trungda Aug 28, 2022
8ac10ff
move test to runtime
trungda Aug 31, 2022
0550bab
Merge branch 'sfackler:master' into tdinh/hostaddr
trungda Dec 27, 2022
3697f6b
Add hostaddr support
trungda Aug 26, 2022
48874dc
IpAddr + try hostaddr first
trungda Aug 27, 2022
d97bed6
also update postgres
trungda Aug 27, 2022
1a9c1d4
fmt
trungda Aug 27, 2022
58149da
explicitly handle host being None
trungda Aug 28, 2022
7a648ad
add negative test
trungda Aug 28, 2022
a70a7c3
move test to runtime
trungda Aug 31, 2022
b0596f7
Merge branch 'tdinh/hostaddr' of github.com:trungda/rust-postgres int…
trungda Dec 27, 2022
071dfa3
added a rename_all container attribute for enums and structs
JaydenElliott Mar 26, 2023
bc8ad8a
Distinguish between field and container attributes when parsing
JaydenElliott Mar 27, 2023
d509b3b
Replaced case conversion with heck
JaydenElliott Mar 27, 2023
f4b181a
Rename_all attribute documentation
JaydenElliott Mar 28, 2023
b19fdd4
Fix postgres-protocol constraint
sfackler Mar 30, 2023
45d51d7
OpenBSD misses some TCP keepalive options
niklasha Apr 4, 2023
e59a165
rustfmt
niklasha Apr 4, 2023
7dd6813
Merge pull request #1014 from niklasha/openbsd-missing-tcp-keepalive-…
sfackler Apr 4, 2023
a67fe64
refactor(types): simplify `<&str as ToSql>::to_sql`
BastiDood Apr 7, 2023
98abdf9
refactor(types): prefer `matches!` macro for readability
BastiDood Apr 7, 2023
8b9b5d0
Merge pull request #1018 from BastiDood/str-to-sql-refactor
sfackler Apr 7, 2023
e71335e
fix serialization of oidvector
sfackler May 1, 2023
8449e4d
Merge pull request #1027 from sfackler/oidvector
sfackler May 1, 2023
d92b3b0
Fix int2vector serialization
sfackler May 1, 2023
23d2524
Merge pull request #1028 from sfackler/int2vector
sfackler May 1, 2023
80adf04
allow `BorrowToSql` for non-static `Box<dyn ToSql>`
laptou May 7, 2023
066b466
Update ci.yml
sfackler May 7, 2023
22469d6
Merge pull request #1029 from laptou/master
sfackler May 7, 2023
4095490
Update criterion requirement from 0.4 to 0.5
dependabot[bot] May 24, 2023
762f67f
Merge pull request #1037 from sfackler/dependabot/cargo/criterion-0.5
sfackler May 24, 2023
64bf779
feat: add support for wasm
zebp Jun 3, 2023
2230e88
add CI job for checking wasm
zebp Jun 3, 2023
edc7fde
gate wasm support behind feature flag
zebp Jun 4, 2023
1f8fb7a
ignore dev deps in wasm ci
zebp Jun 8, 2023
635bac4
specify js feature for wasm ci
zebp Jun 9, 2023
852869d
Merge pull request #1040 from zebp/feat/wasm-support
sfackler Jun 10, 2023
6f19bb9
clean up wasm32 test
sfackler Jun 10, 2023
790af54
Merge pull request #1008 from JaydenElliott/feature/rename_all_attr
sfackler Jun 10, 2023
258fe68
feat(derive): add `#[postgres(allow_mismatch)]`
viniciusth Apr 30, 2023
4f41157
Merge pull request #945 from trungda/tdinh/hostaddr
sfackler Jul 17, 2023
b09e9cc
Add to_sql for bytes Cow as well
andrewbaxter Jul 20, 2023
34c8dc9
Fixes
Jul 20, 2023
d16a9cd
Merge pull request #1051 from andrewbaxter/patch-1
sfackler Jul 20, 2023
f7a2644
align hostaddr tls behavior with documentation
sfackler Jul 23, 2023
b575745
fix test
sfackler Jul 23, 2023
3346858
Implement load balancing
sfackler Jul 23, 2023
babc856
clippy
sfackler Jul 23, 2023
84aed63
fix wasm build
sfackler Jul 23, 2023
d451465
Merge pull request #1052 from sfackler/load-balance
sfackler Jul 23, 2023
e7eb24a
Merge pull request #1026 from viniciusth/feature/allow-mismatch
sfackler Jul 23, 2023
98814b8
Set user to executing processes' user by default.
ISibboI Aug 19, 2023
4c4059a
Propagate changes from `tokio-postgres` to `postgres`.
ISibboI Aug 19, 2023
7a5b19a
Update Rust version in CI to 1.67.0.
ISibboI Aug 19, 2023
f777f74
Merge pull request #1059 from ISibboI/master
sfackler Aug 19, 2023
a454378
Restore back compat
sfackler Aug 19, 2023
496f46c
Release postgres-protocol v0.6.6
sfackler Aug 20, 2023
43e1569
Release postgres-derive v0.4.5
sfackler Aug 20, 2023
6f7ab44
Release postgres-types v0.2.6
sfackler Aug 20, 2023
3d0a593
Release tokio-postgres v0.7.9
sfackler Aug 20, 2023
e08a38f
sync postgres config up with tokio-postgres
sfackler Aug 20, 2023
f45527f
remove bogus docs
sfackler Aug 20, 2023
75cc986
Release postgres v0.19.6
sfackler Aug 20, 2023
cb609be
Defer username default
sfackler Aug 25, 2023
b411e5c
clippy
sfackler Aug 25, 2023
016e9a3
avoid a silly clone
sfackler Aug 25, 2023
234e20b
bump ci version
sfackler Aug 25, 2023
c50fcbd
Release tokio-postgres v0.7.10
sfackler Aug 25, 2023
c5ff8cf
Release postgres v0.19.7
sfackler Aug 25, 2023
b1306a4
remove rustc-serialize dependency
ds-cbo Oct 20, 2023
ea9e0e5
replace deprecated chrono::DateTime::from_utc
ds-cbo Oct 30, 2023
b4ebc4e
add missing import
ds-cbo Oct 30, 2023
19a6ef7
fix more deprecated chrono functions
ds-cbo Oct 31, 2023
ab23ca8
Merge pull request #1077 from ds-cbo/fix-deprecated-chrono-func
sfackler Oct 31, 2023
a8caff1
Merge remote-tracking branch 'upstream/master' into remove-rustc-seri…
ds-cbo Nov 3, 2023
cc93651
Merge pull request #1074 from ds-cbo/remove-rustc-serialize-dependency
sfackler Nov 3, 2023
863c1d6
fix code block
JamesGuthrie Nov 7, 2023
c5aef21
Merge pull request #1080 from JamesGuthrie/patch-1
sfackler Nov 7, 2023
10edbcb
Update lib.rs
sfackler Nov 7, 2023
02bab67
Add table_oid and field_id to columns of prepared statements
bikeshedder Dec 5, 2023
8787615
Simplify Debug impl of Column
bikeshedder Dec 5, 2023
eb3f595
Merge pull request #1084 from bikeshedder/table_oid_column_id
sfackler Dec 11, 2023
bbc0414
Update id types
sfackler Dec 12, 2023
90c92c2
feat(types): add default derive to json wrapper
TroyKomodo Jan 15, 2024
e8f44ec
Merge pull request #1093 from ScuffleTV/troy/add-default-json
sfackler Jan 15, 2024
2f150a7
Update env_logger requirement from 0.10 to 0.11
dependabot[bot] Jan 22, 2024
7bc3deb
Update ci.yml
sfackler Jan 23, 2024
a92c6eb
Update main.rs
sfackler Jan 23, 2024
8989fc9
Merge pull request #1097 from sfackler/dependabot/cargo/env_logger-0.11
sfackler Jan 23, 2024
289cf88
add #[track_caller] to the Row::get() functions
Feb 16, 2024
25314a9
Bump CI version
sfackler Feb 17, 2024
ba1b4cf
Merge pull request #1104 from njaard/master
sfackler Feb 17, 2024
a9ca481
Added ReadOnly session attr
chandr-andr Mar 3, 2024
6a01730
Added ReadOnly session attr
chandr-andr Mar 3, 2024
d6c2835
Merge pull request #1110 from chandr-andr/feature/add_read_only_sessi…
sfackler Mar 3, 2024
4217553
Update base64 requirement from 0.21 to 0.22
dependabot[bot] Mar 4, 2024
270a29b
Merge pull request #1112 from sfackler/dependabot/cargo/base64-0.22
sfackler Mar 4, 2024
9d7c43c
Shrink query_opt/query_one codegen size very slightly
novacrazy Feb 11, 2024
9743630
use `split_once` instead of `split` to parse lsn strings
laxjesse Mar 13, 2024
e528e01
Merge pull request #1118 from laxjesse/split_once_in_lsn_from_str
sfackler Mar 13, 2024
64caf4c
Merge pull request #1101 from Lantern-chat/async_size
sfackler Mar 17, 2024
3836a30
Make license metadata SPDX compliant
paolobarbolini Apr 10, 2024
8cf7f3a
Merge pull request #1130 from paolobarbolini/spdx
sfackler Apr 10, 2024
670cd7d
Update heck requirement from 0.4 to 0.5
dependabot[bot] Apr 10, 2024
98f5a11
Merge pull request #1117 from sfackler/dependabot/cargo/heck-0.5
sfackler Apr 10, 2024
3c6dbe9
Avoid extra clone in config if possible
nyurik May 2, 2024
d5d75d3
add simple_query to GenericClient in tokio_postgres
vsuryamurthy May 23, 2024
fbecae1
feat(types): add 'js' feature for wasm
duarten Mar 11, 2024
6cd4652
Add RowDescription to SimpleQueryMessage
rigby-dane May 29, 2024
7afead9
Formatting updates
rigby-dane May 29, 2024
eec0602
Clippy compliance
rigby-dane May 29, 2024
bd6350c
Formatting
rigby-dane May 30, 2024
f397668
Work with pools that don't support prepared statements
ramnivas May 26, 2024
84994da
Derive Clone for Row
levkk Jul 6, 2024
2b1949d
impl Debug for Statement
cammeresi Jul 6, 2024
0bd8b2b
Merge pull request #1153 from cammeresi/master
sfackler Jul 6, 2024
f9c2d5c
Merge pull request #1152 from levkk/levkk-add-clone-to-row
sfackler Jul 6, 2024
1f31219
Fix a few nits pointed out by clippy
cammeresi Jul 6, 2024
c2b5c8a
Merge pull request #1154 from cammeresi/master
sfackler Jul 6, 2024
263b006
Handle non-UTF8 error fields
sfackler Jul 6, 2024
7cbb462
Merge pull request #1155 from sfackler/non-utf8-error
sfackler Jul 6, 2024
20749d8
Merge pull request #1116 from duarten/postgres-types-js
sfackler Jul 6, 2024
34a68c0
Merge pull request #1142 from vsuryamurthy/add_simple_query_generic_c…
sfackler Jul 6, 2024
ded5e7d
Merge pull request #1137 from nyurik/use-string
sfackler Jul 6, 2024
cfd9163
PR Fix: Only use single clone for RowDescription
rigby-dane Jul 7, 2024
3f8f5de
Replace the state machine to process messages with a direct match sta…
ramnivas Jul 7, 2024
74eb4db
Remove query_raw_with_param_types as per PR feedback
ramnivas Jul 7, 2024
f00ed42
Merge remote-tracking branch 'origin/master' into exograph
ramnivas Jul 7, 2024
2647024
PR Fix: Clone first then move
rigby-dane Jul 8, 2024
647a925
Merge pull request #1144 from rigby-dane/add_row_description
sfackler Jul 9, 2024
dbd4d02
Address review comment to rename query_with_param_types to query_typed
ramnivas Jul 9, 2024
0fa3247
Fix a clippy warning
ramnivas Jul 10, 2024
257bcfd
Merge pull request #1147 from exograph/exograph
sfackler Jul 13, 2024
71c836b
query_typed tweaks
sfackler Jul 14, 2024
a1bdd0b
Merge pull request #1160 from sfackler/query-typed-cleanup
sfackler Jul 14, 2024
a0b2d70
Fix cancellation of TransactionBuilder::start
sfackler Jul 22, 2024
4b9cdca
Merge pull request #1162 from sfackler/transaction-builder-cancellation
sfackler Jul 22, 2024
c358077
Release postgres-protocol v0.6.7
sfackler Jul 22, 2024
6b4566b
Release postgres-types v0.2.7
sfackler Jul 22, 2024
9226618
Release tokio-postgres v0.7.11
sfackler Jul 22, 2024
9f196e7
Release postgres v0.19.8
sfackler Jul 22, 2024
0fc4005
For `query_typed`, deal with the no-data case.
ramnivas Jul 22, 2024
3afcc3d
Merge pull request #1165 from exograph/query-typed-no-data
sfackler Jul 23, 2024
aa10f0d
Support AIX keepalive
ecnelises Jul 23, 2024
d2634a4
Merge pull request #1166 from ecnelises/aix
sfackler Jul 24, 2024
6e68c10
revert fork patches
petrosagg Aug 21, 2024
958826d
Merge remote-tracking branch 'upstream/master' into mz-master
petrosagg Aug 21, 2024
82bb077
Make simple_query::encode() pub(crate).
jeff-davis Dec 14, 2020
cddba06
Connection string config for replication.
jeff-davis Dec 14, 2020
5f2e1e8
implement Stream for Responses
petrosagg May 27, 2021
2016ec3
add copy_both_simple method
petrosagg Apr 1, 2021
41f5bac
ci: enable logical replication in the test image
petrosagg Nov 23, 2021
acc2ce3
add simple query versions of copy operations
petrosagg Apr 1, 2021
2e7372d
config: add sslmode `verify-ca` and `verify-full`
uce May 17, 2021
c8a054c
config: add ssl config params
uce May 19, 2021
11467f8
describe branching strategy
petrosagg May 24, 2021
443f6c6
Fix conditional imports
benesch Jan 16, 2022
4393291
README: update development instructions
benesch Feb 22, 2022
95a1ef7
README: fix links
benesch Feb 22, 2022
6d8777d
Optionally enable deriving Serialize/Deserialize
benesch Jul 10, 2022
cc77e6e
Change SSL configuration to PEM bytes rather than files
benesch Jul 11, 2022
46c667d
Add options for specifying SSL certificates inline
benesch May 28, 2023
e807e3b
Upgrade to Rust 1.77
benesch Mar 25, 2024
3fe1a99
Expose the backend PID on the client
benesch Jun 14, 2024
900ed50
add independent replication crate
petrosagg Aug 21, 2024
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
27 changes: 27 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,33 @@ jobs:
key: clippy-target-${{ runner.os }}-${{ steps.rust-version.outputs.version }}-${{ hashFiles('Cargo.lock') }}y
- run: cargo clippy --all --all-targets

check-wasm32:
name: check-wasm32
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: sfackler/actions/rustup@master
- run: echo "version=$(rustc --version)" >> $GITHUB_OUTPUT
id: rust-version
- run: rustup target add wasm32-unknown-unknown
- uses: actions/cache@v3
with:
path: ~/.cargo/registry/index
key: index-${{ runner.os }}-${{ github.run_number }}
restore-keys: |
index-${{ runner.os }}-
- run: cargo generate-lockfile
- uses: actions/cache@v3
with:
path: ~/.cargo/registry/cache
key: registry-${{ runner.os }}-${{ steps.rust-version.outputs.version }}-${{ hashFiles('Cargo.lock') }}
- run: cargo fetch
- uses: actions/cache@v3
with:
path: target
key: check-wasm32-target-${{ runner.os }}-${{ steps.rust-version.outputs.version }}-${{ hashFiles('Cargo.lock') }}
- run: cargo check --target wasm32-unknown-unknown --manifest-path tokio-postgres/Cargo.toml --no-default-features --features js

test:
name: test
runs-on: ubuntu-latest
Expand Down
2 changes: 2 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,11 @@ members = [
"postgres-native-tls",
"postgres-openssl",
"postgres-protocol",
"postgres-replication",
"postgres-types",
"tokio-postgres",
]
resolver = "2"

[profile.release]
debug = 2
31 changes: 31 additions & 0 deletions postgres-derive-test/src/compile-fail/invalid-allow-mismatch.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
use postgres_types::{FromSql, ToSql};

#[derive(ToSql, Debug)]
#[postgres(allow_mismatch)]
struct ToSqlAllowMismatchStruct {
a: i32,
}

#[derive(FromSql, Debug)]
#[postgres(allow_mismatch)]
struct FromSqlAllowMismatchStruct {
a: i32,
}

#[derive(ToSql, Debug)]
#[postgres(allow_mismatch)]
struct ToSqlAllowMismatchTupleStruct(i32, i32);

#[derive(FromSql, Debug)]
#[postgres(allow_mismatch)]
struct FromSqlAllowMismatchTupleStruct(i32, i32);

#[derive(FromSql, Debug)]
#[postgres(transparent, allow_mismatch)]
struct TransparentFromSqlAllowMismatchStruct(i32);

#[derive(FromSql, Debug)]
#[postgres(allow_mismatch, transparent)]
struct AllowMismatchFromSqlTransparentStruct(i32);

fn main() {}
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
error: #[postgres(allow_mismatch)] may only be applied to enums
--> src/compile-fail/invalid-allow-mismatch.rs:4:1
|
4 | / #[postgres(allow_mismatch)]
5 | | struct ToSqlAllowMismatchStruct {
6 | | a: i32,
7 | | }
| |_^

error: #[postgres(allow_mismatch)] may only be applied to enums
--> src/compile-fail/invalid-allow-mismatch.rs:10:1
|
10 | / #[postgres(allow_mismatch)]
11 | | struct FromSqlAllowMismatchStruct {
12 | | a: i32,
13 | | }
| |_^

error: #[postgres(allow_mismatch)] may only be applied to enums
--> src/compile-fail/invalid-allow-mismatch.rs:16:1
|
16 | / #[postgres(allow_mismatch)]
17 | | struct ToSqlAllowMismatchTupleStruct(i32, i32);
| |_______________________________________________^

error: #[postgres(allow_mismatch)] may only be applied to enums
--> src/compile-fail/invalid-allow-mismatch.rs:20:1
|
20 | / #[postgres(allow_mismatch)]
21 | | struct FromSqlAllowMismatchTupleStruct(i32, i32);
| |_________________________________________________^

error: #[postgres(transparent)] is not allowed with #[postgres(allow_mismatch)]
--> src/compile-fail/invalid-allow-mismatch.rs:24:25
|
24 | #[postgres(transparent, allow_mismatch)]
| ^^^^^^^^^^^^^^

error: #[postgres(allow_mismatch)] is not allowed with #[postgres(transparent)]
--> src/compile-fail/invalid-allow-mismatch.rs:28:28
|
28 | #[postgres(allow_mismatch, transparent)]
| ^^^^^^^^^^^
43 changes: 43 additions & 0 deletions postgres-derive-test/src/composites.rs
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,49 @@ fn name_overrides() {
);
}

#[test]
fn rename_all_overrides() {
#[derive(FromSql, ToSql, Debug, PartialEq)]
#[postgres(name = "inventory_item", rename_all = "SCREAMING_SNAKE_CASE")]
struct InventoryItem {
name: String,
supplier_id: i32,
#[postgres(name = "Price")]
price: Option<f64>,
}

let mut conn = Client::connect("user=postgres host=localhost port=5433", NoTls).unwrap();
conn.batch_execute(
"CREATE TYPE pg_temp.inventory_item AS (
\"NAME\" TEXT,
\"SUPPLIER_ID\" INT,
\"Price\" DOUBLE PRECISION
);",
)
.unwrap();

let item = InventoryItem {
name: "foobar".to_owned(),
supplier_id: 100,
price: Some(15.50),
};

let item_null = InventoryItem {
name: "foobar".to_owned(),
supplier_id: 100,
price: None,
};

test_type(
&mut conn,
"inventory_item",
&[
(item, "ROW('foobar', 100, 15.50)"),
(item_null, "ROW('foobar', 100, NULL)"),
],
);
}

#[test]
fn wrong_name() {
#[derive(FromSql, ToSql, Debug, PartialEq)]
Expand Down
101 changes: 100 additions & 1 deletion postgres-derive-test/src/enums.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::test_type;
use postgres::{Client, NoTls};
use postgres::{error::DbError, Client, NoTls};
use postgres_types::{FromSql, ToSql, WrongType};
use std::error::Error;

Expand Down Expand Up @@ -53,6 +53,35 @@ fn name_overrides() {
);
}

#[test]
fn rename_all_overrides() {
#[derive(Debug, ToSql, FromSql, PartialEq)]
#[postgres(name = "mood", rename_all = "snake_case")]
enum Mood {
VerySad,
#[postgres(name = "okay")]
Ok,
VeryHappy,
}

let mut conn = Client::connect("user=postgres host=localhost port=5433", NoTls).unwrap();
conn.execute(
"CREATE TYPE pg_temp.mood AS ENUM ('very_sad', 'okay', 'very_happy')",
&[],
)
.unwrap();

test_type(
&mut conn,
"mood",
&[
(Mood::VerySad, "'very_sad'"),
(Mood::Ok, "'okay'"),
(Mood::VeryHappy, "'very_happy'"),
],
);
}

#[test]
fn wrong_name() {
#[derive(Debug, ToSql, FromSql, PartialEq)]
Expand Down Expand Up @@ -102,3 +131,73 @@ fn missing_variant() {
let err = conn.execute("SELECT $1::foo", &[&Foo::Bar]).unwrap_err();
assert!(err.source().unwrap().is::<WrongType>());
}

#[test]
fn allow_mismatch_enums() {
#[derive(Debug, ToSql, FromSql, PartialEq)]
#[postgres(allow_mismatch)]
enum Foo {
Bar,
}

let mut conn = Client::connect("user=postgres host=localhost port=5433", NoTls).unwrap();
conn.execute("CREATE TYPE pg_temp.\"Foo\" AS ENUM ('Bar', 'Baz')", &[])
.unwrap();

let row = conn.query_one("SELECT $1::\"Foo\"", &[&Foo::Bar]).unwrap();
assert_eq!(row.get::<_, Foo>(0), Foo::Bar);
}

#[test]
fn missing_enum_variant() {
#[derive(Debug, ToSql, FromSql, PartialEq)]
#[postgres(allow_mismatch)]
enum Foo {
Bar,
Buz,
}

let mut conn = Client::connect("user=postgres host=localhost port=5433", NoTls).unwrap();
conn.execute("CREATE TYPE pg_temp.\"Foo\" AS ENUM ('Bar', 'Baz')", &[])
.unwrap();

let err = conn
.query_one("SELECT $1::\"Foo\"", &[&Foo::Buz])
.unwrap_err();
assert!(err.source().unwrap().is::<DbError>());
}

#[test]
fn allow_mismatch_and_renaming() {
#[derive(Debug, ToSql, FromSql, PartialEq)]
#[postgres(name = "foo", allow_mismatch)]
enum Foo {
#[postgres(name = "bar")]
Bar,
#[postgres(name = "buz")]
Buz,
}

let mut conn = Client::connect("user=postgres host=localhost port=5433", NoTls).unwrap();
conn.execute("CREATE TYPE pg_temp.foo AS ENUM ('bar', 'baz', 'buz')", &[])
.unwrap();

let row = conn.query_one("SELECT $1::foo", &[&Foo::Buz]).unwrap();
assert_eq!(row.get::<_, Foo>(0), Foo::Buz);
}

#[test]
fn wrong_name_and_allow_mismatch() {
#[derive(Debug, ToSql, FromSql, PartialEq)]
#[postgres(allow_mismatch)]
enum Foo {
Bar,
}

let mut conn = Client::connect("user=postgres host=localhost port=5433", NoTls).unwrap();
conn.execute("CREATE TYPE pg_temp.foo AS ENUM ('Bar', 'Baz')", &[])
.unwrap();

let err = conn.query_one("SELECT $1::foo", &[&Foo::Bar]).unwrap_err();
assert!(err.source().unwrap().is::<WrongType>());
}
7 changes: 7 additions & 0 deletions postgres-derive/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,12 @@
# Change Log

## v0.4.5 - 2023-08-19

### Added

* Added a `rename_all` option for enum and struct derives.
* Added an `allow_mismatch` option to disable strict enum variant checks against the Postgres type.

## v0.4.4 - 2023-03-27

### Changed
Expand Down
5 changes: 3 additions & 2 deletions postgres-derive/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
[package]
name = "postgres-derive"
version = "0.4.4"
version = "0.4.5"
authors = ["Steven Fackler <[email protected]>"]
license = "MIT/Apache-2.0"
license = "MIT OR Apache-2.0"
edition = "2018"
description = "An internal crate used by postgres-types"
repository = "https://github.com/sfackler/rust-postgres"
Expand All @@ -15,3 +15,4 @@ test = false
syn = "2.0"
proc-macro2 = "1.0"
quote = "1.0"
heck = "0.5"
42 changes: 24 additions & 18 deletions postgres-derive/src/accepts.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,31 +31,37 @@ pub fn domain_body(name: &str, field: &syn::Field) -> TokenStream {
}
}

pub fn enum_body(name: &str, variants: &[Variant]) -> TokenStream {
pub fn enum_body(name: &str, variants: &[Variant], allow_mismatch: bool) -> TokenStream {
let num_variants = variants.len();
let variant_names = variants.iter().map(|v| &v.name);

quote! {
if type_.name() != #name {
return false;
if allow_mismatch {
quote! {
type_.name() == #name
}
} else {
quote! {
if type_.name() != #name {
return false;
}

match *type_.kind() {
::postgres_types::Kind::Enum(ref variants) => {
if variants.len() != #num_variants {
return false;
}

variants.iter().all(|v| {
match &**v {
#(
#variant_names => true,
)*
_ => false,
match *type_.kind() {
::postgres_types::Kind::Enum(ref variants) => {
if variants.len() != #num_variants {
return false;
}
})

variants.iter().all(|v| {
match &**v {
#(
#variant_names => true,
)*
_ => false,
}
})
}
_ => false,
}
_ => false,
}
}
}
Expand Down
Loading
Loading