| use std::path::PathBuf; |
| |
| use super::split_extern_opt; |
| use crate::EarlyDiagCtxt; |
| use crate::config::UnstableOptions; |
| |
| /// Verifies split_extern_opt handles the supported cases. |
| #[test] |
| fn test_split_extern_opt() { |
| let early_dcx = EarlyDiagCtxt::new(<_>::default()); |
| let unstable_opts = &UnstableOptions::default(); |
| |
| let extern_opt = |
| split_extern_opt(&early_dcx, unstable_opts, "priv,noprelude:foo=libbar.rlib").unwrap(); |
| assert_eq!(extern_opt.crate_name, "foo"); |
| assert_eq!(extern_opt.path, Some(PathBuf::from("libbar.rlib"))); |
| assert_eq!(extern_opt.options, Some("priv,noprelude".to_string())); |
| |
| let extern_opt = split_extern_opt(&early_dcx, unstable_opts, "priv,noprelude:foo").unwrap(); |
| assert_eq!(extern_opt.crate_name, "foo"); |
| assert_eq!(extern_opt.path, None); |
| assert_eq!(extern_opt.options, Some("priv,noprelude".to_string())); |
| |
| let extern_opt = split_extern_opt(&early_dcx, unstable_opts, "foo=libbar.rlib").unwrap(); |
| assert_eq!(extern_opt.crate_name, "foo"); |
| assert_eq!(extern_opt.path, Some(PathBuf::from("libbar.rlib"))); |
| assert_eq!(extern_opt.options, None); |
| |
| let extern_opt = split_extern_opt(&early_dcx, unstable_opts, "foo").unwrap(); |
| assert_eq!(extern_opt.crate_name, "foo"); |
| assert_eq!(extern_opt.path, None); |
| assert_eq!(extern_opt.options, None); |
| } |
| |
| /// Tests some invalid cases for split_extern_opt. |
| #[test] |
| fn test_split_extern_opt_invalid() { |
| let early_dcx = EarlyDiagCtxt::new(<_>::default()); |
| let unstable_opts = &UnstableOptions::default(); |
| |
| // too many `:`s |
| let result = split_extern_opt(&early_dcx, unstable_opts, "priv:noprelude:foo=libbar.rlib"); |
| assert!(result.is_err()); |
| let _ = result.map_err(|e| e.cancel()); |
| |
| // can't nest externs without the unstable flag |
| let result = split_extern_opt(&early_dcx, unstable_opts, "noprelude:foo::bar=libbar.rlib"); |
| assert!(result.is_err()); |
| let _ = result.map_err(|e| e.cancel()); |
| } |
| |
| /// Tests some cases for split_extern_opt with nested crates like `foo::bar`. |
| #[test] |
| fn test_split_extern_opt_nested() { |
| let early_dcx = EarlyDiagCtxt::new(<_>::default()); |
| let unstable_opts = &UnstableOptions { namespaced_crates: true, ..Default::default() }; |
| |
| let extern_opt = |
| split_extern_opt(&early_dcx, unstable_opts, "priv,noprelude:foo::bar=libbar.rlib").unwrap(); |
| assert_eq!(extern_opt.crate_name, "foo::bar"); |
| assert_eq!(extern_opt.path, Some(PathBuf::from("libbar.rlib"))); |
| assert_eq!(extern_opt.options, Some("priv,noprelude".to_string())); |
| |
| let extern_opt = |
| split_extern_opt(&early_dcx, unstable_opts, "priv,noprelude:foo::bar").unwrap(); |
| assert_eq!(extern_opt.crate_name, "foo::bar"); |
| assert_eq!(extern_opt.path, None); |
| assert_eq!(extern_opt.options, Some("priv,noprelude".to_string())); |
| |
| let extern_opt = split_extern_opt(&early_dcx, unstable_opts, "foo::bar=libbar.rlib").unwrap(); |
| assert_eq!(extern_opt.crate_name, "foo::bar"); |
| assert_eq!(extern_opt.path, Some(PathBuf::from("libbar.rlib"))); |
| assert_eq!(extern_opt.options, None); |
| |
| let extern_opt = split_extern_opt(&early_dcx, unstable_opts, "foo::bar").unwrap(); |
| assert_eq!(extern_opt.crate_name, "foo::bar"); |
| assert_eq!(extern_opt.path, None); |
| assert_eq!(extern_opt.options, None); |
| } |
| |
| /// Tests some invalid cases for split_extern_opt with nested crates like `foo::bar`. |
| #[test] |
| fn test_split_extern_opt_nested_invalid() { |
| let early_dcx = EarlyDiagCtxt::new(<_>::default()); |
| let unstable_opts = &UnstableOptions { namespaced_crates: true, ..Default::default() }; |
| |
| // crates can only be nested one deep. |
| let result = |
| split_extern_opt(&early_dcx, unstable_opts, "priv,noprelude:foo::bar::baz=libbar.rlib"); |
| assert!(result.is_err()); |
| let _ = result.map_err(|e| e.cancel()); |
| } |