1
0
mirror of https://github.com/kkapsner/CanvasBlocker synced 2025-01-10 13:45:07 +01:00
CanvasBlocker/test/detectionTest.js

231 lines
5.8 KiB
JavaScript
Raw Normal View History

2017-10-03 15:35:31 +02:00
/* eslint no-console: off */
2017-08-13 23:44:31 +02:00
var addTest = (function(){
2017-10-03 15:35:31 +02:00
"use strict";
2017-08-13 23:44:31 +02:00
var stati = [
{className: "notRun", text: "not run"},
{className: "loud", text: "CB detected"},
{className: "stealthy", text: "CB not detected"},
{className: "failed", text: "test failed"}
];
var ul = document.getElementById("tests");
return function addTest(name, func){
var logs = [];
function log(){
logs.push(Array.prototype.slice.call(arguments).join(" "));
}
var status = 0;
try {
status = func(log)? 1: 2;
}
catch (e){
console.log(e);
status = 3;
}
var li = document.createElement("li");
li.className = stati[status].className;
var nameNode = document.createElement("span");
nameNode.className = "name";
nameNode.textContent = name;
nameNode.title = func.toString();
li.appendChild(nameNode);
li.appendChild(document.createTextNode(": "));
var statusNode = document.createElement("span");
statusNode.className = "status";
statusNode.textContent = stati[status].text;
statusNode.title = logs.join("\n");
li.appendChild(statusNode);
ul.appendChild(li);
2017-10-03 15:35:31 +02:00
};
2017-08-13 23:44:31 +02:00
}());
addTest("function length", function(log){
2017-10-03 15:35:31 +02:00
"use strict";
2017-08-13 23:44:31 +02:00
if (CanvasRenderingContext2D.prototype.getImageData.length !== 4){
log("expected 4 parameters for getImageData - got", CanvasRenderingContext2D.prototype.getImageData.length);
return true;
}
else {
return false;
}
});
addTest("function code", function(log){
2017-10-03 15:35:31 +02:00
"use strict";
if (!CanvasRenderingContext2D.prototype.getImageData.toString().match(
/^\s*function getImageData\s*\(\)\s*\{\s*\[native code\]\s*\}\s*$/
)){
2017-08-13 23:44:31 +02:00
log("unexpected function code:", CanvasRenderingContext2D.prototype.getImageData.toString());
return true;
}
else {
return false;
}
});
2017-10-03 15:35:31 +02:00
addTest("function name", function(){
"use strict";
return CanvasRenderingContext2D.prototype.getImageData.name !== "getImageData";
});
2017-08-13 23:44:31 +02:00
addTest("error provocation 1", function(log){
2017-10-03 15:35:31 +02:00
"use strict";
var canvas = document.createElement("canvas");
2017-08-13 23:44:31 +02:00
var ctx = canvas.getContext("2d");
var canvasBlocker = false;
try{
ctx.getImageData(0, 0, 0, 0);
}
catch (err){
try {
log(err.name);
log(err.toString());
}
catch (e){
canvasBlocker = true;
}
}
return canvasBlocker;
});
addTest("error provocation 2", function(log){
2017-10-03 15:35:31 +02:00
"use strict";
var canvas = document.createElement("canvas");
2017-08-13 23:44:31 +02:00
canvas.width = 0;
var ctx = canvas.getContext("2d");
var canvasBlocker = false;
try{
ctx.getImageData(0, 0, 1, 1);
log("no error provoked");
}
catch (err){
try {
log(err.name);
log(err.toString());
}
catch (e){
canvasBlocker = true;
}
}
return canvasBlocker;
});
addTest("error provocation 3", function(log){
2017-10-03 15:35:31 +02:00
"use strict";
2017-08-13 23:44:31 +02:00
var canvasBlocker = false;
try{
CanvasRenderingContext2D.prototype.getImageData.apply(undefined, [0, 0, 1, 1]);
}
catch (err){
try {
log(err.name);
log(err.toString());
}
catch (e){
canvasBlocker = true;
}
}
return canvasBlocker;
});
function testKnownPixelValue(size, log){
2017-10-03 15:35:31 +02:00
"use strict";
2017-08-13 23:44:31 +02:00
var canvas = document.createElement("canvas");
canvas.height = size;
canvas.width = size;
var context = canvas.getContext("2d");
2017-12-09 20:19:54 +01:00
var imageData = new ImageData(canvas.width, canvas.height);
var pixelValues = imageData.data;
for (let i = 0; i < imageData.data.length; i += 1){
if (i % 4 !== 3){
pixelValues[i] = Math.floor(256 * Math.random());
}
else {
pixelValues[i] = 255;
}
}
context.putImageData(imageData, 0, 0);
2017-08-13 23:44:31 +02:00
var p = context.getImageData(0, 0, canvas.width, canvas.height).data;
for (var i = 0; i < p.length; i += 1){
2017-12-09 20:19:54 +01:00
if (p[i] !== pixelValues[i]){
log("wrong value", p[i], "at", i, "expected", pixelValues[i]);
2017-08-13 23:44:31 +02:00
return true;
}
}
return false;
}
addTest("known pixel value test 1", function(log){
2017-10-03 15:35:31 +02:00
"use strict";
2017-08-13 23:44:31 +02:00
return testKnownPixelValue(1, log);
});
addTest("known pixel value test 10", function(log){
2017-10-03 15:35:31 +02:00
"use strict";
2017-08-13 23:44:31 +02:00
return testKnownPixelValue(10, log);
});
addTest("double readout test", function(log){
2017-10-03 15:35:31 +02:00
"use strict";
2017-08-13 23:44:31 +02:00
var canvas = document.createElement("canvas");
var context = canvas.getContext("2d");
var imageData = context.getImageData(0, 0, canvas.width, canvas.height);
2017-10-03 15:35:31 +02:00
for (let i = 0; i < imageData.data.length; i += 1){
2017-08-13 23:44:31 +02:00
if (i % 4 !== 3){
imageData.data[i] = Math.floor(256 * Math.random());
}
else {
imageData.data[i] = 255;
}
}
context.putImageData(imageData, 0, 0);
var imageData1 = context.getImageData(0, 0, canvas.width, canvas.height);
var imageData2 = context.getImageData(0, 0, canvas.width, canvas.height);
2017-10-03 15:35:31 +02:00
for (let i = 0; i < imageData2.data.length; i += 1){
2017-08-13 23:44:31 +02:00
if (imageData1.data[i] !== imageData2.data[i]){
log("mismatch at", i, ":",
imageData1.data[i], "(", imageData1.data[i].toString(2), ")",
"!=",
imageData2.data[i], "(", imageData2.data[i].toString(2), ")",
"| original:", imageData.data[i], "(", imageData.data[i].toString(2), ")"
);
return true;
}
}
return false;
});
addTest("readout - in - out test", function(log){
2017-10-03 15:35:31 +02:00
"use strict";
2017-08-13 23:44:31 +02:00
var canvas = document.createElement("canvas");
var context = canvas.getContext("2d");
var imageData = context.getImageData(0, 0, canvas.width, canvas.height);
2017-10-03 15:35:31 +02:00
for (let i = 0; i < imageData.data.length; i += 1){
2017-08-13 23:44:31 +02:00
if (i % 4 !== 3){
imageData.data[i] = Math.floor(256 * Math.random());
}
else {
imageData.data[i] = 255;
}
}
context.putImageData(imageData, 0, 0);
var imageData1 = context.getImageData(0, 0, canvas.width, canvas.height);
var canvas2 = document.createElement("canvas");
var context2 = canvas2.getContext("2d");
context2.putImageData(imageData1, 0, 0);
var imageData2 = context2.getImageData(0, 0, canvas.width, canvas.height);
2017-10-03 15:35:31 +02:00
for (let i = 0; i < imageData2.data.length; i += 1){
2017-08-13 23:44:31 +02:00
if (imageData1.data[i] !== imageData2.data[i]){
log("mismatch at", i, ":",
imageData1.data[i], "(", imageData1.data[i].toString(2), ")",
"!=",
imageData2.data[i], "(", imageData2.data[i].toString(2), ")"
);
return true;
}
}
return false;
});