我正在使用带有C#的Webdriver,问题是Webdriver 无法测试设计,所以我尝试进行截图比较,因为我在大网站上工作,每天都有新的未来,新的变化,所以我不知道在哪里或哪个浏览器设计没有损坏。我的问题是你知道任何工具、框架、项目或一些想法吗?
我已经写了一些东西,但它不是那么完美,我的代码在不同的浏览器和版本上制作了网站截图,然后将它们剪切并与演示屏幕进行比较。如果错误像素超过 5%,则测试正在下降。
PS我是小学生)
如果将来有人需要它,我的一些代码:
var screenshot = ((ITakesScreenshot)Global.Driver).GetScreenshot(); screenshot.SaveAsFile(dirHomePage + "homepage.png", ImageFormat.Png); var mainImg = new Bitmap(File.OpenRead(dirHomePage + "homepage.png")); var section = new Rectangle(new Point(0, 0), new Size(mainImg.Width, 153)); this.header = this.CropImage(mainImg, section); this.header = this.ClearImage(this.header, Color.White, 264, mainImg.Width, 30, 60); ImageComparison(this.header, this.demoHeader);
public Bitmap ClearImage(Bitmap source, Color color, int fromW, int toW, int fromH, int toH)
{
Bitmap bmp = source;
for (int i = fromW; i < toW; i++)
{
for (int j = fromH; j < toH; j++)
{
bmp.SetPixel(i, j, color);
}
}
return bmp;
}
public Bitmap CropImage(Bitmap source, Rectangle section)
{
Bitmap bmp = new Bitmap(section.Width, section.Height);
Graphics g = Graphics.FromImage(bmp);
g.DrawImage(source, 0, 0, section, GraphicsUnit.Pixel);
return bmp;
}
public void ImageComparison(Bitmap firstImg, Bitmap secondImg)
{
bool match = false;
int nrBadPixels = 0;
if (firstImg.Width.Equals(secondImg.Width) && firstImg.Height.Equals(secondImg.Height))
{
double acceptedProcent = (firstImg.Width * firstImg.Height) * 0.05;
for (int i = 0; i < firstImg.Width; i++)
{
for (int j = 0; j < firstImg.Height; j++)
{
string firstImgRef = firstImg.GetPixel(i, j).ToString();
string secondImgRef = secondImg.GetPixel(i, j).ToString();
if (firstImgRef != secondImgRef)
{
nrBadPixels++;
if (nrBadPixels > acceptedProcent)
{
match = false;
break;
}
match = true;
}
}
}
}
Assert.IsTrue(match);
}