From 2682ee141816a6c43e0aa9b8b50c18de8a42b08b Mon Sep 17 00:00:00 2001 From: tyranron Date: Thu, 2 May 2024 17:31:20 +0200 Subject: [PATCH] Make Clippy happy for 1.78 Rust --- .../src/schema/translate/graphql_parser.rs | 12 ++--- juniper/src/schema/translate/mod.rs | 1 + juniper/src/validation/rules/mod.rs | 4 +- .../rules/overlapping_fields_can_be_merged.rs | 12 ++--- juniper_codegen/src/common/diagnostic.rs | 14 ------ juniper_codegen/src/common/parse/mod.rs | 22 --------- juniper_codegen/src/graphql_interface/mod.rs | 2 +- .../derive_incompatible_field_type.stderr | 8 ++-- .../interface/struct/attr_cyclic_impl.stderr | 45 +++++++++---------- .../struct/derive_cyclic_impl.stderr | 15 +++---- .../trait/argument_non_input_type.stderr | 4 +- .../fail/interface/trait/cyclic_impl.stderr | 45 +++++++++---------- .../object/argument_non_input_type.stderr | 16 +++++-- .../argument_non_input_type.stderr | 8 ++-- .../fail/union/enum_same_type_ugly.stderr | 34 ++++++++++++++ .../fail/union/struct_same_type_ugly.stderr | 34 ++++++++++++++ .../fail/union/trait_same_type_ugly.stderr | 34 ++++++++++++++ .../tests/codegen_interface_attr_trait.rs | 1 + tests/integration/tests/codegen_union_attr.rs | 2 + tests/integration/tests/issue_407.rs | 1 + tests/integration/tests/issue_798.rs | 1 + tests/integration/tests/issue_922.rs | 1 + 22 files changed, 191 insertions(+), 125 deletions(-) diff --git a/juniper/src/schema/translate/graphql_parser.rs b/juniper/src/schema/translate/graphql_parser.rs index 0fac42ca..eceedbdf 100644 --- a/juniper/src/schema/translate/graphql_parser.rs +++ b/juniper/src/schema/translate/graphql_parser.rs @@ -40,9 +40,9 @@ impl<'a, T> SchemaTranslator<'a, graphql_parser::schema::Document<'a, T>> where T: Text<'a> + Default, { - fn translate_schema(input: &'a SchemaType) -> graphql_parser::schema::Document<'a, T> + fn translate_schema(input: &'a SchemaType) -> graphql_parser::schema::Document<'a, T> where - S: ScalarValue, + S: ScalarValue + 'a, { let mut doc = Document::default(); @@ -94,9 +94,9 @@ impl GraphQLParserTranslator { } } - fn translate_value<'a, S: 'a, T>(input: &'a InputValue) -> ExternalValue<'a, T> + fn translate_value<'a, S, T>(input: &'a InputValue) -> ExternalValue<'a, T> where - S: ScalarValue, + S: ScalarValue + 'a, T: Text<'a>, { match input { @@ -250,9 +250,9 @@ impl GraphQLParserTranslator { } } - fn translate_field<'a, S: 'a, T>(input: &'a Field) -> ExternalField<'a, T> + fn translate_field<'a, S, T>(input: &'a Field) -> ExternalField<'a, T> where - S: ScalarValue, + S: ScalarValue + 'a, T: Text<'a>, { let arguments = input diff --git a/juniper/src/schema/translate/mod.rs b/juniper/src/schema/translate/mod.rs index 99b57ed9..ac370135 100644 --- a/juniper/src/schema/translate/mod.rs +++ b/juniper/src/schema/translate/mod.rs @@ -1,5 +1,6 @@ use crate::{ScalarValue, SchemaType}; +#[cfg_attr(not(feature = "schema-language"), allow(dead_code))] pub trait SchemaTranslator<'a, T> { fn translate_schema(s: &'a SchemaType) -> T; } diff --git a/juniper/src/validation/rules/mod.rs b/juniper/src/validation/rules/mod.rs index 6c22d2c9..1ddaba02 100644 --- a/juniper/src/validation/rules/mod.rs +++ b/juniper/src/validation/rules/mod.rs @@ -35,9 +35,9 @@ use crate::{ }; #[doc(hidden)] -pub fn visit_all_rules<'a, S: Debug>(ctx: &mut ValidatorContext<'a, S>, doc: &'a Document) +pub fn visit_all_rules<'a, S>(ctx: &mut ValidatorContext<'a, S>, doc: &'a Document) where - S: ScalarValue, + S: Debug + ScalarValue, { // Some validators are depending on the results of other ones. // For example, validators checking fragments usually rely on the fact that diff --git a/juniper/src/validation/rules/overlapping_fields_can_be_merged.rs b/juniper/src/validation/rules/overlapping_fields_can_be_merged.rs index a41610d3..9fc53ef0 100644 --- a/juniper/src/validation/rules/overlapping_fields_can_be_merged.rs +++ b/juniper/src/validation/rules/overlapping_fields_can_be_merged.rs @@ -59,26 +59,26 @@ impl OrderedMap { } } - fn get(&self, k: &Q) -> Option<&V> + fn get(&self, k: &Q) -> Option<&V> where K: Borrow, - Q: Hash + Eq, + Q: Hash + Eq + ?Sized, { self.data.get(k) } - fn get_mut(&mut self, k: &Q) -> Option<&mut V> + fn get_mut(&mut self, k: &Q) -> Option<&mut V> where K: Borrow, - Q: Hash + Eq, + Q: Hash + Eq + ?Sized, { self.data.get_mut(k) } - fn contains_key(&self, k: &Q) -> bool + fn contains_key(&self, k: &Q) -> bool where K: Borrow, - Q: Hash + Eq, + Q: Hash + Eq + ?Sized, { self.data.contains_key(k) } diff --git a/juniper_codegen/src/common/diagnostic.rs b/juniper_codegen/src/common/diagnostic.rs index 15f2b0cf..59bb2c0e 100644 --- a/juniper_codegen/src/common/diagnostic.rs +++ b/juniper_codegen/src/common/diagnostic.rs @@ -342,12 +342,6 @@ mod polyfill { /// Behaves like [`Result::unwrap()`]: if `self` is [`Ok`] yield the contained value, /// otherwise abort macro execution. fn unwrap_or_abort(self) -> Self::Ok; - - /// Behaves like [`Result::expect()`]: if `self` is [`Ok`] yield the contained value, - /// otherwise abort macro execution. - /// - /// If it aborts then resulting error message will be preceded with the provided `message`. - fn expect_or_abort(self, message: &str) -> Self::Ok; } impl> ResultExt for Result { @@ -356,13 +350,5 @@ mod polyfill { fn unwrap_or_abort(self) -> T { self.unwrap_or_else(|e| e.into().abort()) } - - fn expect_or_abort(self, message: &str) -> T { - self.unwrap_or_else(|e| { - let mut d = e.into(); - d.msg = format!("{message}: {}", d.msg); - d.abort() - }) - } } } diff --git a/juniper_codegen/src/common/parse/mod.rs b/juniper_codegen/src/common/parse/mod.rs index 304ec4c5..642a050f 100644 --- a/juniper_codegen/src/common/parse/mod.rs +++ b/juniper_codegen/src/common/parse/mod.rs @@ -252,10 +252,6 @@ impl TypeExt for syn::Type { /// Extension of [`syn::Generics`] providing common function widely used by this crate for parsing. pub(crate) trait GenericsExt { - /// Removes all default types out of type parameters and const parameters in these - /// [`syn::Generics`]. - fn remove_defaults(&mut self); - /// Moves all trait and lifetime bounds of these [`syn::Generics`] to its [`syn::WhereClause`]. fn move_bounds_to_where_clause(&mut self); @@ -269,24 +265,6 @@ pub(crate) trait GenericsExt { } impl GenericsExt for syn::Generics { - fn remove_defaults(&mut self) { - use syn::GenericParam as P; - - for p in &mut self.params { - match p { - P::Type(p) => { - p.eq_token = None; - p.default = None; - } - P::Lifetime(_) => {} - P::Const(p) => { - p.eq_token = None; - p.default = None; - } - } - } - } - fn move_bounds_to_where_clause(&mut self) { use syn::GenericParam as P; diff --git a/juniper_codegen/src/graphql_interface/mod.rs b/juniper_codegen/src/graphql_interface/mod.rs index c618af84..5caba2de 100644 --- a/juniper_codegen/src/graphql_interface/mod.rs +++ b/juniper_codegen/src/graphql_interface/mod.rs @@ -401,7 +401,7 @@ impl Definition { let enum_gens = { let mut enum_gens = interface_gens.clone(); - enum_gens.params = interface_gens_lifetimes.clone(); + enum_gens.params.clone_from(&interface_gens_lifetimes); enum_gens.params.extend(variant_gens_pars.clone()); enum_gens.params.extend(interface_gens_tys.clone()); enum_gens diff --git a/tests/codegen/fail/input-object/derive_incompatible_field_type.stderr b/tests/codegen/fail/input-object/derive_incompatible_field_type.stderr index 40ef4e90..86170be5 100644 --- a/tests/codegen/fail/input-object/derive_incompatible_field_type.stderr +++ b/tests/codegen/fail/input-object/derive_incompatible_field_type.stderr @@ -12,7 +12,7 @@ error[E0277]: the trait bound `ObjectA: IsInputType<__S>` is not satisfied as IsInputType> > as IsInputType> - as IsInputType> + > and $N others error[E0277]: the trait bound `ObjectA: FromInputValue<__S>` is not satisfied @@ -32,7 +32,7 @@ error[E0277]: the trait bound `ObjectA: FromInputValue<__S>` is not satisfied as FromInputValue> > as FromInputValue> - as FromInputValue> + > and $N others note: required by a bound in `Registry::<'r, S>::arg` --> $WORKSPACE/juniper/src/executor/mod.rs @@ -57,7 +57,7 @@ error[E0277]: the trait bound `ObjectA: FromInputValue<__S>` is not satisfied as FromInputValue> > as FromInputValue> - as FromInputValue> + > and $N others = note: this error originates in the derive macro `GraphQLInputObject` (in Nightly builds, run with -Z macro-backtrace for more info) @@ -75,6 +75,6 @@ error[E0277]: the trait bound `ObjectA: ToInputValue<_>` is not satisfied as ToInputValue> > as ToInputValue> - as ToInputValue> + > and $N others = note: this error originates in the derive macro `GraphQLInputObject` (in Nightly builds, run with -Z macro-backtrace for more info) diff --git a/tests/codegen/fail/interface/struct/attr_cyclic_impl.stderr b/tests/codegen/fail/interface/struct/attr_cyclic_impl.stderr index c370b161..7d966d1f 100644 --- a/tests/codegen/fail/interface/struct/attr_cyclic_impl.stderr +++ b/tests/codegen/fail/interface/struct/attr_cyclic_impl.stderr @@ -1,27 +1,22 @@ error[E0391]: cycle detected when expanding type alias `Node1Value` - --> fail/interface/struct/attr_cyclic_impl.rs:3:46 - | -3 | #[graphql_interface(impl = Node2Value, for = Node2Value)] - | ^^^^^^^^^^ - | + --> fail/interface/struct/attr_cyclic_impl.rs:3:46 + | +3 | #[graphql_interface(impl = Node2Value, for = Node2Value)] + | ^^^^^^^^^^ + | note: ...which requires expanding type alias `Node2Value`... - --> fail/interface/struct/attr_cyclic_impl.rs:8:46 - | -8 | #[graphql_interface(impl = Node1Value, for = Node1Value)] - | ^^^^^^^^^^ - = note: ...which again requires expanding type alias `Node1Value`, completing the cycle - = note: type aliases cannot be recursive - = help: consider using a struct, enum, or union instead to break the cycle - = help: see for more information -note: cycle used when collecting item types in top-level module - --> fail/interface/struct/attr_cyclic_impl.rs:1:1 - | -1 | / use juniper::graphql_interface; -2 | | -3 | | #[graphql_interface(impl = Node2Value, for = Node2Value)] -4 | | struct Node1 { -... | -12 | | -13 | | fn main() {} - | |____________^ - = note: see https://rustc-dev-guide.rust-lang.org/overview.html#queries and https://rustc-dev-guide.rust-lang.org/query.html for more information + --> fail/interface/struct/attr_cyclic_impl.rs:8:46 + | +8 | #[graphql_interface(impl = Node1Value, for = Node1Value)] + | ^^^^^^^^^^ + = note: ...which again requires expanding type alias `Node1Value`, completing the cycle + = note: type aliases cannot be recursive + = help: consider using a struct, enum, or union instead to break the cycle + = help: see for more information +note: cycle used when computing type of `` + --> fail/interface/struct/attr_cyclic_impl.rs:3:1 + | +3 | #[graphql_interface(impl = Node2Value, for = Node2Value)] + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + = note: see https://rustc-dev-guide.rust-lang.org/overview.html#queries and https://rustc-dev-guide.rust-lang.org/query.html for more information + = 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/interface/struct/derive_cyclic_impl.stderr b/tests/codegen/fail/interface/struct/derive_cyclic_impl.stderr index 8bed2654..f4654ac6 100644 --- a/tests/codegen/fail/interface/struct/derive_cyclic_impl.stderr +++ b/tests/codegen/fail/interface/struct/derive_cyclic_impl.stderr @@ -13,15 +13,10 @@ note: ...which requires expanding type alias `Node2Value`... = note: type aliases cannot be recursive = help: consider using a struct, enum, or union instead to break the cycle = help: see for more information -note: cycle used when collecting item types in top-level module - --> fail/interface/struct/derive_cyclic_impl.rs:1:1 +note: cycle used when computing type of `` + --> fail/interface/struct/derive_cyclic_impl.rs:3:10 | -1 | / use juniper::GraphQLInterface; -2 | | -3 | | #[derive(GraphQLInterface)] -4 | | #[graphql(impl = Node2Value, for = Node2Value)] -... | -14 | | -15 | | fn main() {} - | |____________^ +3 | #[derive(GraphQLInterface)] + | ^^^^^^^^^^^^^^^^ = note: see https://rustc-dev-guide.rust-lang.org/overview.html#queries and https://rustc-dev-guide.rust-lang.org/query.html for more information + = note: this error originates in the derive macro `GraphQLInterface` (in Nightly builds, run with -Z macro-backtrace for more info) diff --git a/tests/codegen/fail/interface/trait/argument_non_input_type.stderr b/tests/codegen/fail/interface/trait/argument_non_input_type.stderr index a72e3015..8f45bb54 100644 --- a/tests/codegen/fail/interface/trait/argument_non_input_type.stderr +++ b/tests/codegen/fail/interface/trait/argument_non_input_type.stderr @@ -11,8 +11,8 @@ error[E0277]: the trait bound `ObjA: IsInputType<__S>` is not satisfied as IsInputType> > as IsInputType> - as IsInputType> > + as IsInputType> and $N others error[E0277]: the trait bound `ObjA: FromInputValue<__S>` is not satisfied @@ -31,8 +31,8 @@ error[E0277]: the trait bound `ObjA: FromInputValue<__S>` is not satisfied as FromInputValue> > as FromInputValue> - as FromInputValue> > + as FromInputValue> and $N others note: required by a bound in `Registry::<'r, S>::arg` --> $WORKSPACE/juniper/src/executor/mod.rs diff --git a/tests/codegen/fail/interface/trait/cyclic_impl.stderr b/tests/codegen/fail/interface/trait/cyclic_impl.stderr index 151fa2f1..af272854 100644 --- a/tests/codegen/fail/interface/trait/cyclic_impl.stderr +++ b/tests/codegen/fail/interface/trait/cyclic_impl.stderr @@ -1,27 +1,22 @@ error[E0391]: cycle detected when expanding type alias `Node1Value` - --> fail/interface/trait/cyclic_impl.rs:3:46 - | -3 | #[graphql_interface(impl = Node2Value, for = Node2Value)] - | ^^^^^^^^^^ - | + --> fail/interface/trait/cyclic_impl.rs:3:46 + | +3 | #[graphql_interface(impl = Node2Value, for = Node2Value)] + | ^^^^^^^^^^ + | note: ...which requires expanding type alias `Node2Value`... - --> fail/interface/trait/cyclic_impl.rs:8:46 - | -8 | #[graphql_interface(impl = Node1Value, for = Node1Value)] - | ^^^^^^^^^^ - = note: ...which again requires expanding type alias `Node1Value`, completing the cycle - = note: type aliases cannot be recursive - = help: consider using a struct, enum, or union instead to break the cycle - = help: see for more information -note: cycle used when collecting item types in top-level module - --> fail/interface/trait/cyclic_impl.rs:1:1 - | -1 | / use juniper::graphql_interface; -2 | | -3 | | #[graphql_interface(impl = Node2Value, for = Node2Value)] -4 | | trait Node1 { -... | -12 | | -13 | | fn main() {} - | |____________^ - = note: see https://rustc-dev-guide.rust-lang.org/overview.html#queries and https://rustc-dev-guide.rust-lang.org/query.html for more information + --> fail/interface/trait/cyclic_impl.rs:8:46 + | +8 | #[graphql_interface(impl = Node1Value, for = Node1Value)] + | ^^^^^^^^^^ + = note: ...which again requires expanding type alias `Node1Value`, completing the cycle + = note: type aliases cannot be recursive + = help: consider using a struct, enum, or union instead to break the cycle + = help: see for more information +note: cycle used when computing type of `` + --> fail/interface/trait/cyclic_impl.rs:3:1 + | +3 | #[graphql_interface(impl = Node2Value, for = Node2Value)] + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + = note: see https://rustc-dev-guide.rust-lang.org/overview.html#queries and https://rustc-dev-guide.rust-lang.org/query.html for more information + = 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_non_input_type.stderr b/tests/codegen/fail/object/argument_non_input_type.stderr index cb8c0e1d..841ff25f 100644 --- a/tests/codegen/fail/object/argument_non_input_type.stderr +++ b/tests/codegen/fail/object/argument_non_input_type.stderr @@ -11,8 +11,8 @@ error[E0277]: the trait bound `ObjA: IsInputType<__S>` is not satisfied as IsInputType> > as IsInputType> - as IsInputType> > + as IsInputType> and $N others error[E0277]: the trait bound `ObjA: FromInputValue<__S>` is not satisfied @@ -31,8 +31,8 @@ error[E0277]: the trait bound `ObjA: FromInputValue<__S>` is not satisfied as FromInputValue> > as FromInputValue> - as FromInputValue> > + as FromInputValue> and $N others note: required by a bound in `Registry::<'r, S>::arg` --> $WORKSPACE/juniper/src/executor/mod.rs @@ -56,8 +56,8 @@ error[E0277]: the trait bound `ObjA: FromInputValue<__S>` is not satisfied as FromInputValue> > as FromInputValue> - as FromInputValue> > + as FromInputValue> and $N others = note: this error originates in the attribute macro `graphql_object` (in Nightly builds, run with -Z macro-backtrace for more info) @@ -74,6 +74,14 @@ error[E0277]: the trait bound `ObjA: FromInputValue<__S>` is not satisfied as FromInputValue> > as FromInputValue> - as FromInputValue> > + as FromInputValue> and $N others + +warning: unused variable: `obj` + --> fail/object/argument_non_input_type.rs:12:18 + | +12 | fn id(&self, obj: ObjA) -> &str { + | ^^^ help: if this is intentional, prefix it with an underscore: `_obj` + | + = note: `#[warn(unused_variables)]` on by default diff --git a/tests/codegen/fail/subscription/argument_non_input_type.stderr b/tests/codegen/fail/subscription/argument_non_input_type.stderr index be23f0ad..5e8da836 100644 --- a/tests/codegen/fail/subscription/argument_non_input_type.stderr +++ b/tests/codegen/fail/subscription/argument_non_input_type.stderr @@ -19,8 +19,8 @@ error[E0277]: the trait bound `ObjA: IsInputType<__S>` is not satisfied as IsInputType> > as IsInputType> - as IsInputType> > + as IsInputType> and $N others error[E0277]: the trait bound `ObjA: FromInputValue<__S>` is not satisfied @@ -39,8 +39,8 @@ error[E0277]: the trait bound `ObjA: FromInputValue<__S>` is not satisfied as FromInputValue> > as FromInputValue> - as FromInputValue> > + as FromInputValue> and $N others note: required by a bound in `Registry::<'r, S>::arg` --> $WORKSPACE/juniper/src/executor/mod.rs @@ -64,8 +64,8 @@ error[E0277]: the trait bound `ObjA: FromInputValue<__S>` is not satisfied as FromInputValue> > as FromInputValue> - as FromInputValue> > + as FromInputValue> and $N others = note: this error originates in the attribute macro `graphql_subscription` (in Nightly builds, run with -Z macro-backtrace for more info) @@ -82,6 +82,6 @@ error[E0277]: the trait bound `ObjA: FromInputValue<__S>` is not satisfied as FromInputValue> > as FromInputValue> - as FromInputValue> > + as FromInputValue> and $N others diff --git a/tests/codegen/fail/union/enum_same_type_ugly.stderr b/tests/codegen/fail/union/enum_same_type_ugly.stderr index 11a97648..9e207cc8 100644 --- a/tests/codegen/fail/union/enum_same_type_ugly.stderr +++ b/tests/codegen/fail/union/enum_same_type_ugly.stderr @@ -8,3 +8,37 @@ error[E0119]: conflicting implementations of trait `MutuallyExclusive` for type | conflicting implementation for `std::string::String` | = note: this error originates in the macro `::juniper::sa::assert_type_ne_all` which comes from the expansion of the derive macro `GraphQLUnion` (in Nightly builds, run with -Z macro-backtrace for more info) + +error[E0277]: the trait bound `std::string::String: GraphQLObject<__S>` is not satisfied + --> fail/union/enum_same_type_ugly.rs:5:7 + | +5 | A(std::string::String), + | ^^^^^^^^^^^^^^^^^^^ the trait `GraphQLObject<__S>` is not implemented for `std::string::String` + | + = help: the following other types implement trait `GraphQLObject`: + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + > + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + <&T as GraphQLObject> + +error[E0277]: the trait bound `std::string::String: GraphQLObject<__S>` is not satisfied + --> fail/union/enum_same_type_ugly.rs:6:7 + | +6 | B(String), + | ^^^^^^ the trait `GraphQLObject<__S>` is not implemented for `std::string::String` + | + = help: the following other types implement trait `GraphQLObject`: + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + > + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + <&T as GraphQLObject> diff --git a/tests/codegen/fail/union/struct_same_type_ugly.stderr b/tests/codegen/fail/union/struct_same_type_ugly.stderr index 6ed02c6f..76c2bb96 100644 --- a/tests/codegen/fail/union/struct_same_type_ugly.stderr +++ b/tests/codegen/fail/union/struct_same_type_ugly.stderr @@ -8,3 +8,37 @@ error[E0119]: conflicting implementations of trait `MutuallyExclusive` for type | conflicting implementation for `std::string::String` | = note: this error originates in the macro `::juniper::sa::assert_type_ne_all` which comes from the expansion of the derive macro `GraphQLUnion` (in Nightly builds, run with -Z macro-backtrace for more info) + +error[E0277]: the trait bound `std::string::String: GraphQLObject<__S>` is not satisfied + --> fail/union/struct_same_type_ugly.rs:5:14 + | +5 | #[graphql(on std::string::String = Character::b)] + | ^^^^^^^^^^^^^^^^^^^ the trait `GraphQLObject<__S>` is not implemented for `std::string::String` + | + = help: the following other types implement trait `GraphQLObject`: + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + > + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + <&T as GraphQLObject> + +error[E0277]: the trait bound `std::string::String: GraphQLObject<__S>` is not satisfied + --> fail/union/struct_same_type_ugly.rs:4:14 + | +4 | #[graphql(on String = Character::a)] + | ^^^^^^ the trait `GraphQLObject<__S>` is not implemented for `std::string::String` + | + = help: the following other types implement trait `GraphQLObject`: + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + > + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + <&T as GraphQLObject> diff --git a/tests/codegen/fail/union/trait_same_type_ugly.stderr b/tests/codegen/fail/union/trait_same_type_ugly.stderr index dc8a1868..a44839f4 100644 --- a/tests/codegen/fail/union/trait_same_type_ugly.stderr +++ b/tests/codegen/fail/union/trait_same_type_ugly.stderr @@ -8,3 +8,37 @@ error[E0119]: conflicting implementations of trait `MutuallyExclusive` for type | conflicting implementation for `std::string::String` | = note: this error originates in the macro `::juniper::sa::assert_type_ne_all` which comes from the expansion of the attribute macro `graphql_union` (in Nightly builds, run with -Z macro-backtrace for more info) + +error[E0277]: the trait bound `std::string::String: GraphQLObject<__S>` is not satisfied + --> fail/union/trait_same_type_ugly.rs:5:28 + | +5 | fn a(&self) -> Option<&String>; + | ^^^^^^ the trait `GraphQLObject<__S>` is not implemented for `std::string::String` + | + = help: the following other types implement trait `GraphQLObject`: + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + > + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + <&T as GraphQLObject> + +error[E0277]: the trait bound `std::string::String: GraphQLObject<__S>` is not satisfied + --> fail/union/trait_same_type_ugly.rs:6:28 + | +6 | fn b(&self) -> Option<&std::string::String>; + | ^^^^^^^^^^^^^^^^^^^ the trait `GraphQLObject<__S>` is not implemented for `std::string::String` + | + = help: the following other types implement trait `GraphQLObject`: + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + > + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + as GraphQLObject> + <&T as GraphQLObject> diff --git a/tests/integration/tests/codegen_interface_attr_trait.rs b/tests/integration/tests/codegen_interface_attr_trait.rs index 51f1f930..6c569b4b 100644 --- a/tests/integration/tests/codegen_interface_attr_trait.rs +++ b/tests/integration/tests/codegen_interface_attr_trait.rs @@ -1,5 +1,6 @@ //! Tests for `#[graphql_interface]` macro placed on a trait. +#![allow(dead_code)] // Assert that `#[graphql_interface]` macro placed on a trait stops Clippy from enforcing `# Errors` // and `# Panics` sections in GraphQL descriptions. #![deny(clippy::missing_errors_doc, clippy::missing_panics_doc)] diff --git a/tests/integration/tests/codegen_union_attr.rs b/tests/integration/tests/codegen_union_attr.rs index 1df7f5cf..a10a2435 100644 --- a/tests/integration/tests/codegen_union_attr.rs +++ b/tests/integration/tests/codegen_union_attr.rs @@ -998,6 +998,7 @@ mod inferred_custom_context { mod ignored_method { use super::*; + #[allow(dead_code)] #[graphql_union] trait Character { fn as_human(&self) -> prelude::Option<&Human> { @@ -1180,6 +1181,7 @@ mod full_featured { use super::*; /// Rust doc. + #[allow(dead_code)] #[graphql_union(name = "MyChar")] #[graphql_union(description = "My character.")] #[graphql_union(context = CustomContext, scalar = DefaultScalarValue)] diff --git a/tests/integration/tests/issue_407.rs b/tests/integration/tests/issue_407.rs index a8a4ef13..a49afdfc 100644 --- a/tests/integration/tests/issue_407.rs +++ b/tests/integration/tests/issue_407.rs @@ -8,6 +8,7 @@ use juniper::{ struct Query; +#[allow(dead_code)] #[graphql_interface(for = [Human, Droid])] trait Character { fn id(&self) -> &str; diff --git a/tests/integration/tests/issue_798.rs b/tests/integration/tests/issue_798.rs index 40252406..0572594b 100644 --- a/tests/integration/tests/issue_798.rs +++ b/tests/integration/tests/issue_798.rs @@ -6,6 +6,7 @@ use juniper::{ EmptySubscription, GraphQLObject, GraphQLUnion, RootNode, }; +#[allow(dead_code)] #[graphql_interface(for = [Human, Droid])] trait Character { fn id(&self) -> &str; diff --git a/tests/integration/tests/issue_922.rs b/tests/integration/tests/issue_922.rs index b592f392..627a5ed8 100644 --- a/tests/integration/tests/issue_922.rs +++ b/tests/integration/tests/issue_922.rs @@ -24,6 +24,7 @@ impl Query { } } +#[allow(dead_code)] #[graphql_interface(for = [Human, Droid])] trait Character { fn id(&self) -> i32;