From f018e9539b199aa4712b8a2a90035beaebe6d3ac Mon Sep 17 00:00:00 2001 From: Imbris Date: Sat, 29 Oct 2022 23:00:55 -0400 Subject: [PATCH] Rework buffer_usage test to properly check every failure case using error scopes (instead of accidentally just testing the first one). --- wgpu/tests/buffer_usages.rs | 76 ++++++++++++++++++++++--------------- wgpu/tests/common/mod.rs | 2 +- 2 files changed, 47 insertions(+), 31 deletions(-) diff --git a/wgpu/tests/buffer_usages.rs b/wgpu/tests/buffer_usages.rs index ebf679ca05..f0d98a2009 100644 --- a/wgpu/tests/buffer_usages.rs +++ b/wgpu/tests/buffer_usages.rs @@ -1,39 +1,49 @@ //! Tests for buffer usages validation. +use crate::common::{fail, initialize_test, valid, TestParameters}; use wgt::BufferAddress; -use crate::common::{initialize_test, TestParameters}; +const BUFFER_SIZE: BufferAddress = 1234; #[test] fn buffer_usage() { - fn try_create( - usages: &[wgpu::BufferUsages], - enable_mappable_primary_buffers: bool, - should_panic: bool, - ) { + fn try_create(enable_mappable_primary_buffers: bool, usages: &[(bool, &[wgpu::BufferUsages])]) { let mut parameters = TestParameters::default(); if enable_mappable_primary_buffers { parameters = parameters.features(wgpu::Features::MAPPABLE_PRIMARY_BUFFERS); } - if should_panic { - parameters = parameters.failure(); - } initialize_test(parameters, |ctx| { - for usage in usages.iter().copied() { - let _buffer = ctx.device.create_buffer(&wgpu::BufferDescriptor { - label: None, - size: BUFFER_SIZE, - usage, - mapped_at_creation: false, - }); + for (expect_validation_error, usage) in + usages + .iter() + .flat_map(|&(expect_validation_error, usages)| { + usages + .iter() + .copied() + .map(move |u| (expect_validation_error, u)) + }) + { + let create_buffer = || { + let _buffer = ctx.device.create_buffer(&wgpu::BufferDescriptor { + label: None, + size: BUFFER_SIZE, + usage, + mapped_at_creation: false, + }); + }; + if expect_validation_error { + fail(&ctx.device, create_buffer); + } else { + valid(&ctx.device, create_buffer); + } } }); } use wgpu::BufferUsages as Bu; - let always_valid = [ + let always_valid = &[ Bu::MAP_READ, Bu::MAP_WRITE, Bu::MAP_READ | Bu::COPY_DST, @@ -41,25 +51,31 @@ fn buffer_usage() { ]; // MAP_READ can only be paired with COPY_DST and MAP_WRITE can only be paired with COPY_SRC // (unless Features::MAPPABlE_PRIMARY_BUFFERS is enabled). - let needs_mappable_primary_buffers = [ + let needs_mappable_primary_buffers = &[ Bu::MAP_READ | Bu::COPY_DST | Bu::COPY_SRC, Bu::MAP_WRITE | Bu::COPY_SRC | Bu::COPY_DST, Bu::MAP_READ | Bu::MAP_WRITE, Bu::MAP_WRITE | Bu::MAP_READ, Bu::MAP_READ | Bu::COPY_DST | Bu::STORAGE, Bu::MAP_WRITE | Bu::COPY_SRC | Bu::STORAGE, - wgpu::BufferUsages::all(), + Bu::all(), ]; - let always_fail = [Bu::empty()]; - - try_create(&always_valid, false, false); - try_create(&always_valid, true, false); + let always_fail = &[Bu::empty()]; - try_create(&needs_mappable_primary_buffers, false, true); - try_create(&needs_mappable_primary_buffers, true, false); - - try_create(&always_fail, false, true); - try_create(&always_fail, true, true); + try_create( + false, + &[ + (false, always_valid), + (true, needs_mappable_primary_buffers), + (true, always_fail), + ], + ); + try_create( + true, + &[ + (false, always_valid), + (false, needs_mappable_primary_buffers), + (true, always_fail), + ], + ); } - -const BUFFER_SIZE: BufferAddress = 1234; diff --git a/wgpu/tests/common/mod.rs b/wgpu/tests/common/mod.rs index 3a87e41c60..de94b61937 100644 --- a/wgpu/tests/common/mod.rs +++ b/wgpu/tests/common/mod.rs @@ -177,7 +177,7 @@ pub fn initialize_test(parameters: TestParameters, test_function: impl FnOnce(Te backend_bits, None, )) - .expect("could not find sutable adapter on the system"); + .expect("could not find suitable adapter on the system"); let adapter_info = adapter.get_info(); let adapter_lowercase_name = adapter_info.name.to_lowercase();