blob: 76ef530f81ce1b63887789845ebdc71f5208edda [file] [log] [blame]
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -07001export const description = `
2Examples of writing CTS tests with various features.
Kai Ninomiyacb13fba2019-10-24 16:59:36 -07003
4Start here when looking for examples of basic framework usage.
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -07005`;
6
Kai Ninomiya20bc11b2020-03-31 14:45:44 -07007import { TestGroup } from '../common/framework/index.js';
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -07008
9import { GPUTest } from './gpu_test.js';
10
11// To run these tests in the standalone runner, run `grunt build` or `grunt pre` then open:
Kai Ninomiya20bc11b2020-03-31 14:45:44 -070012// - http://localhost:8080/?runnow=1&q=webgpu:examples:
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070013// To run in WPT, copy/symlink the out-wpt/ directory as the webgpu/ directory in WPT, then open:
Kai Ninomiya20bc11b2020-03-31 14:45:44 -070014// - (wpt server url)/webgpu/cts.html?q=webgpu:examples:
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070015//
16// Tests here can be run individually or in groups:
Kai Ninomiya20bc11b2020-03-31 14:45:44 -070017// - ?q=webgpu:examples:basic/async=
18// - ?q=webgpu:examples:basic/
19// - ?q=webgpu:examples:
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070020
21export const g = new TestGroup(GPUTest);
22
Kai Ninomiya20bc11b2020-03-31 14:45:44 -070023// Note: spaces in test names are replaced with underscores: webgpu:examples:test_name=
Kai Ninomiya04ec6b62019-10-25 00:35:32 -070024g.test('test name', t => {});
25
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070026g.test('basic', t => {
27 t.expect(true);
28 t.expect(true, 'true should be true');
29
30 t.shouldThrow(
Kai Ninomiyabb2e71f2019-08-02 16:25:56 -070031 // The expected '.name' of the thrown error.
32 'TypeError',
33 // This function is run inline inside shouldThrow, and is expected to throw.
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070034 () => {
Kai Ninomiyabb2e71f2019-08-02 16:25:56 -070035 throw new TypeError();
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070036 },
Kai Ninomiyabb2e71f2019-08-02 16:25:56 -070037 // Log message.
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070038 'function should throw Error'
39 );
40});
41
42g.test('basic/async', async t => {
43 // shouldReject must be awaited to ensure it can wait for the promise before the test ends.
Kai Ninomiyac42e2982019-10-23 15:44:28 -070044 t.shouldReject(
Kai Ninomiyabb2e71f2019-08-02 16:25:56 -070045 // The expected '.name' of the thrown error.
46 'TypeError',
47 // Promise expected to reject.
48 Promise.reject(new TypeError()),
49 // Log message.
50 'Promise.reject should reject'
51 );
52
53 // Promise can also be an IIFE.
Kai Ninomiyac42e2982019-10-23 15:44:28 -070054 t.shouldReject(
Kai Ninomiyabb2e71f2019-08-02 16:25:56 -070055 'TypeError',
56 (async () => {
57 throw new TypeError();
58 })(),
59 'Promise.reject should reject'
60 );
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070061});
62
Kai Ninomiya13820262019-10-17 15:30:56 -070063// A test can be parameterized with a simple array of objects.
64//
65// Parameters can be public (x, y) which means they're part of the case name.
66// They can also be private by starting with an underscore (_result), which passes
67// them into the test but does not make them part of the case name:
68//
Kai Ninomiya20bc11b2020-03-31 14:45:44 -070069// - webgpu:examples:basic/params={"x":2,"y":4} runs with t.params = {x: 2, y: 5, _result: 6}.
70// - webgpu:examples:basic/params={"x":-10,"y":18} runs with t.params = {x: -10, y: 18, _result: 8}.
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070071g.test('basic/params', t => {
Kai Ninomiya13820262019-10-17 15:30:56 -070072 t.expect(t.params.x + t.params.y === t.params._result);
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070073}).params([
Kai Ninomiya13820262019-10-17 15:30:56 -070074 { x: 2, y: 4, _result: 6 }, //
75 { x: -10, y: 18, _result: 8 },
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070076]);
Kai Ninomiya13820262019-10-17 15:30:56 -070077// (note the blank comment above to enforce newlines on autoformat)
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070078
79g.test('gpu/async', async t => {
80 const fence = t.queue.createFence();
81 t.queue.signal(fence, 2);
82 await fence.onCompletion(1);
83 t.expect(fence.getCompletedValue() === 2);
84});
85
86g.test('gpu/buffers', async t => {
87 const data = new Uint32Array([0, 1234, 0]);
88 const [src, map] = t.device.createBufferMapped({
89 size: 12,
90 usage: GPUBufferUsage.COPY_SRC | GPUBufferUsage.COPY_DST,
91 });
92 new Uint32Array(map).set(data);
93 src.unmap();
94
95 // Use the expectContents helper to check the actual contents of a GPUBuffer.
96 // Like shouldReject, it must be awaited.
Kai Ninomiyac42e2982019-10-23 15:44:28 -070097 t.expectContents(src, data);
Kai Ninomiya8e4e5dd2019-08-02 14:00:30 -070098});