summaryrefslogtreecommitdiffstats
path: root/dom/webgpu/tests/cts/checkout/standalone/index.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
commit6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch)
treea68f146d7fa01f0134297619fbe7e33db084e0aa /dom/webgpu/tests/cts/checkout/standalone/index.html
parentInitial commit. (diff)
downloadthunderbird-upstream/1%115.7.0.tar.xz
thunderbird-upstream/1%115.7.0.zip
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/webgpu/tests/cts/checkout/standalone/index.html')
-rw-r--r--dom/webgpu/tests/cts/checkout/standalone/index.html423
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>