@@ -408,7 +408,7 @@ mod tests {
408408 #[ test]
409409 fn build_command ( ) {
410410 insta:: assert_compact_debug_snapshot!( get_build_commands( "@rust-timer build 5832462aa1d9373b24ace96ad2c50b7a18af9952" ) ,
411- @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af9952", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None } })]"# ) ;
411+ @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af9952", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: None } })]"# ) ;
412412 }
413413
414414 #[ test]
@@ -417,7 +417,7 @@ mod tests {
417417@rust-timer build 5832462aa1d9373b24ace96ad2c50b7a18af9952
418418@rust-timer build 23936af287657fa4148aeab40cc2a780810fae52
419419"# ) ,
420- @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af9952", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None } }), Ok(BuildCommand { sha: "23936af287657fa4148aeab40cc2a780810fae52", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None } })]"# ) ;
420+ @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af9952", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: None } }), Ok(BuildCommand { sha: "23936af287657fa4148aeab40cc2a780810fae52", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles : None } })]"# ) ;
421421 }
422422
423423 #[ test]
@@ -429,14 +429,14 @@ mod tests {
429429 #[ test]
430430 fn build_command_complex ( ) {
431431 insta:: assert_compact_debug_snapshot!( get_build_commands( " @rust-timer build sha123456 exclude=baz include=foo,bar runs=4" ) ,
432- @r#"[Ok(BuildCommand { sha: "sha123456", params: BenchmarkParameters { include: Some("foo,bar"), exclude: Some("baz"), runs: Some(4), backends: None } })]"# ) ;
432+ @r#"[Ok(BuildCommand { sha: "sha123456", params: BenchmarkParameters { include: Some("foo,bar"), exclude: Some("baz"), runs: Some(4), backends: None, profiles: None } })]"# ) ;
433433 }
434434
435435 #[ test]
436436 fn build_command_link ( ) {
437437 insta:: assert_compact_debug_snapshot!( get_build_commands( r#"
438438@rust-timer build https://github.com/rust-lang/rust/commit/323f521bc6d8f2b966ba7838a3f3ee364e760b7e"# ) ,
439- @r#"[Ok(BuildCommand { sha: "323f521bc6d8f2b966ba7838a3f3ee364e760b7e", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None } })]"# ) ;
439+ @r#"[Ok(BuildCommand { sha: "323f521bc6d8f2b966ba7838a3f3ee364e760b7e", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: None } })]"# ) ;
440440 }
441441
442442 #[ test]
@@ -452,7 +452,7 @@ mod tests {
452452 #[ test]
453453 fn queue_command ( ) {
454454 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue" ) ,
455- @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None } }))" ) ;
455+ @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: None } }))" ) ;
456456 }
457457
458458 #[ test]
@@ -470,19 +470,19 @@ mod tests {
470470 #[ test]
471471 fn queue_command_include ( ) {
472472 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue include=abcd,feih" ) ,
473- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("abcd,feih"), exclude: None, runs: None, backends: None } }))"# ) ;
473+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("abcd,feih"), exclude: None, runs: None, backends: None, profiles: None } }))"# ) ;
474474 }
475475
476476 #[ test]
477477 fn queue_command_exclude ( ) {
478478 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue exclude=foo134,barzbaz41baf" ) ,
479- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: Some("foo134,barzbaz41baf"), runs: None, backends: None } }))"# ) ;
479+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: Some("foo134,barzbaz41baf"), runs: None, backends: None, profiles: None } }))"# ) ;
480480 }
481481
482482 #[ test]
483483 fn queue_command_runs ( ) {
484484 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue runs=5" ) ,
485- @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: Some(5), backends: None } }))" ) ;
485+ @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: Some(5), backends: None, profiles: None } }))" ) ;
486486 }
487487
488488 #[ test]
@@ -494,7 +494,7 @@ mod tests {
494494 #[ test]
495495 fn queue_command_combination ( ) {
496496 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue include=acda,13asd exclude=c13,DA runs=5" ) ,
497- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("acda,13asd"), exclude: Some("c13,DA"), runs: Some(5), backends: None } }))"# ) ;
497+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("acda,13asd"), exclude: Some("c13,DA"), runs: Some(5), backends: None, profiles: None } }))"# ) ;
498498 }
499499
500500 #[ test]
@@ -506,19 +506,19 @@ mod tests {
506506 #[ test]
507507 fn queue_command_spaces ( ) {
508508 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue include=abcd,das " ) ,
509- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("abcd,das"), exclude: None, runs: None, backends: None } }))"# ) ;
509+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("abcd,das"), exclude: None, runs: None, backends: None, profiles: None } }))"# ) ;
510510 }
511511
512512 #[ test]
513513 fn queue_command_with_bors ( ) {
514514 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@bors try @rust-timer queue include=foo,bar" ) ,
515- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("foo,bar"), exclude: None, runs: None, backends: None } }))"# ) ;
515+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("foo,bar"), exclude: None, runs: None, backends: None, profiles: None } }))"# ) ;
516516 }
517517
518518 #[ test]
519519 fn queue_command_parameter_order ( ) {
520520 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue runs=3 exclude=c,a include=b" ) ,
521- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("b"), exclude: Some("c,a"), runs: Some(3), backends: None } }))"# ) ;
521+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("b"), exclude: Some("c,a"), runs: Some(3), backends: None, profiles: None } }))"# ) ;
522522 }
523523
524524 #[ test]
@@ -529,7 +529,7 @@ Let's do a perf run quickly and then we can merge it.
529529@bors try @rust-timer queue include=foo,bar
530530
531531Otherwise LGTM."# ) ,
532- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("foo,bar"), exclude: None, runs: None, backends: None } }))"# ) ;
532+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("foo,bar"), exclude: None, runs: None, backends: None, profiles: None } }))"# ) ;
533533 }
534534
535535 fn get_build_commands ( body : & str ) -> Vec < Result < BuildCommand < ' _ > , String > > {
@@ -539,44 +539,58 @@ Otherwise LGTM."#),
539539 #[ test]
540540 fn build_command_with_backends ( ) {
541541 insta:: assert_compact_debug_snapshot!( get_build_commands( r#"@rust-timer build 5832462aa1d9373b24ace96ad2c50b7a18af995G"# ) ,
542- @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af995G", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None } })]"# ) ;
542+ @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af995G", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: None } })]"# ) ;
543543 insta:: assert_compact_debug_snapshot!( get_build_commands( r#"@rust-timer build 5832462aa1d9373b24ace96ad2c50b7a18af995A backends=Llvm"# ) ,
544- @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af995A", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Llvm") } })]"# ) ;
544+ @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af995A", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Llvm"), profiles: None } })]"# ) ;
545545 insta:: assert_compact_debug_snapshot!( get_build_commands( r#"@rust-timer build 23936af287657fa4148aeab40cc2a780810fae5B backends=Cranelift"# ) ,
546- @r#"[Ok(BuildCommand { sha: "23936af287657fa4148aeab40cc2a780810fae5B", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Cranelift") } })]"# ) ;
546+ @r#"[Ok(BuildCommand { sha: "23936af287657fa4148aeab40cc2a780810fae5B", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Cranelift"), profiles: None } })]"# ) ;
547547 insta:: assert_compact_debug_snapshot!( get_build_commands( r#"@rust-timer build 23936af287657fa4148aeab40cc2a780810fae5C backends=Cranelift,Llvm"# ) ,
548- @r#"[Ok(BuildCommand { sha: "23936af287657fa4148aeab40cc2a780810fae5C", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Cranelift,Llvm") } })]"# ) ;
548+ @r#"[Ok(BuildCommand { sha: "23936af287657fa4148aeab40cc2a780810fae5C", params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Cranelift,Llvm"), profiles: None } })]"# ) ;
549549 insta:: assert_compact_debug_snapshot!( get_build_commands( r#"@rust-timer build 5832462aa1d9373b24ace96ad2c50b7a18af995D include=hello backends=Llvm"# ) ,
550- @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af995D", params: BenchmarkParameters { include: Some("hello"), exclude: None, runs: None, backends: Some("Llvm") } })]"# ) ;
550+ @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af995D", params: BenchmarkParameters { include: Some("hello"), exclude: None, runs: None, backends: Some("Llvm"), profiles: None } })]"# ) ;
551551 insta:: assert_compact_debug_snapshot!( get_build_commands( r#"@rust-timer build 5832462aa1d9373b24ace96ad2c50b7a18af995E runs=10 backends=Llvm"# ) ,
552- @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af995E", params: BenchmarkParameters { include: None, exclude: None, runs: Some(10), backends: Some("Llvm") } })]"# ) ;
552+ @r#"[Ok(BuildCommand { sha: "5832462aa1d9373b24ace96ad2c50b7a18af995E", params: BenchmarkParameters { include: None, exclude: None, runs: Some(10), backends: Some("Llvm"), profiles: None } })]"# ) ;
553553 }
554554
555555 #[ test]
556556 fn queue_command_with_backends ( ) {
557557 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue backends=Llvm" ) ,
558- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Llvm") } }))"# ) ;
558+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Llvm"), profiles: None } }))"# ) ;
559559 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue backends=Cranelift" ) ,
560- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Cranelift") } }))"# ) ;
560+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Cranelift"), profiles: None } }))"# ) ;
561561 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue backends=Cranelift,Llvm" ) ,
562- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Cranelift,Llvm") } }))"# ) ;
562+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Cranelift,Llvm"), profiles: None } }))"# ) ;
563563 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue" ) ,
564- @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None } }))" ) ;
564+ @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: None } }))" ) ;
565565 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue include=hello backends=Llvm" ) ,
566- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("hello"), exclude: None, runs: None, backends: Some("Llvm") } }))"# ) ;
566+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("hello"), exclude: None, runs: None, backends: Some("Llvm"), profiles: None } }))"# ) ;
567567 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue include=hello exclude=ripgrep runs=3 backends=Llvm" ) ,
568- @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("hello"), exclude: Some("ripgrep"), runs: Some(3), backends: Some("Llvm") } }))"# ) ;
568+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: Some("hello"), exclude: Some("ripgrep"), runs: Some(3), backends: Some("Llvm"), profiles: None } }))"# ) ;
569+ }
570+
571+ #[ test]
572+ fn queue_command_with_profiles ( ) {
573+ insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue profiles=Doc" ) ,
574+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: Some("Doc") } }))"# ) ;
575+ insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue profiles=Check,Clippy" ) ,
576+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: Some("Check,Clippy") } }))"# ) ;
577+ insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue profiles=Doc,Clippy,Opt backends=Cranelift,Llvm" ) ,
578+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: Some("Cranelift,Llvm"), profiles: Some("Doc,Clippy,Opt") } }))"# ) ;
579+ insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue profiles=Foo" ) ,
580+ @r#"Some(Err("Cannot parse profiles: Invalid profile: Foo. Valid values are: check, debug, opt, doc, doc-json, clippy"))"# ) ;
581+ insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue profiles=check" ) ,
582+ @r#"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: Some("check") } }))"# ) ;
569583 }
570584
571585 #[ test]
572586 fn no_empty_arguments_thank_you ( ) {
573587 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue include=" ) ,
574- @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None } }))" ) ;
588+ @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: None } }))" ) ;
575589 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue exclude=" ) ,
576- @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None } }))" ) ;
590+ @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: None } }))" ) ;
577591 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue runs=" ) ,
578- @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None } }))" ) ;
592+ @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: None } }))" ) ;
579593 insta:: assert_compact_debug_snapshot!( parse_queue_command( "@rust-timer queue backends=" ) ,
580- @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None } }))" ) ;
594+ @"Some(Ok(QueueCommand { params: BenchmarkParameters { include: None, exclude: None, runs: None, backends: None, profiles: None } }))" ) ;
581595 }
582596}
0 commit comments