chromium/third_party/blink/web_tests/fast/canvas/canvas-path-context-clip.html

<script src="../../resources/testharness.js"></script>
<script src="../../resources/testharnessreport.js"></script>
<body>
<canvas id="canvas" width="200" height="200"></canvas>
<script>

var ctx = document.getElementById('canvas').getContext('2d');

function checkResult(expectedColors, sigma) {
    data = ctx.getImageData(50, 50, 1, 1).data;
    for (var i = 0; i < 4; i++)
        assert_approx_equals(data[i], expectedColors[i], sigma);
}

function drawRectanglesOn(contextOrPath) {
    contextOrPath.rect(0, 0, 100, 100);
    contextOrPath.rect(25, 25, 50, 50);
}

function testClipWith(fillRule, path) {
    ctx.fillStyle = 'rgb(255,0,0)';
    ctx.beginPath();
    ctx.fillRect(0, 0, 100, 100);
    ctx.fillStyle = 'rgb(0,255,0)';
    if (path) {
        if (fillRule) {
            ctx.clip(path, fillRule);
        } else {
            ctx.clip(path);
        }
    } else {
        ctx.beginPath();
        drawRectanglesOn(ctx);
        if (fillRule) {
            ctx.clip(fillRule);
        } else {
            ctx.clip();
        }
    }
    ctx.beginPath();
    ctx.fillRect(0, 0, 100, 100);
    if (fillRule == 'evenodd') {
        checkResult([255, 0, 0, 255], 5);
    } else {
        checkResult([0, 255, 0, 255], 5);
    }
}

test(function(t) {
    fillRules = [undefined, 'nonzero', 'evenodd'];
    path = new Path2D();
    drawRectanglesOn(path);

    for (var i = 0; i < fillRules.length; i++) {
       testClipWith(fillRules[i]);
       testClipWith(fillRules[i], path);
    }

    // Test exception cases.
    assert_throws_js(TypeError, function() {
      ctx.clip(null);
    });
    assert_throws_js(TypeError, function() {
      ctx.clip(null, null);
    });
    assert_throws_js(TypeError, function() {
      ctx.clip(null, 'nonzero');
    });
    assert_throws_js(TypeError, function() {
      ctx.clip(path, null);
    });
    assert_throws_js(TypeError, function() {
      ctx.clip([], 'nonzero');
    });
    assert_throws_js(TypeError, function() {
      ctx.clip({}, 'nonzero');
    });
    assert_throws_js(TypeError, function() {
      ctx.clip(null, 'evenodd');
    });
    assert_throws_js(TypeError, function() {
      ctx.clip([], 'evenodd');
    });
    assert_throws_js(TypeError, function() {
      ctx.clip({}, 'evenodd');
    });
    assert_throws_js(TypeError, function() {
      ctx.clip('gazonk');
    });
    assert_throws_js(TypeError, function() {
      ctx.clip(path, 'gazonk');
    });
    assert_throws_js(TypeError, function() {
      ctx.clip(undefined, undefined);
    });
    assert_throws_js(TypeError, function() {
      ctx.clip(undefined, 'nonzero');
    });
}, 'Series of tests to ensure clip() works with path and winding rule parameters.');
</script>
</body>