diff --git a/src/Diff.ml b/src/Diff.ml index dc3d63f6..09dbba2f 100644 --- a/src/Diff.ml +++ b/src/Diff.ml @@ -29,20 +29,24 @@ module MakeDiff (IO1 : ImageIO.ImageIO) (IO2 : ImageIO.ImageIO) = struct let compare (base : IO1.t ImageIO.img) (comp : IO2.t ImageIO.img) ?(antialiasing = false) ?(outputDiffMask = false) ?(diffLines = false) - ?diffPixel ?(threshold = 0.1) ?ignoreRegions () = + ?diffPixel ?(threshold = 0.1) ?ignoreRegions ?(captureDiff = true) () = let maxDelta = maxYIQPossibleDelta *. (threshold ** 2.) in let diffPixel = match diffPixel with Some x -> x | None -> redPixel in let diffOutput = - match outputDiffMask with - | true -> IO1.makeSameAsLayout base - | false -> base + match captureDiff with + | true -> + Some + (match outputDiffMask with + | true -> IO1.makeSameAsLayout base + | false -> base) + | false -> None in let diffCount = ref 0 in let diffLinesStack = Stack.create () in let countDifference x y = incr diffCount; - IO1.setImgColor ~x ~y diffPixel diffOutput; + diffOutput |> Option.iter (IO1.setImgColor ~x ~y diffPixel); if diffLines @@ -115,10 +119,23 @@ module MakeDiff (IO1 : ImageIO.ImageIO) (IO2 : ImageIO.ImageIO) = struct && (base.width <> comp.width || base.height <> comp.height) then Layout else - let diffResult = + let diffOutput, diffCount, diffPercentage, diffLinesStack = compare base comp ~threshold ~diffPixel ~outputDiffMask ~antialiasing - ~diffLines ?ignoreRegions () + ~diffLines ?ignoreRegions ~captureDiff:true () in + Pixel (Option.get diffOutput, diffCount, diffPercentage, diffLinesStack) + let diffWithoutOutput (base : IO1.t ImageIO.img) (comp : IO2.t ImageIO.img) + ?(threshold = 0.1) ?(failOnLayoutChange = true) ?(antialiasing = false) + ?(diffLines = false) ?ignoreRegions () = + if + failOnLayoutChange = true + && (base.width <> comp.width || base.height <> comp.height) + then Layout + else + let diffResult = + compare base comp ~threshold ~outputDiffMask:false ~antialiasing + ~diffLines ?ignoreRegions ~captureDiff:false () + in Pixel diffResult end diff --git a/test/Test_Core.ml b/test/Test_Core.ml index d4a1a0ae..4399f540 100644 --- a/test/Test_Core.ml +++ b/test/Test_Core.ml @@ -48,10 +48,14 @@ let test_diff_color () = ~diffPixel:(Int32.of_int 4278255360 (*int32 representation of #00ff00*)) () in + check bool "diffOutput" (Option.is_some diffOutput) true; + let diffOutput = Option.get diffOutput in let originalDiff = Png.IO.loadImage "test-images/png/orange_diff_green.png" in let diffMaskOfDiff, diffOfDiffPixels, diffOfDiffPercentage, _ = PNG_Diff.compare originalDiff diffOutput () in + check bool "diffMaskOfDiff" (Option.is_some diffMaskOfDiff) true; + let diffMaskOfDiff = Option.get diffMaskOfDiff in if diffOfDiffPixels > 0 then ( Png.IO.saveImage diffOutput "test-images/png/diff-output-green.png"; Png.IO.saveImage diffMaskOfDiff "test-images/png/diff-of-diff-green.png"); diff --git a/test/Test_IO_BMP.ml b/test/Test_IO_BMP.ml index 4d6f716b..c8c87e79 100644 --- a/test/Test_IO_BMP.ml +++ b/test/Test_IO_BMP.ml @@ -34,8 +34,12 @@ let test_creates_correct_diff_output_image () = let img1 = load_image "test-images/bmp/clouds.bmp" in let img2 = load_image "test-images/bmp/clouds-2.bmp" in let diffOutput, _, _, _ = Diff.compare img1 img2 () in + check bool "diffOutput" (Option.is_some diffOutput) true; + let diffOutput = Option.get diffOutput in let originalDiff = load_png_image "test-images/bmp/clouds-diff.png" in let diffMaskOfDiff, diffOfDiffPixels, diffOfDiffPercentage, _ = Output_Diff.compare originalDiff diffOutput () in + check bool "diffMaskOfDiff" (Option.is_some diffMaskOfDiff) true; + let diffMaskOfDiff = Option.get diffMaskOfDiff in if diffOfDiffPixels > 0 then ( Bmp.IO.saveImage diffOutput "test-images/bmp/_diff-output.png"; Png.IO.saveImage diffMaskOfDiff "test-images/bmp/_diff-of-diff.png" diff --git a/test/Test_IO_JPG.ml b/test/Test_IO_JPG.ml index e2fc6dc5..00fd8946 100644 --- a/test/Test_IO_JPG.ml +++ b/test/Test_IO_JPG.ml @@ -43,10 +43,14 @@ let test_creates_correct_diff_output_image () = let img1 = load_image "test-images/jpg/tiger.jpg" in let img2 = load_image "test-images/jpg/tiger-2.jpg" in let diffOutput, _, _, _ = Diff.compare img1 img2 () in + check bool "diffOutput" (Option.is_some diffOutput) true; + let diffOutput = Option.get diffOutput in let originalDiff = load_png_image "test-images/jpg/tiger-diff.png" in let diffMaskOfDiff, diffOfDiffPixels, diffOfDiffPercentage, _ = Output_Diff.compare originalDiff diffOutput () in + check bool "diffMaskOfDiff" (Option.is_some diffMaskOfDiff) true; + let diffMaskOfDiff = Option.get diffMaskOfDiff in if diffOfDiffPixels > 0 then ( Jpg.IO.saveImage diffOutput "test-images/jpg/_diff-output.png"; Png.IO.saveImage diffMaskOfDiff "test-images/jpg/_diff-of-diff.png"); diff --git a/test/Test_IO_PNG.ml b/test/Test_IO_PNG.ml index 496321cd..208603d0 100644 --- a/test/Test_IO_PNG.ml +++ b/test/Test_IO_PNG.ml @@ -40,10 +40,14 @@ let () = let img1 = load_image "test-images/png/orange.png" in let img2 = load_image "test-images/png/orange_changed.png" in let diffOutput, _, _, _ = Diff.compare img1 img2 () in + check bool "diffOutput" (Option.is_some diffOutput) true; + let diffOutput = Option.get diffOutput in let originalDiff = load_image "test-images/png/orange_diff.png" in let diffMaskOfDiff, diffOfDiffPixels, diffOfDiffPercentage, _ = Diff.compare originalDiff diffOutput () in + check bool "diffMaskOfDiff" (Option.is_some diffMaskOfDiff) true; + let diffMaskOfDiff = Option.get diffMaskOfDiff in if diffOfDiffPixels > 0 then ( Png.IO.saveImage diffOutput "test-images/png/diff-output.png"; Png.IO.saveImage diffMaskOfDiff diff --git a/test/Test_IO_TIFF.ml b/test/Test_IO_TIFF.ml index a5eb80aa..d2845387 100644 --- a/test/Test_IO_TIFF.ml +++ b/test/Test_IO_TIFF.ml @@ -49,12 +49,16 @@ let run_tiff_tests () = let img1 = load_tiff_image "test-images/tiff/laptops.tiff" in let img2 = load_tiff_image "test-images/tiff/laptops-2.tiff" in let diffOutput, _, _, _ = Diff.compare img1 img2 () in + check bool "diffOutput" (Option.is_some diffOutput) true; + let diffOutput = Option.get diffOutput in let originalDiff = load_png_image "test-images/tiff/laptops-diff.png" in let diffMaskOfDiff, diffOfDiffPixels, diffOfDiffPercentage, _ = Output_Diff.compare originalDiff diffOutput () in + check bool "diffMaskOfDiff" (Option.is_some diffMaskOfDiff) true; + let diffMaskOfDiff = Option.get diffMaskOfDiff in if diffOfDiffPixels > 0 then ( Tiff.IO.saveImage diffOutput "test-images/tiff/_diff-output.png"; Png.IO.saveImage diffMaskOfDiff