diff options
Diffstat (limited to 'dom/webgpu/tests/cts/checkout/standalone/index.html')
-rw-r--r-- | dom/webgpu/tests/cts/checkout/standalone/index.html | 423 |
1 files changed, 423 insertions, 0 deletions
diff --git a/dom/webgpu/tests/cts/checkout/standalone/index.html b/dom/webgpu/tests/cts/checkout/standalone/index.html new file mode 100644 index 0000000000..834a0e2179 --- /dev/null +++ b/dom/webgpu/tests/cts/checkout/standalone/index.html @@ -0,0 +1,423 @@ +<html> + <head> + <meta charset="UTF-8"> + <title>WebGPU CTS</title> + <link + id="favicon" + rel="shortcut icon" + type="image/png" + href="" + /> + <link rel="preconnect" href="https://fonts.googleapis.com"> + <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin> + <link href="https://fonts.googleapis.com/css2?family=Poppins&display=swap" rel="stylesheet"> + <meta name="viewport" content="width=device-width" /> + <!-- Chrome Origin Trial token for https://gpuweb.github.io (see dev_server.ts for localhost tokens) --> + <meta http-equiv="origin-trial" content="AmV1vLgjOQ01SlGnVhpoKXy7gLW+K/plXHwHKnYn4S4US98WaSesKBI+XSUMo95unQARyMGDvW70KsfyeYblZQ0AAABQeyJvcmlnaW4iOiJodHRwczovL2dwdXdlYi5naXRodWIuaW86NDQzIiwiZmVhdHVyZSI6IldlYkdQVSIsImV4cGlyeSI6MTY2MzcxODM5OX0="> + <link rel="stylesheet" href="third_party/normalize.min.css" /> + <script src="third_party/jquery/jquery-3.3.1.min.js"></script> + <style> + :root { + color-scheme: light dark; + + --fg-color: #000; + --bg-color: #fff; + --border-color: #888; + --emphasis-fg-color: #F00; + + --results-fg-color: gray; + --node-description-fg-color: #gray; + --node-hover-bg-color: rgba(0, 0, 0, 0.1); + + --testcaselogbtn-bg-color: #eee; + --subtree-border-color: #ddd; + --subtree-hover-left-border-color: #000; + --multicase-border-color: #55f; + --testcase-border-color: #bbf; + --testcase-bg-color: #bbb; + + --testcase-data-status-fail-bg-color: #fdd; + --testcase-data-status-warn-bg-color: #ffb; + --testcase-data-status-pass-bg-color: #cfc; + --testcase-data-status-skip-bg-color: #eee; + + --testcase-logs-bg-color: #white; + --testcase-log-odd-bg-color: #fff; + --testcase-log-even-bg-color: #f8f8f8; + --testcase-log-text-fg-color: #666; + --testcase-log-text-first-line-fg-color: #000; + --button-image-filter: none; + } + @media (prefers-color-scheme: dark) { + :root { + --fg-color: #fff; + --bg-color: #000; + --border-color: #888; + --emphasis-fg-color: #F44; + + --results-fg-color: #aaa; + --node-description-fg-color: #aaa; + --node-hover-bg-color: rgba(255, 255, 255, 0.1); + + --testcaselogbtn-bg-color: #666; + --subtree-border-color: #444; + --subtree-hover-left-border-color: #FFF; + --multicase-border-color: #338; + --testcase-border-color: #55a; + --testcase-bg-color: #888; + + --testcase-data-status-fail-bg-color: #400; + --testcase-data-status-warn-bg-color: #660; + --testcase-data-status-pass-bg-color: #040; + --testcase-data-status-skip-bg-color: #444; + + --testcase-logs-bg-color: #black; + --testcase-log-odd-bg-color: #000; + --testcase-log-even-bg-color: #080808; + --testcase-log-text-fg-color: #aaa; + --testcase-log-text-first-line-fg-color: #fff; + --button-image-filter: invert(100%); + } + } + body { + font-family: monospace; + min-width: 400px; + margin: 0.5em; + } + * { + box-sizing: border-box; + } + h1 { + font-size: 1.5em; + font-family: 'Poppins', sans-serif; + height: 1.2em; + vertical-align: middle; + } + input[type=button], + button { + cursor: pointer; + } + .logo { + height: 1.2em; + float: left; + } + .important { + font-weight: bold; + color: var(--emphasis-fg-color); + } + #options label { + display: flex; + } + table#options { + border-collapse: collapse; + width: 100%; + } + #options td { + border: 1px solid var(--subtree-border-color); + width: 1px; /* to make the columns as small as possible */ + } + #options tr:hover { + background: var(--node-hover-bg-color); + } + #options td:nth-child(1) { + text-align: right; + } + #options td:nth-child(2), + #options td:nth-child(3) { + padding-left: 0.5em; + } + #options td:nth-child(3) { + width: 100%; /* to make the last column use the space */ + } + #info { + font-family: monospace; + } + #progress { + position: fixed; + display: flex; + width: 100%; + left: 0; + top: 0; + background-color: #000; + color: #fff; + align-items: center; + } + #progress .progress-test-name { + flex: 1 1; + min-width: 0; + overflow: hidden; + text-overflow: ellipsis; + direction: rtl; + white-space: nowrap; + } + #resultsJSON { + font-family: monospace; + width: 100%; + height: 15em; + } + + #resultsVis { + border-right: 1px solid var(--results-fg-color); + } + + /* tree nodes */ + + .nodeheader { + display: flex; + width: 100%; + padding: 0px 2px 0px 1px; + } + .nodeheader:hover { + background: var(--node-hover-bg-color); + } + .subtreerun, + .leafrun, + .nodelink, + .collapsebtn, + .testcaselogbtn { + display: inline-flex; + flex-shrink: 0; + flex-grow: 0; + justify-content: center; + align-items: center; + text-decoration: none; + vertical-align: top; + color: var(--fg-color); + background-color: var(--testcaselogbtn-bg-color); + background-repeat: no-repeat; + background-position: center; + border: 1px solid var(--border-color); + } + .subtreerun::before, + .leafrun::before, + .nodelink::before, + .collapsebtn::before, + .testcaselogbtn::before { + content: ""; + width: 100%; + height: 100%; + background-repeat: no-repeat; + background-position: center; + filter: var(--button-image-filter); + } + @media (pointer: fine) { + .subtreerun, + .leafrun, + .nodelink, + .collapsebtn, + .testcaselogbtn { + flex-basis: 24px; + border-radius: 4px; + width: 24px; + height: 18px; + } + } + @media (pointer: coarse) { + .subtreerun, + .leafrun, + .nodelink, + .collapsebtn, + .testcaselogbtn { + flex-basis: 36px; + border-radius: 6px; + width: 36px; + height: 36px; + } + } + .subtreerun::before { + background-image: url(); + } + .leafrun::before { + background-image: url(); + } + .nodelink::before { + background-image: url(); + } + .nodetitle { + display: inline; + flex: 10 0 4em; + } + .nodecolumns { + position: absolute; + left: 220px; + } + .nodequery { + font-weight: bold; + background: transparent; + border: none; + padding: 2px; + margin: 0 0.5em; + width: calc(100vw - 360px); + } + .nodedescription { + margin: 0 0 0 1em; + color: var(--node-description-fg-color); + white-space: pre-wrap; + font-size: 80%; + } + + /* tree nodes which are subtrees */ + + .subtree { + margin: 3px 0 0 0; + padding: 3px 0 0 3px; + border-width: 1px 0 0; + border-style: solid; + border-color: var(--subtree-border-color); + } + .subtree::before { + float: right; + margin-right: 3px; + } + .subtree[data-status='fail'], .subtree[data-status='passfail'] { + background: linear-gradient(90deg, var(--testcase-data-status-fail-bg-color), var(--testcase-data-status-fail-bg-color) 16px, var(--bg-color) 16px); + } + .subtree[data-status='fail']::before { + content: "⛔" + } + .subtree[data-status='pass'] { + background: linear-gradient(90deg, var(--testcase-data-status-pass-bg-color), var(--testcase-data-status-pass-bg-color) 16px, var(--bg-color) 16px); + } + .subtree[data-status='pass']::before { + content: "✔" + } + .subtree[data-status='passfail']::before { + content: "✔/⛔" + } + .subtree:hover { + border-left-color: var(--subtree-hover-left-border-color); + } + .subtree.multifile > .subtreechildren > .subtree.multitest, + .subtree.multifile > .subtreechildren > .subtree.multicase { + border-width: 2px 0 0 1px; + border-color: var(--multicase-border-color); + } + .subtree.multitest > .subtreechildren > .subtree.multicase, + .subtree.multitest > .subtreechildren > .testcase { + border-width: 2px 0 0 1px; + border-color: var(--testcase-border-color); + } + .subtreechildren { + margin-left: 9px; + } + + /* tree nodes which are test cases */ + + .testcase { + padding: 3px; + border-width: 1px 0 0 0; + border-style: solid; + border-color: var(--border-color); + background: var(--testcase-bg-color); + } + .testcase:first-child { + margin-top: 3px; + } + .testcase::after { + float: right; + margin-top: -1.1em; + } + .testcase[data-status='fail'] { + background: var(--testcase-data-status-fail-bg-color); + } + .testcase[data-status='fail']::after { + content: "⛔" + } + .testcase[data-status='warn'] { + background: var(--testcase-data-status-warn-bg-color); + } + .testcase[data-status='warn']::after { + content: "⚠" + } + .testcase[data-status='pass'] { + background: var(--testcase-data-status-pass-bg-color); + } + .testcase[data-status='pass']::after { + content: "✔" + } + .testcase[data-status='skip'] { + background: var(--testcase-data-status-skip-bg-color); + } + .testcase .nodequery { + font-weight: normal; + width: calc(100vw - 275px); + } + .testcasetime { + white-space: nowrap; + text-align: right; + flex: 1 0 5.5em; + } + .testcaselogs { + margin-left: 6px; + width: calc(100% - 6px); + border-width: 0 0px 0 1px; + border-style: solid; + border-color: var(--border-color); + background: var(--testcase-logs-bg-color); + } + .testcaselog { + display: flex; + } + .testcaselog:nth-child(odd) { + background: var(--testcase-log-odd-bg-color); + } + .testcaselog:nth-child(even) { + background: var(--testcase-log-even-bg-color); + } + .testcaselogbtn::before { + background-image: url(); + } + .testcaselogtext { + flex: 1 0; + font-size: 10pt; + white-space: pre-wrap; + word-break: break-word; + margin: 0; + color: var(--testcase-log-text-fg-color) + } + .testcaselogtext::first-line { + color: var(--testcase-log-text-first-line-fg-color); + } + + @media only screen and (max-width: 600px) { + .subtreechildren { + margin-left: 2px; + } + .testcaselogs { + margin-left: 2px; + width: calc(100% - 2px); + } + .nodequery { + position: relative; + left: 0; + width: 100%; + } + } + </style> + </head> + <body> + <h1><img class="logo" src="webgpu-logo-notext.svg">WebGPU Conformance Test Suite</h1> + <details> + <summary>options (requires reload!)</summary> + <table id="options"> + <tbody></tbody> + </table> + <p class="important">Note: The options above only set the url parameters. + You must reload the page for the options to take affect.</p> + </details> + <p> + <input type=button id=expandall value="Expand All (slow!)"> + <label><input type=checkbox id=autoCloseOnPass> Auto-close each subtree when it passes</label> + </p> + + <div id="info"></div> + <div id="resultsVis"></div> + <div id="progress" style="display: none;"><button type="button">stop</button><div class="progress-test-name"></div></div> + + <p> + <input type="button" id="copyResultsJSON" value="Copy results as JSON"> + </p> + + <script type="module" src="../out/common/runtime/standalone.js"></script> + </body> +</html> |