]> git.eshelyaron.com Git - emacs.git/commitdiff
Continue to work on Bug#36940
authorMichael Albinus <michael.albinus@gmx.de>
Wed, 7 Aug 2019 12:12:14 +0000 (14:12 +0200)
committerMichael Albinus <michael.albinus@gmx.de>
Wed, 7 Aug 2019 12:12:14 +0000 (14:12 +0200)
* test/lisp/net/tramp-tests.el (tramp--test-file-attributes-equal-p):
Make the check more precise.  (Bug#36940)

test/lisp/net/tramp-tests.el

index 7ec709a4a6e2c19a425c99b3042480dfcdb9a7c9..bcc74cc3a2caa5df9d0681fe5ab1ddf3cd8f8bfb 100644 (file)
@@ -3085,23 +3085,44 @@ This tests also `access-file', `file-readable-p',
 
 (defsubst tramp--test-file-attributes-equal-p (attr1 attr2)
   "Check, whether file attributes ATTR1 and ATTR2 are equal.
-They might differ only in time attributes."
-  ;; Access time.
-  (setcar (nthcdr 4 attr1) tramp-time-dont-know)
-  (setcar (nthcdr 4 attr2) tramp-time-dont-know)
-  ;; Modification time.
-  (when (or (tramp-compat-time-equal-p (nth 5 attr1) tramp-time-dont-know)
-           (tramp-compat-time-equal-p (nth 5 attr2) tramp-time-dont-know)
-           (< (abs (tramp-time-diff (nth 5 attr1) (nth 5 attr2))) 5))
-    (setcar (nthcdr 5 attr1) tramp-time-dont-know)
-    (setcar (nthcdr 5 attr2) tramp-time-dont-know))
-  ;; Status change time.
-  (when (or (tramp-compat-time-equal-p (nth 6 attr1) tramp-time-dont-know)
-           (tramp-compat-time-equal-p (nth 6 attr2) tramp-time-dont-know)
-           (< (abs (tramp-time-diff (nth 6 attr1) (nth 6 attr2))) 5))
-    (setcar (nthcdr 6 attr1) tramp-time-dont-know)
-    (setcar (nthcdr 6 attr2) tramp-time-dont-know))
-  (equal attr1 attr2))
+They might differ only in time attributes or directory size."
+  (let ((attr1 (copy-sequence attr1))
+       (attr2 (copy-sequence attr2))
+       (start-time
+        (aref
+         (ert--stats-test-start-times ert--current-run-stats)
+         (ert--stats-test-pos ert--current-run-stats (ert-running-test)))))
+    ;; Access time.
+    (setcar (nthcdr 4 attr1) tramp-time-dont-know)
+    (setcar (nthcdr 4 attr2) tramp-time-dont-know)
+    ;; Modification time.  If any of the time values is "don't know",
+    ;; we cannot compare, and we normalize the time stamps.  If the
+    ;; time value is newer than the test start time, normalize it,
+    ;; because due to caching the time stamps could differ slightly (a
+    ;; few seconds).
+    (when (or (tramp-compat-time-equal-p (nth 5 attr1) tramp-time-dont-know)
+             (tramp-compat-time-equal-p (nth 5 attr2) tramp-time-dont-know))
+      (setcar (nthcdr 5 attr1) tramp-time-dont-know)
+      (setcar (nthcdr 5 attr2) tramp-time-dont-know))
+    (when (time-less-p start-time (nth 5 attr1))
+      (setcar (nthcdr 5 attr1) tramp-time-dont-know))
+    (when (time-less-p start-time (nth 5 attr2))
+      (setcar (nthcdr 5 attr2) tramp-time-dont-know))
+    ;; Status change time.  Dito.
+    (when (or (tramp-compat-time-equal-p (nth 6 attr1) tramp-time-dont-know)
+             (tramp-compat-time-equal-p (nth 6 attr2) tramp-time-dont-know))
+      (setcar (nthcdr 6 attr1) tramp-time-dont-know)
+      (setcar (nthcdr 6 attr2) tramp-time-dont-know))
+    (when (time-less-p start-time (nth 6 attr1))
+      (setcar (nthcdr 6 attr1) tramp-time-dont-know))
+    (when (time-less-p start-time (nth 6 attr2))
+      (setcar (nthcdr 6 attr2) tramp-time-dont-know))
+    ;; Size.  Set it to 0 for directories, because it might have
+    ;; changed.  For example the upper directory "../".
+    (when (eq (car attr1) t) (setcar (nthcdr 7 attr1) 0))
+    (when (eq (car attr2) t) (setcar (nthcdr 7 attr2) 0))
+    ;; The check.
+    (equal attr1 attr2)))
 
 ;; This isn't 100% correct, but better than no explainer at all.
 (put #'tramp--test-file-attributes-equal-p 'ert-explainer #'ert--explain-equal)