From 437551b90e966f6876870391101a1eaacda70538 Mon Sep 17 00:00:00 2001 From: Roman Kuznetsov Date: Mon, 7 Aug 2023 16:02:50 +0300 Subject: [PATCH] perf: provide diffBuffer in ImageDiffError --- package-lock.json | 14 +++++------ package.json | 2 +- .../capture-processors/assert-refs.js | 4 ++-- .../assert-view/errors/image-diff-error.js | 18 +++++++++++---- src/browser/commands/assert-view/index.js | 12 +++++++++- src/image.js | 1 + .../src/browser/commands/assert-view/index.js | 23 +++++++++++++------ test/src/image.js | 1 + 8 files changed, 52 insertions(+), 23 deletions(-) diff --git a/package-lock.json b/package-lock.json index 56b3fa7e2..f1b52e609 100644 --- a/package-lock.json +++ b/package-lock.json @@ -28,7 +28,7 @@ "glob-extra": "^5.0.2", "inherit": "^2.2.2", "lodash": "^4.17.21", - "looks-same": "^8.1.0", + "looks-same": "^8.2.1", "micromatch": "^4.0.5", "mocha": "^10.2.0", "plugins-loader": "^1.1.0", @@ -9779,9 +9779,9 @@ } }, "node_modules/looks-same": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/looks-same/-/looks-same-8.1.0.tgz", - "integrity": "sha512-gdMgCSCvhpR2/AA15CamZD7Ch+gx8sOqWyRzz3j1Gs8+2VBCyHm3CRMS8EK+5rNvpwf9AGEnDunredVM5+f46w==", + "version": "8.2.1", + "resolved": "https://registry.npmjs.org/looks-same/-/looks-same-8.2.1.tgz", + "integrity": "sha512-55u5dWPWc/9cIFRtDjqbH/J3h0nyar1gqFrDIDQSpqYDDd19dZUQtTMxLj0hvsxzp/qzQ0EV0HChtXRWylY2Pg==", "dependencies": { "color-diff": "^1.1.0", "fs-extra": "^8.1.0", @@ -22101,9 +22101,9 @@ "dev": true }, "looks-same": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/looks-same/-/looks-same-8.1.0.tgz", - "integrity": "sha512-gdMgCSCvhpR2/AA15CamZD7Ch+gx8sOqWyRzz3j1Gs8+2VBCyHm3CRMS8EK+5rNvpwf9AGEnDunredVM5+f46w==", + "version": "8.2.1", + "resolved": "https://registry.npmjs.org/looks-same/-/looks-same-8.2.1.tgz", + "integrity": "sha512-55u5dWPWc/9cIFRtDjqbH/J3h0nyar1gqFrDIDQSpqYDDd19dZUQtTMxLj0hvsxzp/qzQ0EV0HChtXRWylY2Pg==", "requires": { "color-diff": "^1.1.0", "fs-extra": "^8.1.0", diff --git a/package.json b/package.json index 71cb0471a..760691739 100644 --- a/package.json +++ b/package.json @@ -62,7 +62,7 @@ "glob-extra": "^5.0.2", "inherit": "^2.2.2", "lodash": "^4.17.21", - "looks-same": "^8.1.0", + "looks-same": "^8.2.1", "micromatch": "^4.0.5", "mocha": "^10.2.0", "plugins-loader": "^1.1.0", diff --git a/src/browser/commands/assert-view/capture-processors/assert-refs.js b/src/browser/commands/assert-view/capture-processors/assert-refs.js index 3af8b302f..5f0d8b0be 100644 --- a/src/browser/commands/assert-view/capture-processors/assert-refs.js +++ b/src/browser/commands/assert-view/capture-processors/assert-refs.js @@ -9,7 +9,7 @@ exports.handleNoRefImage = (currImg, refImg, state) => { }; exports.handleImageDiff = (currImg, refImg, state, opts) => { - const { tolerance, antialiasingTolerance, canHaveCaret, diffAreas, config } = opts; + const { tolerance, antialiasingTolerance, canHaveCaret, diffAreas, config, diffBuffer } = opts; const { buildDiffOpts, system: { diffColor }, @@ -25,5 +25,5 @@ exports.handleImageDiff = (currImg, refImg, state, opts) => { ...buildDiffOpts, }; - return Promise.reject(ImageDiffError.create(state, currImg, refImg, diffOpts, diffAreas)); + return Promise.reject(ImageDiffError.create(state, currImg, refImg, diffOpts, diffAreas, diffBuffer)); }; diff --git a/src/browser/commands/assert-view/errors/image-diff-error.js b/src/browser/commands/assert-view/errors/image-diff-error.js index be95e1b4d..920f955c2 100644 --- a/src/browser/commands/assert-view/errors/image-diff-error.js +++ b/src/browser/commands/assert-view/errors/image-diff-error.js @@ -10,19 +10,27 @@ module.exports = class ImageDiffError extends BaseStateError { static fromObject(data) { const { diffBounds, diffClusters } = data; - return new ImageDiffError(data.stateName, data.currImg, data.refImg, data.diffOpts, { - diffBounds, - diffClusters, - }); + return new ImageDiffError( + data.stateName, + data.currImg, + data.refImg, + data.diffOpts, + { + diffBounds, + diffClusters, + }, + data.diffBuffer, + ); } - constructor(stateName, currImg, refImg, diffOpts, { diffBounds, diffClusters } = {}) { + constructor(stateName, currImg, refImg, diffOpts, { diffBounds, diffClusters } = {}, diffBuffer) { super(stateName, currImg, refImg); this.message = `images are different for "${stateName}" state`; this.diffOpts = diffOpts; this.diffBounds = diffBounds; this.diffClusters = diffClusters; + this.diffBuffer = diffBuffer; } saveDiffTo(diffPath) { diff --git a/src/browser/commands/assert-view/index.js b/src/browser/commands/assert-view/index.js index 411014f8e..7a068492e 100644 --- a/src/browser/commands/assert-view/index.js +++ b/src/browser/commands/assert-view/index.js @@ -90,14 +90,24 @@ module.exports = browser => { equal, diffBounds, diffClusters, + diffImage, metaInfo = {}, } = await Image.compare(refBuffer, currBuffer, imageCompareOpts); Object.assign(refImg, metaInfo.refImg); if (!equal) { + const diffBuffer = await diffImage.createBuffer("png"); const diffAreas = { diffBounds, diffClusters }; const { tolerance, antialiasingTolerance } = opts; - const imageDiffOpts = { tolerance, antialiasingTolerance, canHaveCaret, diffAreas, config, emitter }; + const imageDiffOpts = { + tolerance, + antialiasingTolerance, + canHaveCaret, + diffAreas, + config, + emitter, + diffBuffer, + }; await fs.outputFile(currImg.path, currBuffer); diff --git a/src/image.js b/src/image.js index 81af668ea..721ab96e5 100644 --- a/src/image.js +++ b/src/image.js @@ -159,6 +159,7 @@ module.exports = class Image { ignoreCaret: opts.canHaveCaret, pixelRatio: opts.pixelRatio, ...opts.compareOpts, + createDiffImage: true, }; ["tolerance", "antialiasingTolerance"].forEach(option => { if (option in opts) { diff --git a/test/src/browser/commands/assert-view/index.js b/test/src/browser/commands/assert-view/index.js index 79de6eefb..0965a0755 100644 --- a/test/src/browser/commands/assert-view/index.js +++ b/test/src/browser/commands/assert-view/index.js @@ -74,7 +74,7 @@ describe("assertView command", () => { beforeEach(() => { sandbox.stub(Image, "create").returns(Object.create(Image.prototype)); - sandbox.stub(Image, "compare").resolves(true); + sandbox.stub(Image, "compare").resolves({ diffImage: { createBuffer: sandbox.stub() } }); sandbox.stub(Image.prototype, "getSize"); sandbox.stub(fs, "readFileSync"); @@ -494,7 +494,7 @@ describe("assertView command", () => { describe("image compare", () => { it("should add opts from runtime config to temp", async () => { - Image.compare.resolves({ equal: true }); + Image.compare.resolves({ equal: true, diffImage: { createBuffer: sandbox.stub() } }); RuntimeConfig.getInstance.returns({ tempOpts: { some: "opts" } }); const browser = await initBrowser_(); @@ -506,7 +506,7 @@ describe("assertView command", () => { it("should compare a current image with a reference", async () => { const config = mkConfig_({ getScreenshotPath: () => "/ref/path" }); const image = stubImage_(); - Image.compare.resolves({ equal: true }); + Image.compare.resolves({ equal: true, diffImage: { createBuffer: sandbox.stub() } }); temp.path.returns("/curr/path"); fs.readFile.withArgs("/ref/path").resolves("refPngBuffer"); ScreenShooter.prototype.capture.resolves(image); @@ -525,7 +525,9 @@ describe("assertView command", () => { }); fs.readFile.withArgs("/ref/path").resolves("refPngBuffer"); image.toPngBuffer.resolves("currPngBuffer"); - Image.compare.withArgs("refPngBuffer", "currPngBuffer").resolves({ equal: true }); + Image.compare + .withArgs("refPngBuffer", "currPngBuffer") + .resolves({ equal: true, diffImage: { createBuffer: sandbox.stub() } }); ScreenShooter.prototype.capture.resolves(image); await fn(browser); @@ -589,7 +591,7 @@ describe("assertView command", () => { describe("if images are not equal", () => { beforeEach(() => { - Image.compare.resolves({ equal: false }); + Image.compare.resolves({ equal: false, diffImage: { createBuffer: sandbox.stub() } }); }); describe("assert refs", () => { @@ -613,6 +615,7 @@ describe("assertView command", () => { Image.compare.resolves({ equal: false, metaInfo: { refImg: { size: { width: 300, height: 400 } } }, + diffImage: { createBuffer: sandbox.stub() }, }); await fn(browser, "state"); @@ -664,7 +667,10 @@ describe("assertView command", () => { }); it("should pass diff bounds to error", async () => { - Image.compare.resolves({ diffBounds: { left: 0, top: 0, right: 10, bottom: 10 } }); + Image.compare.resolves({ + diffBounds: { left: 0, top: 0, right: 10, bottom: 10 }, + diffImage: { createBuffer: sandbox.stub() }, + }); const browser = await initBrowser_(); await fn(browser); @@ -675,7 +681,10 @@ describe("assertView command", () => { }); it("should pass diff clusters to error", async () => { - Image.compare.resolves({ diffClusters: [{ left: 0, top: 0, right: 10, bottom: 10 }] }); + Image.compare.resolves({ + diffClusters: [{ left: 0, top: 0, right: 10, bottom: 10 }], + diffImage: { createBuffer: sandbox.stub() }, + }); const browser = await initBrowser_(); await fn(browser); diff --git a/test/src/image.js b/test/src/image.js index f5e5e5ba4..e93d08564 100644 --- a/test/src/image.js +++ b/test/src/image.js @@ -277,6 +277,7 @@ describe("Image", () => { tolerance: 250, antialiasingTolerance: 100500, stopOnFirstFail: true, + createDiffImage: true, }); });