From 9113d491e7f0975b33b75dfa1f0d7bfe65c124fa Mon Sep 17 00:00:00 2001 From: Erich Gubler Date: Thu, 30 May 2024 18:06:40 -0400 Subject: [PATCH] WIP: feat(update_backlog): add `--preset=promote-not-not-passing` TODO: Validate that this is useful. --- moz-webgpu-cts/src/main.rs | 17 +++++++++++++++++ moz-webgpu-cts/src/shared.rs | 4 ++++ 2 files changed, 21 insertions(+) diff --git a/moz-webgpu-cts/src/main.rs b/moz-webgpu-cts/src/main.rs index 3d10f10..5778e9c 100644 --- a/moz-webgpu-cts/src/main.rs +++ b/moz-webgpu-cts/src/main.rs @@ -144,6 +144,8 @@ enum OnZeroItem { enum UpdateBacklogPreset { /// Remove tests that expect only `PASS` outcomes on all platforms from `backlog`. PromotePermaPassing, + /// Remove tests that, at most, expect `PASS`, `TIMEOUT`, and `NOTRUN` outcomes from `backlog`. + PromoteNotNotPassing, } fn main() -> ExitCode { @@ -1450,6 +1452,7 @@ fn run(cli: Cli) -> ExitCode { enum Case { #[default] PermaPass, + NotNotPass, Other, } let mut found_write_err = false; @@ -1488,6 +1491,12 @@ fn run(cli: Cli) -> ExitCode { [(platform, build_profile)]; if let Some(SubtestOutcome::Pass) = expected.as_permanent() { Case::PermaPass + } else if expected.is_subset( + SubtestOutcome::Pass + | SubtestOutcome::Timeout + | SubtestOutcome::NotRun, + ) { + Case::NotNotPass } else { Case::Other } @@ -1508,6 +1517,14 @@ fn run(cli: Cli) -> ExitCode { properties.implementation_status = None; } } + UpdateBacklogPreset::PromoteNotNotPassing => { + if matches!( + value_across_all_platforms(), + Ok(Case::PermaPass | Case::NotNotPass) + ) { + properties.implementation_status = None; + } + } } } match write_to_file(file_path, metadata::format_file(file)) { diff --git a/moz-webgpu-cts/src/shared.rs b/moz-webgpu-cts/src/shared.rs index 4546a2e..d5dd633 100644 --- a/moz-webgpu-cts/src/shared.rs +++ b/moz-webgpu-cts/src/shared.rs @@ -97,6 +97,10 @@ where { self.inner().is_superset(rep.inner()) } + + pub fn is_subset(&self, rep: EnumSet) -> bool { + self.inner().is_subset(rep) + } } impl Display for Expected