* bug#29223: 26.0.90; [Regression][Emacs26] Problem in network stack
@ 2017-11-09 5:16 Damien Cassou
2017-11-09 5:32 ` Paul Eggert
0 siblings, 1 reply; 4+ messages in thread
From: Damien Cassou @ 2017-11-09 5:16 UTC (permalink / raw)
To: 29223; +Cc: Nicolas Petton, Paul Eggert
[-- Attachment #1: Type: text/plain, Size: 4939 bytes --]
The commit "Avoid unnecessary rounding errors in timestamps" (3aee7b)
introduces a regression in the network stack. This can be seen while
using org-caldav and I managed to reproduce with emacs -Q (see attached
files).
Among the attached files, script.el is of the most importance. The first
call to `contact-server' works fine whereas the second triggers a
server-side error: 503 Service Unavailable. Unfortunately, you can't
directly reuse this script as it depends on a personal nextcloud
instance.
Reverting the commit fixes the bug. I added its author on CC.
commit 3aee7be62eaf8caef6f2fab31bee79674b3abbb7
Author: Paul Eggert <eggert@cs.ucla.edu>
Date: Sun Oct 22 01:04:36 2017 -0700
Avoid unnecessary rounding errors in timestamps
Avoid the rounding errors of float-time when it’s easy. E.g.,
replace (< (float-time a) (float-time b)) with (time-less-p a b).
* lisp/desktop.el (desktop-save):
* lisp/ecomplete.el (ecomplete-add-item):
* lisp/epg.el (epg-wait-for-completion):
* lisp/files.el (dir-locals-find-file, dir-locals-read-from-dir):
* lisp/image-dired.el (image-dired-get-thumbnail-image)
(image-dired-create-thumb-1):
* lisp/info.el (info-insert-file-contents):
* lisp/ls-lisp.el (ls-lisp-format-time):
* lisp/net/ange-ftp.el (ange-ftp-file-newer-than-file-p)
(ange-ftp-verify-visited-file-modtime):
* lisp/net/rcirc.el (rcirc-ctcp-sender-PING):
* lisp/textmodes/remember.el (remember-store-in-mailbox):
* lisp/url/url-cookie.el (url-cookie-expired-p):
Bypass float-time to avoid rounding errors.
* lisp/files.el (dir-locals-find-file):
In GNU Emacs 26.0.90 (build 1, x86_64-pc-linux-gnu, GTK+ Version 3.22.21)
of 2017-11-09 built on luz4
Repository revision: b23adf48bfe03332f508f088265a0c8162747cae
Windowing system distributor 'Fedora Project', version 11.0.11903000
System Description: Fedora release 26 (Twenty Six)
Recent messages:
For information about GNU Emacs and the GNU system, type C-h C-a.
Configured using:
'configure --cache-file=/tmp/emacs.config.cache'
Configured features:
XPM JPEG TIFF GIF PNG RSVG IMAGEMAGICK SOUND GPM DBUS GSETTINGS NOTIFY
ACL LIBSELINUX GNUTLS LIBXML2 FREETYPE M17N_FLT LIBOTF XFT ZLIB
TOOLKIT_SCROLL_BARS GTK3 X11 LIBSYSTEMD LCMS2
Important settings:
value of $LC_MONETARY: fr_FR.UTF-8
value of $LC_NUMERIC: fr_FR.UTF-8
value of $LC_TIME: fr_FR.UTF-8
value of $LANG: en_US.UTF-8
value of $XMODIFIERS: @im=ibus
locale-coding-system: utf-8-unix
Major mode: Lisp Interaction
Minor modes in effect:
tooltip-mode: t
global-eldoc-mode: t
eldoc-mode: t
electric-indent-mode: t
mouse-wheel-mode: t
tool-bar-mode: t
menu-bar-mode: t
file-name-shadow-mode: t
global-font-lock-mode: t
font-lock-mode: t
blink-cursor-mode: t
auto-composition-mode: t
auto-encryption-mode: t
auto-compression-mode: t
line-number-mode: t
transient-mark-mode: t
Load-path shadows:
None found.
Features:
(shadow sort mail-extr emacsbug message rmc puny seq byte-opt gv
bytecomp byte-compile cconv cl-loaddefs cl-lib dired dired-loaddefs
format-spec rfc822 mml easymenu mml-sec password-cache epa derived epg
epg-config gnus-util rmail rmail-loaddefs mm-decode mm-bodies mm-encode
mail-parse rfc2231 mailabbrev gmm-utils mailheader sendmail rfc2047
rfc2045 ietf-drums mm-util mail-prsvr mail-utils elec-pair time-date
mule-util tooltip eldoc electric uniquify ediff-hook vc-hooks
lisp-float-type mwheel term/x-win x-win term/common-win x-dnd tool-bar
dnd fontset image regexp-opt fringe tabulated-list replace newcomment
text-mode elisp-mode lisp-mode prog-mode register page menu-bar
rfn-eshadow isearch timer select scroll-bar mouse jit-lock font-lock
syntax facemenu font-core term/tty-colors frame cl-generic cham georgian
utf-8-lang misc-lang vietnamese tibetan thai tai-viet lao korean
japanese eucjp-ms cp51932 hebrew greek romanian slovak czech european
ethiopic indian cyrillic chinese composite charscript charprop
case-table epa-hook jka-cmpr-hook help simple abbrev obarray minibuffer
cl-preloaded nadvice loaddefs button faces cus-face macroexp files
text-properties overlay sha1 md5 base64 format env code-pages mule
custom widget hashtable-print-readable backquote dbusbind inotify lcms2
dynamic-setting system-font-setting font-render-setting move-toolbar gtk
x-toolkit x multi-tty make-network-process emacs)
Memory information:
((conses 16 94504 6564)
(symbols 48 20339 1)
(miscs 40 45 119)
(strings 32 28291 1407)
(string-bytes 1 748828)
(vectors 16 13964)
(vector-slots 8 492182 6318)
(floats 8 49 68)
(intervals 56 224 0)
(buffers 992 12))
--
Damien Cassou
http://damiencassou.seasidehosting.st
"Success is the ability to go from one failure to another without
losing enthusiasm." --Winston Churchill
[-- Attachment #2: bisect.log --]
[-- Type: text/plain, Size: 2354 bytes --]
git bisect start
# good: [da62c1532e479bbac4ce242ee1d170df9c435591] Improve the documentation of filesets
git bisect good da62c1532e479bbac4ce242ee1d170df9c435591
# bad: [255ba01148f69f452937e67feb7af5d4c1466fed] Fix handling of nil PRED2 arg for completion-table-with-predicate
git bisect bad 255ba01148f69f452937e67feb7af5d4c1466fed
# good: [fd42a19260841a2e3c39fd983c7601a3f517bf4b] When opening new eww buffers, use buffer names based on the host name
git bisect good fd42a19260841a2e3c39fd983c7601a3f517bf4b
# good: [65b323e14e09fa6024fee93fd484deea4b7f51a2] Don't put deleted packages in the trash (bug#14967)
git bisect good 65b323e14e09fa6024fee93fd484deea4b7f51a2
# good: [bf0045d7a4cd4c7d4df3fa34b8a12795e8ee73aa] Avoid aborting in 'waitpid' on MS-Windows
git bisect good bf0045d7a4cd4c7d4df3fa34b8a12795e8ee73aa
# good: [1c30f9fc08649649676ed812f1579f0948558ceb] Flymake diagnostics now apply to arbitrary buffer regions
git bisect good 1c30f9fc08649649676ed812f1579f0948558ceb
# good: [dc8812829b81540d385eaa5577fa31397a8181d3] Remove resizable attribute on macOS undecorated frames (bug#28512)
git bisect good dc8812829b81540d385eaa5577fa31397a8181d3
# bad: [82a16c547bc32fda6073c97b6c8989b473f0315b] Fix some duplicate word typos
git bisect bad 82a16c547bc32fda6073c97b6c8989b473f0315b
# bad: [b51009d7f02b796bcdf9b0893bc4ad348460e844] * admin/authors.el (authors-canonical-author-name): Ignore name issues in "lax" ChangeLogs.
git bisect bad b51009d7f02b796bcdf9b0893bc4ad348460e844
# good: [4587d8e0ef3302e9a2d99e2981897537eb320168] Document 'minibuffer-with-setup-hook'
git bisect good 4587d8e0ef3302e9a2d99e2981897537eb320168
# good: [237e96bc5259e59ac5623a93a47f64abffab4e0b] Test that advice doesn't trigger bytecomp warnings (Bug#28803)
git bisect good 237e96bc5259e59ac5623a93a47f64abffab4e0b
# bad: [6360611457a39292e11980bb522a14a5c9a58716] Port to OpenIndiana
git bisect bad 6360611457a39292e11980bb522a14a5c9a58716
# bad: [3aee7be62eaf8caef6f2fab31bee79674b3abbb7] Avoid unnecessary rounding errors in timestamps
git bisect bad 3aee7be62eaf8caef6f2fab31bee79674b3abbb7
# good: [2bfa42855bf0278497f2e4540eac2086dab254c3] Fix xdg timestamp error on 32-bit Emacs
git bisect good 2bfa42855bf0278497f2e4540eac2086dab254c3
# first bad commit: [3aee7be62eaf8caef6f2fab31bee79674b3abbb7] Avoid unnecessary rounding errors in timestamps
[-- Attachment #3: script.el --]
[-- Type: text/plain, Size: 1212 bytes --]
(defun contact-server ()
"Contact server."
(let* ((username "damien")
(password "the password")
(authorization (format "Basic %s" (base64-encode-string (format "%s:%s" username password))))
(url "https://damien@some-nextcloud.foo/personal")
(url-request-method "OPTIONS")
(url-request-data nil)
(url-request-extra-headers `(("Authorization" . ,authorization)))
(buffer (url-retrieve-synchronously url)))
(with-current-buffer buffer
(goto-char (point-min))
(when (not (re-search-forward "^HTTP[^ ]* \\([0-9]+ .*\\)$"
(point-at-eol) t))
(user-error "No valid HTTP response from URL %s" url))
(let ((response (match-string 1)))
(when (not (string-match "2[0-9][0-9].*" response))
(user-error "Error while checking for OPTIONS at URL %s: %s" url response)))
(mail-narrow-to-head)
(let ((davheader (mail-fetch-field "dav")))
(when (not davheader)
(user-error "The URL %s does not accept DAV requests" url)))
(message "Success contacting server"))))
(progn
(message "Contacting server (1/2)")
(contact-server)
(message "Contacting server (2/2)")
(contact-server))
[-- Attachment #4: script.sh --]
[-- Type: application/x-sh, Size: 224 bytes --]
^ permalink raw reply [flat|nested] 4+ messages in thread
* bug#29223: 26.0.90; [Regression][Emacs26] Problem in network stack
2017-11-09 5:16 bug#29223: 26.0.90; [Regression][Emacs26] Problem in network stack Damien Cassou
@ 2017-11-09 5:32 ` Paul Eggert
2017-11-09 6:30 ` Damien Cassou
0 siblings, 1 reply; 4+ messages in thread
From: Paul Eggert @ 2017-11-09 5:32 UTC (permalink / raw)
To: damien, 29223; +Cc: Nicolas Petton
[-- Attachment #1: Type: text/plain, Size: 116 bytes --]
Thanks for reporting the problem. I installed the attached patch into the
emacs-26 branch; please give it a try.
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-Fix-URL-cookie-expiration-bug.patch --]
[-- Type: text/x-patch; name="0001-Fix-URL-cookie-expiration-bug.patch", Size: 973 bytes --]
From 781f276cc12a204ec7db9ffd30d22a9a18c0fe94 Mon Sep 17 00:00:00 2001
From: Paul Eggert <eggert@cs.ucla.edu>
Date: Wed, 8 Nov 2017 21:30:26 -0800
Subject: [PATCH] Fix URL cookie expiration bug
Problem reported by Damien Cassou (Bug#29223).
* lisp/url/url-cookie.el (url-cookie-expired-p):
Fix typo in previous change, which caused unexpired cookies
to be treated as expired and vice versa.
---
lisp/url/url-cookie.el | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/lisp/url/url-cookie.el b/lisp/url/url-cookie.el
index 28dfced..d922033 100644
--- a/lisp/url/url-cookie.el
+++ b/lisp/url/url-cookie.el
@@ -161,7 +161,7 @@ url-cookie-expired-p
(let ((exp (url-cookie-expires cookie)))
(and (> (length exp) 0)
(condition-case ()
- (time-less-p nil (date-to-time exp))
+ (time-less-p (date-to-time exp) nil)
(error nil)))))
(defun url-cookie-retrieve (host &optional localpart secure)
--
2.7.4
^ permalink raw reply related [flat|nested] 4+ messages in thread
* bug#29223: 26.0.90; [Regression][Emacs26] Problem in network stack
2017-11-09 5:32 ` Paul Eggert
@ 2017-11-09 6:30 ` Damien Cassou
2017-11-09 6:45 ` Paul Eggert
0 siblings, 1 reply; 4+ messages in thread
From: Damien Cassou @ 2017-11-09 6:30 UTC (permalink / raw)
To: eggert, 29223; +Cc: Nicolas Petton
Paul Eggert <eggert@cs.ucla.edu> writes:
> Thanks for reporting the problem. I installed the attached patch into the
> emacs-26 branch; please give it a try.
this fixes my problem! That was fast!
Thank you very much.
--
Damien Cassou
http://damiencassou.seasidehosting.st
"Success is the ability to go from one failure to another without
losing enthusiasm." --Winston Churchill
^ permalink raw reply [flat|nested] 4+ messages in thread
* bug#29223: 26.0.90; [Regression][Emacs26] Problem in network stack
2017-11-09 6:30 ` Damien Cassou
@ 2017-11-09 6:45 ` Paul Eggert
0 siblings, 0 replies; 4+ messages in thread
From: Paul Eggert @ 2017-11-09 6:45 UTC (permalink / raw)
To: Damien Cassou, 29223-done; +Cc: Nicolas Petton
Damien Cassou wrote:
> this fixes my problem! That was fast!
Thanks for checking; closing the bug report.
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2017-11-09 6:45 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-11-09 5:16 bug#29223: 26.0.90; [Regression][Emacs26] Problem in network stack Damien Cassou
2017-11-09 5:32 ` Paul Eggert
2017-11-09 6:30 ` Damien Cassou
2017-11-09 6:45 ` Paul Eggert
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).