From e5e7ee1d2103cd2fd592c805f42a7036df731fed Mon Sep 17 00:00:00 2001 From: jzm-intel Date: Fri, 20 Oct 2023 15:22:21 +0800 Subject: [PATCH] wgsl: Implement validation test for parsing f16 literal (#3059) This PR add missing validation test for parsing f16 literal. Issue: #1192 --- src/webgpu/shader/validation/parse/literal.spec.ts | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/src/webgpu/shader/validation/parse/literal.spec.ts b/src/webgpu/shader/validation/parse/literal.spec.ts index 25aaf71fddc8..576d646a7b09 100644 --- a/src/webgpu/shader/validation/parse/literal.spec.ts +++ b/src/webgpu/shader/validation/parse/literal.spec.ts @@ -287,10 +287,16 @@ const kAbstractFloat = new Set([ .desc( ` Test that valid half floats are accepted, and invalid half floats are rejected - -TODO: Need to inject the 'enable fp16' into the shader to enable the parsing. ` ) .params(u => u.combine('val', new Set([...kValidF16, ...kInvalidF16])).beginSubcases()) - .unimplemented(); + .beforeAllSubcases(t => { + t.selectDeviceOrSkipTestCase('shader-f16'); + }) + .fn(t => { + const { val } = t.params; + const code = `var test: f16 = ${val};`; + const extensionList = ['f16']; + t.expectCompileResult(kValidF16.has(val), t.wrapInEntryPoint(code, extensionList)); + }); }