content/base/test/test_meta_viewport2.html

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/content/base/test/test_meta_viewport2.html	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,77 @@
     1.4 +<!DOCTYPE HTML>
     1.5 +<html>
     1.6 +<head>
     1.7 +  <meta charset="utf-8">
     1.8 +  <title>meta viewport test</title>
     1.9 +  <script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
    1.10 +  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
    1.11 +  <meta name="viewport" content="width=device-width">
    1.12 +  <script src="viewport_helpers.js"></script>
    1.13 +</head>
    1.14 +<body>
    1.15 +  <p>width=device-width</p>
    1.16 +  <script type="application/javascript;version=1.7">
    1.17 +    "use strict";
    1.18 +
    1.19 +    SimpleTest.waitForExplicitFinish();
    1.20 +
    1.21 +    let tests = [];
    1.22 +
    1.23 +    tests.push(function test1() {
    1.24 +      SpecialPowers.pushPrefEnv(scaleRatio(1.0),
    1.25 +        function() {
    1.26 +          let info = getViewportInfo(800, 480);
    1.27 +          is(info.defaultZoom, 1,    "initial zoom is 100%");
    1.28 +          is(info.width,       800,  "width is the same as the displayWidth");
    1.29 +          is(info.height,      480,  "height is the same as the displayHeight");
    1.30 +          is(info.autoSize,    true, "width=device-width enables autoSize");
    1.31 +          is(info.allowZoom,   true, "zooming is enabled by default");
    1.32 +
    1.33 +          info = getViewportInfo(900, 600);
    1.34 +          is(info.width,       900,  "changing the displayWidth changes the width");
    1.35 +          is(info.height,      600,  "changing the displayHeight changes the height");
    1.36 +
    1.37 +          nextTest();
    1.38 +        });
    1.39 +    });
    1.40 +
    1.41 +    tests.push(function test2() {
    1.42 +      SpecialPowers.pushPrefEnv(scaleRatio(1.5),
    1.43 +        function() {
    1.44 +          let info = getViewportInfo(900, 600);
    1.45 +          is(info.defaultZoom, 1.5,  "initial zoom is 150%");
    1.46 +          is(info.width,       600,  "width equals displayWidth/1.5");
    1.47 +          is(info.height,      400,  "height equals displayHeight/1.5");
    1.48 +
    1.49 +          nextTest();
    1.50 +        });
    1.51 +    });
    1.52 +
    1.53 +    function getViewportInfo(aDisplayWidth, aDisplayHeight) {
    1.54 +      let defaultZoom = {}, allowZoom = {}, minZoom = {}, maxZoom = {},
    1.55 +          width = {}, height = {}, autoSize = {};
    1.56 +
    1.57 +      let cwu = SpecialPowers.getDOMWindowUtils(window);
    1.58 +      cwu.getViewportInfo(aDisplayWidth, aDisplayHeight, defaultZoom, allowZoom,
    1.59 +                          minZoom, maxZoom, width, height, autoSize);
    1.60 +      return {
    1.61 +        defaultZoom: defaultZoom.value,
    1.62 +        minZoom: minZoom.value,
    1.63 +        maxZoom: maxZoom.value,
    1.64 +        width: width.value,
    1.65 +        height: height.value,
    1.66 +        autoSize: autoSize.value,
    1.67 +        allowZoom: allowZoom.value
    1.68 +      };
    1.69 +    }
    1.70 +
    1.71 +    function nextTest() {
    1.72 +      if (tests.length)
    1.73 +        (tests.shift())();
    1.74 +      else
    1.75 +        SimpleTest.finish();
    1.76 +    }
    1.77 +    addEventListener("load", nextTest);
    1.78 +  </script>
    1.79 +</body>
    1.80 +</html>

mercurial