From: Joseph Turner via "Bug reports for GNU Emacs, the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org>
To: Eli Zaretskii <eliz@gnu.org>
Cc: 70093@debbugs.gnu.org, da_vid@orange.fr
Subject: bug#70093: Remove unnecessary `image-tests--map-equal'
Date: Sat, 30 Mar 2024 22:32:26 -0700 [thread overview]
Message-ID: <8734s7c6cv.fsf@breatheoutbreathe.in> (raw)
In-Reply-To: <86y19zaswg.fsf@gnu.org>
[-- Attachment #1: Type: text/plain, Size: 878 bytes --]
Eli Zaretskii <eliz@gnu.org> writes:
>> Cc: Eli Zaretskii <eliz@gnu.org>, David Ponce <da_vid@orange.fr>
>> From: Joseph Turner <joseph@breatheoutbreathe.in>
>> Date: Sat, 30 Mar 2024 12:44:14 -0700
>>
>> With the resolution of bug#69992, it may be possible to remove the
>> `image-tests--map-equal' equality predicate from lisp/image-tests.el.
>
> Why is it a good idea to remove tests? If the test tests some of our
> code which should work as the test assumes, we should not remove it.
Not removing tests, but rather making the tests more strict (if possible).
>> Eli and David, would you please apply the attached patch and then run
>> the tests to see if we still need to allow for tolerances in
>> `image--compute-map-and-original-map'?
>
> ENOPATCH
Sorry about that. Please check if the tests still pass on your machine
when we use `equal' to compare image maps.
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-Compare-image-maps-with-equal-in-tests.patch --]
[-- Type: text/x-diff, Size: 4386 bytes --]
From e85fd88a2943fa95d2d7eea3a542308adaa81582 Mon Sep 17 00:00:00 2001
From: Joseph Turner <joseph@breatheoutbreathe.in>
Date: Sat, 30 Mar 2024 12:38:52 -0700
Subject: [PATCH] Compare image maps with `equal' in tests
With the fixes to image map transformation introduced in cc212ea314d,
the tests should now exactly predict calculated image maps.
* test/lisp/image-tests.el (image-tests--map-equal): Remove function.
(image--compute-map-and-original-map): Use equal to compare image maps.
---
test/lisp/image-tests.el | 46 +++++-----------------------------------
1 file changed, 5 insertions(+), 41 deletions(-)
diff --git a/test/lisp/image-tests.el b/test/lisp/image-tests.el
index 020781eff50..41b87b8d337 100644
--- a/test/lisp/image-tests.el
+++ b/test/lisp/image-tests.el
@@ -178,37 +178,6 @@ image-create-image-with-map
(got-original-map (image-property image :original-map)))
(should (equal got-original-map original-map-other)))))
-(defun image-tests--map-equal (a b &optional tolerance)
- "Return t if maps A and B have the same coordinates within TOLERANCE.
-Since image sizes calculations vary on different machines, this function
-allows for each image map coordinate in A to be within TOLERANCE to the
-corresponding coordinate in B. When nil, TOLERANCE defaults to 5."
- (unless tolerance (setq tolerance 5))
- (catch 'different
- (cl-labels ((check-tolerance
- (coord-a coord-b)
- (unless (>= tolerance (abs (- coord-a coord-b)))
- (throw 'different nil))))
- (dotimes (i (length a))
- (pcase-let ((`((,type-a . ,coords-a) ,_id ,_plist) (nth i a))
- (`((,type-b . ,coords-b) ,_id ,_plist) (nth i b)))
- (unless (eq type-a type-b)
- (throw 'different nil))
- (pcase-exhaustive type-a
- ('rect
- (check-tolerance (caar coords-a) (caar coords-b))
- (check-tolerance (cdar coords-a) (cdar coords-b))
- (check-tolerance (cadr coords-a) (cadr coords-b))
- (check-tolerance (cddr coords-a) (cddr coords-b)))
- ('circle
- (check-tolerance (caar coords-a) (caar coords-b))
- (check-tolerance (cdar coords-a) (cdar coords-b))
- (check-tolerance (cdar coords-a) (cdar coords-b)))
- ('poly
- (dotimes (i (length coords-a))
- (check-tolerance (aref coords-a i) (aref coords-b i))))))))
- t))
-
(ert-deftest image--compute-map-and-original-map ()
"Test `image--compute-map' and `image--compute-original-map'."
(skip-unless (display-images-p))
@@ -237,25 +206,20 @@ image--compute-map-and-original-map
:scale 2 :rotation 90 :flip t)))
;; Test that `image--compute-original-map' correctly generates
;; original-map when creating an already transformed image.
- (should (image-tests--map-equal (image-property image :original-map)
- original-map))
+ (should (equal (image-property image :original-map) original-map))
(setf (image-property image :flip) nil)
(setf (image-property image :rotation) 0)
(setf (image-property image :scale) 2)
- (should (image-tests--map-equal (image--compute-map image)
- scaled-map))
+ (should (equal (image--compute-map image) scaled-map))
(setf (image-property image :scale) 1)
(setf (image-property image :rotation) 90)
- (should (image-tests--map-equal (image--compute-map image)
- rotated-map))
+ (should (equal (image--compute-map image) rotated-map))
(setf (image-property image :rotation) 0)
(setf (image-property image :flip) t)
- (should (image-tests--map-equal (image--compute-map image)
- flipped-map))
+ (should (equal (image--compute-map image) flipped-map))
(setf (image-property image :scale) 2)
(setf (image-property image :rotation) 90)
- (should (image-tests--map-equal (image--compute-map image)
- scaled-rotated-flipped-map))
+ (should (equal (image--compute-map image) scaled-rotated-flipped-map))
;; Uncomment to test manually by interactively transforming the
;; image and checking the map boundaries by hovering them.
--
2.41.0
next prev parent reply other threads:[~2024-03-31 5:32 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-03-30 19:44 bug#70093: Remove unnecessary `image-tests--map-equal' Joseph Turner via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-30 22:04 ` bug#70093: *** SPAM *** " David Ponce via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-31 7:37 ` Joseph Turner via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-31 10:08 ` David Ponce via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-04-02 10:36 ` David Ponce via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-04-06 1:50 ` Joseph Turner via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-04-07 16:01 ` David Ponce via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-31 5:10 ` Eli Zaretskii
2024-03-31 5:32 ` Joseph Turner via Bug reports for GNU Emacs, the Swiss army knife of text editors [this message]
2024-03-31 7:33 ` Eli Zaretskii
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=8734s7c6cv.fsf@breatheoutbreathe.in \
--to=bug-gnu-emacs@gnu.org \
--cc=70093@debbugs.gnu.org \
--cc=da_vid@orange.fr \
--cc=eliz@gnu.org \
--cc=joseph@breatheoutbreathe.in \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).