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
|
export const description = `
Validation tests for setPipeline on render pass and render bundle.
`;
import { makeTestGroup } from '../../../../../../common/framework/test_group.js';
import { kRenderEncodeTypes } from '../../../../../util/command_buffer_maker.js';
import { ValidationTest } from '../../../validation_test.js';
import { kRenderEncodeTypeParams } from './render.js';
export const g = makeTestGroup(ValidationTest);
g.test('invalid_pipeline')
.desc(
`
Tests setPipeline should generate an error iff using an 'invalid' pipeline.
`
)
.paramsSubcasesOnly(u =>
u.combine('encoderType', kRenderEncodeTypes).combine('state', ['valid', 'invalid'] as const)
)
.fn(t => {
const { encoderType, state } = t.params;
const pipeline = t.createRenderPipelineWithState(state);
const { encoder, validateFinish } = t.createEncoder(encoderType);
encoder.setPipeline(pipeline);
validateFinish(state !== 'invalid');
});
g.test('pipeline,device_mismatch')
.desc('Tests setPipeline cannot be called with a render pipeline created from another device')
.paramsSubcasesOnly(kRenderEncodeTypeParams.combine('mismatched', [true, false]))
.beforeAllSubcases(t => {
t.selectMismatchedDeviceOrSkipTestCase(undefined);
})
.fn(async t => {
const { encoderType, mismatched } = t.params;
const sourceDevice = mismatched ? t.mismatchedDevice : t.device;
const pipeline = sourceDevice.createRenderPipeline({
layout: 'auto',
vertex: {
module: sourceDevice.createShaderModule({
code: `@vertex fn main() -> @builtin(position) vec4<f32> { return vec4<f32>(); }`,
}),
entryPoint: 'main',
},
fragment: {
module: sourceDevice.createShaderModule({
code: '@fragment fn main() {}',
}),
entryPoint: 'main',
targets: [{ format: 'rgba8unorm', writeMask: 0 }],
},
primitive: { topology: 'triangle-list' },
});
const { encoder, validateFinish } = t.createEncoder(encoderType);
encoder.setPipeline(pipeline);
validateFinish(!mismatched);
});
|