1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
export const description = `
This test dedicatedly tests createRenderPipeline validation issues related to the shader modules.
Note: entry point matching tests are in ../shader_module/entry_point.spec.ts
`;
import { makeTestGroup } from '../../../../common/framework/test_group.js';
import {
getFragmentShaderCodeWithOutput,
kDefaultVertexShaderCode,
kDefaultFragmentShaderCode,
} from '../../../util/shader.js';
import { CreateRenderPipelineValidationTest } from './common.js';
export const g = makeTestGroup(CreateRenderPipelineValidationTest);
const values = [0, 1, 0, 1];
g.test('device_mismatch')
.desc(
'Tests createRenderPipeline(Async) cannot be called with a shader module created from another device'
)
.paramsSubcasesOnly(u =>
u.combine('isAsync', [true, false]).combineWithParams([
{ vertex_mismatched: false, fragment_mismatched: false, _success: true },
{ vertex_mismatched: true, fragment_mismatched: false, _success: false },
{ vertex_mismatched: false, fragment_mismatched: true, _success: false },
])
)
.beforeAllSubcases(t => {
t.selectMismatchedDeviceOrSkipTestCase(undefined);
})
.fn(async t => {
const { isAsync, vertex_mismatched, fragment_mismatched, _success } = t.params;
const code = `
@vertex fn main() -> @builtin(position) vec4<f32> {
return vec4<f32>(0.0, 0.0, 0.0, 1.0);
}
`;
const descriptor = {
vertex: {
module: vertex_mismatched
? t.mismatchedDevice.createShaderModule({ code })
: t.device.createShaderModule({ code }),
entryPoint: 'main',
},
fragment: {
module: fragment_mismatched
? t.mismatchedDevice.createShaderModule({
code: getFragmentShaderCodeWithOutput([
{ values, plainType: 'f32', componentCount: 4 },
]),
})
: t.device.createShaderModule({
code: getFragmentShaderCodeWithOutput([
{ values, plainType: 'f32', componentCount: 4 },
]),
}),
entryPoint: 'main',
targets: [{ format: 'rgba8unorm' }] as const,
},
layout: t.getPipelineLayout(),
};
t.doCreateRenderPipelineTest(isAsync, _success, descriptor);
});
g.test('invalid,vertex')
.desc(`Tests shader module must be valid.`)
.params(u => u.combine('isAsync', [true, false]).combine('isVertexShaderValid', [true, false]))
.fn(async t => {
const { isAsync, isVertexShaderValid } = t.params;
t.doCreateRenderPipelineTest(isAsync, isVertexShaderValid, {
layout: 'auto',
vertex: {
module: isVertexShaderValid
? t.device.createShaderModule({
code: kDefaultVertexShaderCode,
})
: t.createInvalidShaderModule(),
entryPoint: 'main',
},
});
});
g.test('invalid,fragment')
.desc(`Tests shader module must be valid.`)
.params(u => u.combine('isAsync', [true, false]).combine('isFragmentShaderValid', [true, false]))
.fn(async t => {
const { isAsync, isFragmentShaderValid } = t.params;
t.doCreateRenderPipelineTest(isAsync, isFragmentShaderValid, {
layout: 'auto',
vertex: {
module: t.device.createShaderModule({
code: kDefaultVertexShaderCode,
}),
entryPoint: 'main',
},
fragment: {
module: isFragmentShaderValid
? t.device.createShaderModule({
code: kDefaultFragmentShaderCode,
})
: t.createInvalidShaderModule(),
entryPoint: 'main',
targets: [{ format: 'rgba8unorm' }],
},
});
});
|