blob: b4e7adf5a7b9f73c89fe0257aaa8210102d10b19 [file]
<!-- webkit-test-runner [ enableMetalDebugDevice=true ] -->
<script>
globalThis.testRunner?.waitUntilDone();
const log = globalThis.$vm?.print ?? console.log;
const format = 'bgra8unorm';
onload = async () => {
let adapter = await navigator.gpu.requestAdapter({});
let device = await adapter.requestDevice({});
device.pushErrorScope('validation');
let module = device.createShaderModule({
code: `
@vertex
fn v(@location(0) fromVertexBuffer: f32) -> @builtin(position) vec4f {
return vec4(fromVertexBuffer);
}
@fragment
fn f() -> @location(0) vec4f {
return vec4();
}
`,
});
let pipeline = device.createRenderPipeline({
layout: device.createPipelineLayout({bindGroupLayouts: []}),
vertex: {
module,
buffers: [{
arrayStride: 8,
attributes: [{format: 'float32', offset: 0, shaderLocation: 0}],
}],
},
fragment: {module, targets: [{format}]},
primitive: {topology: 'point-list'},
});
let texture = device.createTexture({format, size: [1, 1, 1], usage: GPUTextureUsage.RENDER_ATTACHMENT});
let renderPassDescriptor = {
colorAttachments: [
{
view: texture.createView(),
clearValue: [0, 0, 0, 0],
loadOp: 'clear',
storeOp: 'store',
},
],
};
let commandEncoder = device.createCommandEncoder();
let renderPassEncoder = commandEncoder.beginRenderPass(renderPassDescriptor);
renderPassEncoder.setPipeline(pipeline);
let vertexBuffer = device.createBuffer({size: 4, usage: GPUBufferUsage.VERTEX});
renderPassEncoder.setVertexBuffer(0, vertexBuffer);
renderPassEncoder.draw(1);
renderPassEncoder.end();
device.queue.submit([commandEncoder.finish()]);
await device.queue.onSubmittedWorkDone();
let error = await device.popErrorScope();
if (error) {
log(error.message);
} else {
log('no validation error');
}
globalThis.testRunner?.notifyDone();
};
</script>