From 9835e2ae736235810b4ea1c162ca5e65c547e770 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sat, 18 May 2024 04:49:50 +0200 Subject: Merging upstream version 1.71.1+dfsg1. Signed-off-by: Daniel Baumann --- vendor/syn-1.0.109/tests/test_pat.rs | 67 ++++++++++++++++++++++++++++++++++++ 1 file changed, 67 insertions(+) create mode 100644 vendor/syn-1.0.109/tests/test_pat.rs (limited to 'vendor/syn-1.0.109/tests/test_pat.rs') diff --git a/vendor/syn-1.0.109/tests/test_pat.rs b/vendor/syn-1.0.109/tests/test_pat.rs new file mode 100644 index 000000000..695e4736e --- /dev/null +++ b/vendor/syn-1.0.109/tests/test_pat.rs @@ -0,0 +1,67 @@ +#[macro_use] +mod macros; + +use proc_macro2::{Delimiter, Group, TokenStream, TokenTree}; +use quote::quote; +use std::iter::FromIterator; +use syn::{Item, Pat, Stmt}; + +#[test] +fn test_pat_ident() { + match syn::parse2(quote!(self)).unwrap() { + Pat::Ident(_) => (), + value => panic!("expected PatIdent, got {:?}", value), + } +} + +#[test] +fn test_pat_path() { + match syn::parse2(quote!(self::CONST)).unwrap() { + Pat::Path(_) => (), + value => panic!("expected PatPath, got {:?}", value), + } +} + +#[test] +fn test_leading_vert() { + // https://github.com/rust-lang/rust/blob/1.43.0/src/test/ui/or-patterns/remove-leading-vert.rs + + syn::parse_str::("fn f() {}").unwrap(); + syn::parse_str::("fn fun1(| A: E) {}").unwrap_err(); + syn::parse_str::("fn fun2(|| A: E) {}").unwrap_err(); + + syn::parse_str::("let | () = ();").unwrap(); + syn::parse_str::("let (| A): E;").unwrap(); + syn::parse_str::("let (|| A): (E);").unwrap_err(); + syn::parse_str::("let (| A,): (E,);").unwrap(); + syn::parse_str::("let [| A]: [E; 1];").unwrap(); + syn::parse_str::("let [|| A]: [E; 1];").unwrap_err(); + syn::parse_str::("let TS(| A): TS;").unwrap(); + syn::parse_str::("let TS(|| A): TS;").unwrap_err(); + syn::parse_str::("let NS { f: | A }: NS;").unwrap(); + syn::parse_str::("let NS { f: || A }: NS;").unwrap_err(); +} + +#[test] +fn test_group() { + let group = Group::new(Delimiter::None, quote!(Some(_))); + let tokens = TokenStream::from_iter(vec![TokenTree::Group(group)]); + + snapshot!(tokens as Pat, @r###" + Pat::TupleStruct { + path: Path { + segments: [ + PathSegment { + ident: "Some", + arguments: None, + }, + ], + }, + pat: PatTuple { + elems: [ + Pat::Wild, + ], + }, + } + "###); +} -- cgit v1.2.3