summaryrefslogtreecommitdiffstats
path: root/dom/canvas/test/webgl-mochitest/test_webgl_request_mismatch.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /dom/canvas/test/webgl-mochitest/test_webgl_request_mismatch.html
parentInitial commit. (diff)
downloadfirefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz
firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/canvas/test/webgl-mochitest/test_webgl_request_mismatch.html')
-rw-r--r--dom/canvas/test/webgl-mochitest/test_webgl_request_mismatch.html90
1 files changed, 90 insertions, 0 deletions
diff --git a/dom/canvas/test/webgl-mochitest/test_webgl_request_mismatch.html b/dom/canvas/test/webgl-mochitest/test_webgl_request_mismatch.html
new file mode 100644
index 0000000000..1dcab1c167
--- /dev/null
+++ b/dom/canvas/test/webgl-mochitest/test_webgl_request_mismatch.html
@@ -0,0 +1,90 @@
+<!DOCTYPE HTML>
+<html>
+<head>
+<script src="/tests/SimpleTest/SimpleTest.js"></script>
+<link rel="stylesheet" href="/tests/SimpleTest/test.css">
+</head>
+<body>
+<script>
+
+WEBGL_TYPES = {};
+WEBGL_TYPES['experimental-webgl'] = true;
+WEBGL_TYPES.webgl = true;
+
+function AreBothIn(a, b, set) {
+ return (a in set) && (b in set);
+}
+
+function IsAlias(typeA, typeB) {
+ if (typeA == typeB)
+ return true;
+
+ if (AreBothIn(typeA, typeB, WEBGL_TYPES))
+ return true;
+
+ return false;
+}
+
+function TestContextRetrieval(creationType, requestType, functionalTypeSet) {
+ var canvas = document.createElement('canvas');
+ var createdGL = canvas.getContext(creationType);
+
+ var didCreationSucceed = (createdGL != null);
+ if (creationType in functionalTypeSet) {
+ ok(createdGL, 'Context creation should succeed for type \'' +
+ creationType + '\'');
+ } else {
+ ok(!createdGL, 'Context creation should fail for type \'' +
+ creationType + '\'');
+ return;
+ }
+
+ var requestedGL = canvas.getContext(requestType);
+
+ if (requestType in functionalTypeSet &&
+ IsAlias(creationType, requestType))
+ {
+ ok(requestedGL, 'Request for \'' + requestType + '\' from \'' +
+ creationType + '\' should succeed.');
+ ok(requestedGL == createdGL, 'Request for \'' + requestType +
+ '\' from \'' + creationType +
+ '\' should match.');
+ } else {
+ ok(!requestedGL, 'Request for \'' + requestType + '\' from \'' +
+ creationType + '\' should fail.');
+ }
+}
+
+function IsWebGLFunctional() {
+ var canvas = document.createElement('canvas');
+ return canvas.getContext('experimental-webgl') != null;
+}
+
+function IsWebGLConformant() {
+ var canvas = document.createElement('canvas');
+ return canvas.getContext('webgl') != null;
+}
+
+var typeList = ['2d', 'experimental-webgl', 'webgl'];
+var functionalTypeSet = {};
+functionalTypeSet['2d'] = true;
+
+if (IsWebGLFunctional())
+ functionalTypeSet['experimental-webgl'] = true;
+
+if (IsWebGLConformant())
+ functionalTypeSet.webgl = true;
+
+for (var i in typeList) {
+ var creationType = typeList[i];
+
+ for (var j in typeList) {
+ var requestType = typeList[j];
+
+ TestContextRetrieval(creationType, requestType, functionalTypeSet);
+ }
+}
+
+</script>
+</body>
+</html>