From 279bbedc3cce0f750e786eca8ce253daef8d5370 Mon Sep 17 00:00:00 2001 From: tyranron Date: Sat, 9 Sep 2023 15:00:10 +0300 Subject: [PATCH] Fix CI pipeline - fix codegen tests for latest nightly - switch workspace default to `resolver = "2"` - fix `juniper` tests for latest `chrono` version --- Cargo.toml | 1 + juniper/Cargo.toml | 8 ++--- juniper/src/integrations/chrono.rs | 36 ++++++++++++++----- .../trait/argument_wrong_default_array.stderr | 14 ++++---- .../argument_wrong_default_array.stderr | 14 ++++---- .../argument_wrong_default_array.stderr | 14 ++++---- tests/integration/Cargo.toml | 2 +- 7 files changed, 55 insertions(+), 34 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 42535782..94b6ec98 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,4 +1,5 @@ [workspace] +resolver = "2" members = [ "benches", "examples/basic_subscriptions", diff --git a/juniper/Cargo.toml b/juniper/Cargo.toml index 88bb5d21..4c1a403c 100644 --- a/juniper/Cargo.toml +++ b/juniper/Cargo.toml @@ -50,7 +50,7 @@ anyhow = { version = "1.0.47", default-features = false, optional = true } async-trait = "0.1.39" bigdecimal = { version = "0.4", optional = true } bson = { version = "2.4", features = ["chrono-0_4"], optional = true } -chrono = { version = "0.4.20", features = ["alloc"], default-features = false, optional = true } +chrono = { version = "0.4.30", features = ["alloc"], default-features = false, optional = true } chrono-tz = { version = "0.8", default-features = false, optional = true } fnv = "1.0.3" futures = { version = "0.3.22", features = ["alloc"], default-features = false } @@ -61,7 +61,7 @@ juniper_codegen = { version = "0.16.0-dev", path = "../juniper_codegen" } rust_decimal = { version = "1.20", default-features = false, optional = true } ryu = { version = "1.0", optional = true } serde = { version = "1.0.122", features = ["derive"] } -serde_json = { version = "1.0.18", default-features = false, optional = true } +serde_json = { version = "1.0.18", features = ["std"], default-features = false, optional = true } smartstring = "1.0" static_assertions = "1.1" time = { version = "0.3", features = ["formatting", "macros", "parsing"], optional = true } @@ -70,13 +70,13 @@ uuid = { version = "1.3", default-features = false, optional = true } # Fixes for MSRV check. # TODO: Try remove on upgrade of `chrono-tz` crate. -regex = { version = "1.6", default-features = false, optional = true } +regex = { version = "1.6", features = ["std"], default-features = false, optional = true } # TODO: Remove on upgrade to 0.4.1 version of `graphql-parser`. void = { version = "1.0.2", optional = true } [dev-dependencies] bencher = "0.1.2" -chrono = { version = "0.4.20", features = ["alloc"], default-features = false } +chrono = { version = "0.4.30", features = ["alloc"], default-features = false } pretty_assertions = "1.0.0" serde_json = "1.0.18" tokio = { version = "1.0", features = ["macros", "time", "rt-multi-thread"] } diff --git a/juniper/src/integrations/chrono.rs b/juniper/src/integrations/chrono.rs index 9fbf9bf4..c74eaa01 100644 --- a/juniper/src/integrations/chrono.rs +++ b/juniper/src/integrations/chrono.rs @@ -593,7 +593,7 @@ mod date_time_test { for (raw, expected) in [ ( "2014-11-28T21:00:09+09:00", - DateTime::::from_utc( + DateTime::::from_naive_utc_and_offset( NaiveDateTime::new( NaiveDate::from_ymd_opt(2014, 11, 28).unwrap(), NaiveTime::from_hms_opt(12, 0, 9).unwrap(), @@ -603,7 +603,17 @@ mod date_time_test { ), ( "2014-11-28T21:00:09Z", - DateTime::::from_utc( + DateTime::::from_naive_utc_and_offset( + NaiveDateTime::new( + NaiveDate::from_ymd_opt(2014, 11, 28).unwrap(), + NaiveTime::from_hms_opt(21, 0, 9).unwrap(), + ), + FixedOffset::east_opt(0).unwrap(), + ), + ), + ( + "2014-11-28 21:00:09z", + DateTime::::from_naive_utc_and_offset( NaiveDateTime::new( NaiveDate::from_ymd_opt(2014, 11, 28).unwrap(), NaiveTime::from_hms_opt(21, 0, 9).unwrap(), @@ -613,7 +623,7 @@ mod date_time_test { ), ( "2014-11-28T21:00:09+00:00", - DateTime::::from_utc( + DateTime::::from_naive_utc_and_offset( NaiveDateTime::new( NaiveDate::from_ymd_opt(2014, 11, 28).unwrap(), NaiveTime::from_hms_opt(21, 0, 9).unwrap(), @@ -623,7 +633,17 @@ mod date_time_test { ), ( "2014-11-28T21:00:09.05+09:00", - DateTime::::from_utc( + DateTime::::from_naive_utc_and_offset( + NaiveDateTime::new( + NaiveDate::from_ymd_opt(2014, 11, 28).unwrap(), + NaiveTime::from_hms_milli_opt(12, 0, 9, 50).unwrap(), + ), + FixedOffset::east_opt(0).unwrap(), + ), + ), + ( + "2014-11-28 21:00:09.05+09:00", + DateTime::::from_naive_utc_and_offset( NaiveDateTime::new( NaiveDate::from_ymd_opt(2014, 11, 28).unwrap(), NaiveTime::from_hms_milli_opt(12, 0, 9, 50).unwrap(), @@ -652,7 +672,7 @@ mod date_time_test { graphql_input_value!("56:34:22"), graphql_input_value!("56:34:22.000"), graphql_input_value!("1996-12-1914:23:43"), - graphql_input_value!("1996-12-19 14:23:43Z"), + graphql_input_value!("1996-12-19Q14:23:43Z"), graphql_input_value!("1996-12-19T14:23:43"), graphql_input_value!("1996-12-19T14:23:43ZZ"), graphql_input_value!("1996-12-19T14:23:43.543"), @@ -682,7 +702,7 @@ mod date_time_test { fn formats_correctly() { for (val, expected) in [ ( - DateTime::::from_utc( + DateTime::::from_naive_utc_and_offset( NaiveDateTime::new( NaiveDate::from_ymd_opt(1996, 12, 19).unwrap(), NaiveTime::from_hms_opt(0, 0, 0).unwrap(), @@ -692,7 +712,7 @@ mod date_time_test { graphql_input_value!("1996-12-19T00:00:00Z"), ), ( - DateTime::::from_utc( + DateTime::::from_naive_utc_and_offset( NaiveDateTime::new( NaiveDate::from_ymd_opt(1564, 1, 30).unwrap(), NaiveTime::from_hms_milli_opt(5, 0, 0, 123).unwrap(), @@ -780,7 +800,7 @@ mod integration_test { } fn date_time() -> DateTime { - DateTime::from_utc( + DateTime::from_naive_utc_and_offset( LocalDateTime::new( Date::from_ymd_opt(1996, 12, 20).unwrap(), LocalTime::from_hms_opt(0, 39, 57).unwrap(), diff --git a/tests/codegen/fail/interface/trait/argument_wrong_default_array.stderr b/tests/codegen/fail/interface/trait/argument_wrong_default_array.stderr index d8452fd9..d5aa5f0c 100644 --- a/tests/codegen/fail/interface/trait/argument_wrong_default_array.stderr +++ b/tests/codegen/fail/interface/trait/argument_wrong_default_array.stderr @@ -6,13 +6,13 @@ error[E0277]: the trait bound `[bool; 2]: From<[bool; 3]>` is not satisfied | = help: the following other types implement trait `From`: <[bool; LANES] as From>> - <[u32; 4] as From> - <[u64; 2] as From> - <[u64; 4] as From> - <[T; N] as From>> - <[T; 1] as From<(T,)>> - <[T; 2] as From<(T, T)>> - <[T; 3] as From<(T, T, T)>> + <[u32; 4] as From> + <[u32; 8] as From> + <[u32; 16] as From> + <[u64; 2] as From> + <[u64; 4] as From> + <[u64; 8] as From> + <[u128; 1] as From> and $N others = note: required for `[bool; 3]` to implement `Into<[bool; 2]>` = note: this error originates in the attribute macro `graphql_interface` (in Nightly builds, run with -Z macro-backtrace for more info) diff --git a/tests/codegen/fail/object/argument_wrong_default_array.stderr b/tests/codegen/fail/object/argument_wrong_default_array.stderr index 5f74eea8..04716e21 100644 --- a/tests/codegen/fail/object/argument_wrong_default_array.stderr +++ b/tests/codegen/fail/object/argument_wrong_default_array.stderr @@ -6,13 +6,13 @@ error[E0277]: the trait bound `[bool; 2]: From<[bool; 3]>` is not satisfied | = help: the following other types implement trait `From`: <[bool; LANES] as From>> - <[u32; 4] as From> - <[u64; 2] as From> - <[u64; 4] as From> - <[T; N] as From>> - <[T; 1] as From<(T,)>> - <[T; 2] as From<(T, T)>> - <[T; 3] as From<(T, T, T)>> + <[u32; 4] as From> + <[u32; 8] as From> + <[u32; 16] as From> + <[u64; 2] as From> + <[u64; 4] as From> + <[u64; 8] as From> + <[u128; 1] as From> and $N others = note: required for `[bool; 3]` to implement `Into<[bool; 2]>` = note: this error originates in the attribute macro `graphql_object` (in Nightly builds, run with -Z macro-backtrace for more info) diff --git a/tests/codegen/fail/subscription/argument_wrong_default_array.stderr b/tests/codegen/fail/subscription/argument_wrong_default_array.stderr index 563b8b00..f7618614 100644 --- a/tests/codegen/fail/subscription/argument_wrong_default_array.stderr +++ b/tests/codegen/fail/subscription/argument_wrong_default_array.stderr @@ -6,13 +6,13 @@ error[E0277]: the trait bound `[bool; 2]: From<[bool; 3]>` is not satisfied | = help: the following other types implement trait `From`: <[bool; LANES] as From>> - <[u32; 4] as From> - <[u64; 2] as From> - <[u64; 4] as From> - <[T; N] as From>> - <[T; 1] as From<(T,)>> - <[T; 2] as From<(T, T)>> - <[T; 3] as From<(T, T, T)>> + <[u32; 4] as From> + <[u32; 8] as From> + <[u32; 16] as From> + <[u64; 2] as From> + <[u64; 4] as From> + <[u64; 8] as From> + <[u128; 1] as From> and $N others = note: required for `[bool; 3]` to implement `Into<[bool; 2]>` = note: this error originates in the attribute macro `graphql_subscription` (in Nightly builds, run with -Z macro-backtrace for more info) diff --git a/tests/integration/Cargo.toml b/tests/integration/Cargo.toml index 1d4d5304..4da107dc 100644 --- a/tests/integration/Cargo.toml +++ b/tests/integration/Cargo.toml @@ -6,7 +6,7 @@ publish = false [dev-dependencies] async-trait = "0.1.39" -chrono = { version = "0.4.20", default-features = false } +chrono = { version = "0.4", default-features = false } derive_more = "0.99" fnv = "1.0" futures = "0.3"