Bug 981936 - Fix hardcoded paths in WebGL conformance tests. - r=kamidphish
authorJeff Gilbert <jgilbert@mozilla.com>
Mon, 17 Mar 2014 16:05:03 -0700
changeset 173977 14f78cd007ac6b5f123822b0490f7e65bab64aca
parent 173976 ffe8bcfac12e925637cb325eaf01fcb2fb8b312f
child 173978 e158b74486220dcf525cdfcb89528473a59d0b00
push id26438
push userphilringnalda@gmail.com
push dateTue, 18 Mar 2014 05:39:07 +0000
treeherderautoland@89275f0ae29f [default view] [failures only]
perfherder[talos] [build metrics] [platform microbench] (compared to previous push)
reviewerskamidphish
bugs981936
milestone31.0a1
first release with
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
last release without
nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
Bug 981936 - Fix hardcoded paths in WebGL conformance tests. - r=kamidphish
content/canvas/test/webgl-conformance/conformance/more/functions/readPixelsBadArgs.html
content/canvas/test/webgl-conformance/conformance/more/functions/texImage2DHTML.html
content/canvas/test/webgl-conformance/conformance/more/functions/texSubImage2DHTML.html
content/canvas/test/webgl-conformance/conformance/textures/origin-clean-conformance.html
content/canvas/test/webgl-conformance/mochitest-conformance-files.ini
content/canvas/test/webgl-conformance/resources/cors-util.js
content/canvas/test/webgl-conformance/resources/js-test-pre.js
--- a/content/canvas/test/webgl-conformance/conformance/more/functions/readPixelsBadArgs.html
+++ b/content/canvas/test/webgl-conformance/conformance/more/functions/readPixelsBadArgs.html
@@ -26,16 +26,17 @@ HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES
 WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 OTHER DEALINGS IN THE SOFTWARE.
 
 -->
 <link rel="stylesheet" type="text/css" href="../unit.css" />
 <script type="application/x-javascript" src="../unit.js"></script>
 <script type="application/x-javascript" src="../util.js"></script>
+<script src="../../../resources/cors-util.js"></script>
 <script type="application/x-javascript">
 
 Tests.startUnit = function () {
   var canvas = document.getElementById('gl');
   var gl = wrapGLContext(canvas.getContext(GL_CONTEXT_ID));
   return [gl];
 }
 
@@ -110,10 +111,15 @@ Tests.testReadPixelsSOPCanvas = function
 
 Tests.endUnit = function(gl) {
 }
 
 </script>
 </head><body>
 <canvas id="gl" width="16" height="16"></canvas>
 <canvas id="c" width="128" height="128"></canvas>
-<img id="i" src="http://example.com/tests/content/canvas/test/webgl/resources/opengl_logo.jpg">
+<img id="i">
+<script>
+var imagePath = 'resources/opengl_logo.jpg';
+var relPathToBase = '../../../';
+setExampleDotComImage('i', imagePath, relPathToBase);
+</script>
 </body></html>
--- a/content/canvas/test/webgl-conformance/conformance/more/functions/texImage2DHTML.html
+++ b/content/canvas/test/webgl-conformance/conformance/more/functions/texImage2DHTML.html
@@ -26,16 +26,17 @@ HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES
 WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 OTHER DEALINGS IN THE SOFTWARE.
 
 -->
 <link rel="stylesheet" type="text/css" href="../unit.css" />
 <script type="application/x-javascript" src="../unit.js"></script>
 <script type="application/x-javascript" src="../util.js"></script>
+<script src="../../../resources/cors-util.js"></script>
 <script type="application/x-javascript">
 
 Tests.startUnit = function () {
     var canvas = document.getElementById('gl');
     var gl = wrapGLContext(canvas.getContext(GL_CONTEXT_ID));
     gl.viewport(0,0,canvas.width,canvas.height);
     gl.clearColor(0,0,1,1);
     gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);
@@ -142,11 +143,15 @@ void main()
     vec4 c = texture2D(Texture, texCoord0.st);
     gl_FragColor = c;
 }
 </script>
 </head><body>
 <canvas id="gl" width="256" height="256"></canvas>
 <canvas id="c" width="256" height="256"></canvas>
 <img id="i" width="256" height="256"  src="">
-<img id="i2" src="http://example.com/tests/content/canvas/test/webgl/resources/thunderbird-logo-64x64.png">
-
+<img id="i2">
+<script>
+var imagePath = 'resources/thunderbird-logo-64x64.png';
+var relPathToBase = '../../../';
+setExampleDotComImage('i2', imagePath, relPathToBase);
+</script>
 </body></html>
--- a/content/canvas/test/webgl-conformance/conformance/more/functions/texSubImage2DHTML.html
+++ b/content/canvas/test/webgl-conformance/conformance/more/functions/texSubImage2DHTML.html
@@ -26,16 +26,17 @@ HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES
 WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 OTHER DEALINGS IN THE SOFTWARE.
 
 -->
 <link rel="stylesheet" type="text/css" href="../unit.css" />
 <script type="application/x-javascript" src="../unit.js"></script>
 <script type="application/x-javascript" src="../util.js"></script>
+<script src="../../../resources/cors-util.js"></script>
 <script type="application/x-javascript">
 
 Tests.startUnit = function () {
     var canvas = document.getElementById('gl');
     var gl = wrapGLContext(canvas.getContext(GL_CONTEXT_ID));
     gl.viewport(0,0,canvas.width,canvas.height);
     gl.clearColor(0,0,1,1);
     gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);
@@ -154,11 +155,15 @@ void main()
     vec4 c = texture2D(Texture, texCoord0.st);
     gl_FragColor = c;
 }
 </script>
 </head><body>
 <canvas id="gl" width="256" height="256"></canvas>
 <canvas id="c" width="256" height="256"></canvas>
 <img id="i" width="256" height="256"  src="">
-<img id="i2" src="http://example.com/tests/content/canvas/test/webgl/resources/thunderbird-logo-64x64.png">
-
+<img id="i2">
+<script>
+var imagePath = 'resources/thunderbird-logo-64x64.png';
+var relPathToBase = '../../../';
+setExampleDotComImage('i2', imagePath, relPathToBase);
+</script>
 </body></html>
--- a/content/canvas/test/webgl-conformance/conformance/textures/origin-clean-conformance.html
+++ b/content/canvas/test/webgl-conformance/conformance/textures/origin-clean-conformance.html
@@ -6,16 +6,17 @@ found in the LICENSE file.
 <!DOCTYPE html>
 <html>
 <head>
 <meta charset="utf-8">
 <title>WebGL Origin Restrictions Conformance Tests</title>
 <link rel="stylesheet" href="../../resources/js-test-style.css"/>
 <script src="../../resources/desktop-gl-constants.js" type="text/javascript"></script>
 <script src="../../resources/js-test-pre.js"></script>
+<script src="../../resources/cors-util.js"></script>
 <script src="../resources/webgl-test.js"></script>
 <script>
 // This function returns the last 2 words of the domain of a URL
 // This is probably not the correct check but it will do for now.
 function getBaseDomain(str) {
   str = str.replace("\\", "/");
   var pos = str.indexOf("://");
   if (pos >= 0) {
@@ -32,20 +33,22 @@ function causedException(func) {
   try {
     func();
   } catch(e) {
     hadException = true;
   }
   return hadException;
 }
 
-window.onload = function() {
+function onImageLoad() {
   description("This test ensures WebGL implementations follow proper same-origin restrictions.");
   var img = document.getElementById("img");
-  assertMsg(img.width > 0 && img.height > 0, "img was loaded");
+  assertMsg(img.width > 0 && img.height > 0,
+            "Image should have loaded properly: " + img.src);
+
   imgDomain = getBaseDomain(img.src);
   pageDomain = getBaseDomain(window.location.toString());
   assertMsg(imgDomain != pageDomain,
             "img domain (" + imgDomain + ") and page domain (" + pageDomain + ") are not the same.");
 
   function makeTexImage2D(gl, src) {
     return function() {
       gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, src);
@@ -118,11 +121,16 @@ window.onload = function() {
 }
 </script>
 </head>
 <body>
 <div id="description"></div>
 <div id="console"></div>
 <canvas id="canvas1"></canvas>
 <canvas id="canvas2"></canvas>
-<img id="img" src="http://example.com/tests/content/canvas/test/webgl/resources/opengl_logo.jpg" style="display:none;">
+<img id="img" style="display:none;">
+<script>
+var imagePath = 'resources/opengl_logo.jpg';
+var relPathToBase = '../../';
+setExampleDotComImage('img', imagePath, relPathToBase, onImageLoad);
+</script>
 </body>
 </html>
--- a/content/canvas/test/webgl-conformance/mochitest-conformance-files.ini
+++ b/content/canvas/test/webgl-conformance/mochitest-conformance-files.ini
@@ -460,15 +460,16 @@ support-files =
   conformance/uniforms/00_test_list.txt
   conformance/uniforms/gl-uniform-arrays.html
   conformance/uniforms/gl-uniform-bool.html
   conformance/uniforms/gl-uniformmatrix4fv.html
   conformance/uniforms/gl-unknown-uniform.html
   conformance/uniforms/null-uniform-location.html
   conformance/uniforms/uniform-location.html
   conformance/uniforms/uniform-samplers-test.html
+  resources/cors-util.js
   resources/desktop-gl-constants.js
   resources/js-test-pre.js
   resources/js-test-style.css
   resources/opengl_logo.jpg
   resources/thunderbird-logo-64x64.png
   resources/webgl-logo.png
   resources/webgl-test-harness.js
new file mode 100644
--- /dev/null
+++ b/content/canvas/test/webgl-conformance/resources/cors-util.js
@@ -0,0 +1,31 @@
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+
+function getExampleDotComURL(conformanceDirRelativePath) {
+  var prefix = 'http://example.com/tests/content/canvas/test/webgl-conformance/';
+  return prefix + conformanceDirRelativePath;
+}
+
+function setExampleDotComImage(imageElemID, imagePath, relPathToBase, onLoadCallback) {
+  var img = document.getElementById(imageElemID);
+  if (!img)
+    throw 'Bad `imageElemID`: ' + imageElemID;
+
+  if (onLoadCallback)
+    img.onload = onLoadCallback;
+
+  img.onerror = function() {
+    console.log('Failed to load image from: ' + img.src);
+    console.log('Loading same-domain backup image.');
+
+    img.onerror = function() {
+      console.log('Failed to load backup image from: ' + img.src);
+      return;
+    };
+
+    img.src = relPathToBase + imagePath;
+  };
+
+  img.src = getExampleDotComURL(imagePath);
+}
--- a/content/canvas/test/webgl-conformance/resources/js-test-pre.js
+++ b/content/canvas/test/webgl-conformance/resources/js-test-pre.js
@@ -111,32 +111,32 @@ function testFailed(msg)
         messages.unshift(stack.pop());
     }
 
     for (message in messages) {
         dump(messages[message] + '\n');
     }
 }
 
-function testFailedRender(msg, ref, test, width, height) 
+function testFailedRender(msg, ref, test, width, height)
 {
     var refData;
     if (typeof ref.getImageData == 'function') {
         refData = ref.canvas.toDataURL();
     } else {
         refData = arrayToURLData(ref, width, height);
     }
 
     var testData;
     if (typeof test.getImageData == 'function') {
         testData = test.canvas.toDataURL();
     } else {
         testData = arrayToURLData(test, width, height);
     }
-    
+
     testFailed(msg);
 
     var data = 'REFTEST TEST-DEBUG-INFO | ' + msg + ' | image comparison (==)\n' +
                'REFTEST   IMAGE 1 (TEST): ' + testData + '\n' +
                'REFTEST   IMAGE 2 (REFERENCE): ' + refData;
     dump('FAIL: ' + data + '\n');
     dump('To view the differences between these image renderings, go to the following link: https://hg.mozilla.org/mozilla-central/raw-file/tip/layout/tools/reftest/reftest-analyzer.xhtml#log=' +
     encodeURIComponent(encodeURIComponent(data)) + '\n');
@@ -467,9 +467,8 @@ function gc() {
     for (var i = 0; i < 1000; i++)
         gcRec(10);
 }
 
 function finishTest() {
     debug('<br /><span class="pass">TEST COMPLETE</span>');
     notifyFinishedToHarness();
 }
-