* bug#71178: Batch ert wrongly aborts a test run, and wrongly fails to say why.
@ 2024-05-24 19:23 Alan Mackenzie
2024-05-26 20:13 ` J.P.
0 siblings, 1 reply; 7+ messages in thread
From: Alan Mackenzie @ 2024-05-24 19:23 UTC (permalink / raw)
To: 71178; +Cc: Stefan Monnier
Hello, Stefan and Emacs.
In my development branch, based on master, last updated ~March 2024.
(i) Build emacs.
(ii) make -j17 check.
The ert session this starts goes well, apart from in
lisp/erc/erc-tests.el. This gets aborted by ert after 62 from 92 tests
have passed. Test 63 fails for known reasons, a mismatch of two strings
compared with `equal'.
The log file, erc-tests.log, looks like this around the output for test
63:
.........................................................
passed 60/92 erc--update-user-modes (0.000093 sec)
passed 61/92 erc--user-modes (0.000053 sec)
passed 62/92 erc--valid-local-channel-p (0.000071 sec)
Test erc--with-dependent-type-match backtrace:
Aborted: Ran 92 tests, 62 results as expected, 1 unexpected (2024-05-24
15:26:55+0000, 2.791555 sec)
1 unexpected results:
FAILED erc--with-dependent-type-match
UNKNOWN erc--with-entrypoint-environment
UNKNOWN erc-channel-p
UNKNOWN erc-channel-user
........................................................
Note that
(i) No error message or backtrace gets printed for test 63. This is a
bug.
(ii) The test run gets aborted. This shouldn't happen, and is a bug.
erc-tests.el runs satisfactorally in an Emacs session, started by M-x
ert, and accepting the default selection t.
--
Alan Mackenzie (Nuremberg, Germany).
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#71178: Batch ert wrongly aborts a test run, and wrongly fails to say why.
2024-05-24 19:23 bug#71178: Batch ert wrongly aborts a test run, and wrongly fails to say why Alan Mackenzie
@ 2024-05-26 20:13 ` J.P.
2024-05-27 15:28 ` Alan Mackenzie
0 siblings, 1 reply; 7+ messages in thread
From: J.P. @ 2024-05-26 20:13 UTC (permalink / raw)
To: Alan Mackenzie; +Cc: Stefan Monnier, 71178
Hi Alan,
Alan Mackenzie <acm@muc.de> writes:
> Hello, Stefan and Emacs.
>
> In my development branch, based on master, last updated ~March 2024.
>
> (i) Build emacs.
> (ii) make -j17 check.
>
> The ert session this starts goes well, apart from in
> lisp/erc/erc-tests.el. This gets aborted by ert after 62 from 92 tests
> have passed. Test 63 fails for known reasons, a mismatch of two strings
> compared with `equal'.
>
> The log file, erc-tests.log, looks like this around the output for test
> 63:
>
> .........................................................
> passed 60/92 erc--update-user-modes (0.000093 sec)
> passed 61/92 erc--user-modes (0.000053 sec)
> passed 62/92 erc--valid-local-channel-p (0.000071 sec)
> Test erc--with-dependent-type-match backtrace:
>
> Aborted: Ran 92 tests, 62 results as expected, 1 unexpected (2024-05-24
> 15:26:55+0000, 2.791555 sec)
>
> 1 unexpected results:
> FAILED erc--with-dependent-type-match
> UNKNOWN erc--with-entrypoint-environment
> UNKNOWN erc-channel-p
> UNKNOWN erc-channel-user
I'm afraid I must claim this as my own handiwork. My apologies.
> ........................................................
>
> Note that
> (i) No error message or backtrace gets printed for test 63. This is a
> bug.
> (ii) The test run gets aborted. This shouldn't happen, and is a bug.
Yes, this is unfortunate.
> erc-tests.el runs satisfactorally in an Emacs session, started by M-x
> ert, and accepting the default selection t.
It seems you have identified the underlying cause:
https://lists.gnu.org/archive/html/emacs-devel/2024-05/msg01140.html
The test itself is of minimal utility and is therefore rubbish (if not
outright vandalism), so I will remove it unless you'd rather it stick
around until the conversation on the list gets going.
Thanks,
J.P.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#71178: Batch ert wrongly aborts a test run, and wrongly fails to say why.
2024-05-26 20:13 ` J.P.
@ 2024-05-27 15:28 ` Alan Mackenzie
2024-05-28 13:33 ` J.P.
0 siblings, 1 reply; 7+ messages in thread
From: Alan Mackenzie @ 2024-05-27 15:28 UTC (permalink / raw)
To: J.P.; +Cc: Stefan Monnier, 71178
Hello, JP.
On Sun, May 26, 2024 at 13:13:43 -0700, J.P. wrote:
> Hi Alan,
> Alan Mackenzie <acm@muc.de> writes:
> > Hello, Stefan and Emacs.
> > In my development branch, based on master, last updated ~March 2024.
> > (i) Build emacs.
> > (ii) make -j17 check.
> > The ert session this starts goes well, apart from in
> > lisp/erc/erc-tests.el. This gets aborted by ert after 62 from 92 tests
> > have passed. Test 63 fails for known reasons, a mismatch of two strings
> > compared with `equal'.
> > The log file, erc-tests.log, looks like this around the output for test
> > 63:
> > .........................................................
> > passed 60/92 erc--update-user-modes (0.000093 sec)
> > passed 61/92 erc--user-modes (0.000053 sec)
> > passed 62/92 erc--valid-local-channel-p (0.000071 sec)
> > Test erc--with-dependent-type-match backtrace:
> > Aborted: Ran 92 tests, 62 results as expected, 1 unexpected (2024-05-24
> > 15:26:55+0000, 2.791555 sec)
> > 1 unexpected results:
> > FAILED erc--with-dependent-type-match
> > UNKNOWN erc--with-entrypoint-environment
> > UNKNOWN erc-channel-p
> > UNKNOWN erc-channel-user
> I'm afraid I must claim this as my own handiwork. My apologies.
Thanks! But I think that erc--restore-initialize-priors has triggered
the error rather than containing the error itself. I don't really think
you should be apologising for this. ;-)
> > ........................................................
> > Note that
> > (i) No error message or backtrace gets printed for test 63. This is a
> > bug.
> > (ii) The test run gets aborted. This shouldn't happen, and is a bug.
> Yes, this is unfortunate.
> > erc-tests.el runs satisfactorally in an Emacs session, started by M-x
> > ert, and accepting the default selection t.
> It seems you have identified the underlying cause:
> https://lists.gnu.org/archive/html/emacs-devel/2024-05/msg01140.html
I've been looking at lisp/emacs-lisp/ert.el, and I think that suppressing
the debug output (or rather, not invoking a backtrace dump in batch mode)
is where the problem lies. However, when I enabled these in my own copy,
they produced an erc.log of over 100 MB. But that was in my customised
Emacs where I've changed quite a few things always to get a complete
backtrace. So I'm not sure what is best, here.
> The test itself is of minimal utility and is therefore rubbish (if not
> outright vandalism), so I will remove it unless you'd rather it stick
> around until the conversation on the list gets going.
I think I'd rather the test should stay there a bit longer. It
highlights problems in pcase.el and ert.el which might get fixed sooner
if the test is still there. _MIGHT_ (here's hoping!).
> Thanks,
> J.P.
--
Alan Mackenzie (Nuremberg, Germany).
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#71178: Batch ert wrongly aborts a test run, and wrongly fails to say why.
2024-05-27 15:28 ` Alan Mackenzie
@ 2024-05-28 13:33 ` J.P.
2024-06-05 22:13 ` J.P.
0 siblings, 1 reply; 7+ messages in thread
From: J.P. @ 2024-05-28 13:33 UTC (permalink / raw)
To: Alan Mackenzie; +Cc: Stefan Monnier, 71178
Hi Alan,
Alan Mackenzie <acm@muc.de> writes:
>> It seems you have identified the underlying cause:
>
>> https://lists.gnu.org/archive/html/emacs-devel/2024-05/msg01140.html
>
> I've been looking at lisp/emacs-lisp/ert.el, and I think that suppressing
> the debug output (or rather, not invoking a backtrace dump in batch mode)
> is where the problem lies. However, when I enabled these in my own copy,
> they produced an erc.log of over 100 MB. But that was in my customised
> Emacs where I've changed quite a few things always to get a complete
> backtrace. So I'm not sure what is best, here.
I too have bumped into failures that don't produce a backtrace, at least
in recent versions. However, the ones I typically see look more like:
Error in process sentinel
Make[3] *** [Makefile:184 lisp/erc/erc-*.log] Error 255
...
1 files did not finish:
lisp/erc/erc-*.log
Make *** [Makefile:266 check-lisp-erc] Error 2
With these, it seems debug output is being intentionally suppressed on
account of the error originating from some process sentinel or timer.
And when I enable `debug-on-error', a backtrace appears as expected.
This leads me to assume such occurrences are somewhat unrelated to what
you're experiencing. That said, I'm fairly convinced I've encountered
the odd mystery failure with no specified error. And the "aborted" line
in your excerpt does look familiar. Sadly, though, I cannot reliably
reproduce anything similar (yet).
>> The test itself is of minimal utility and is therefore rubbish (if not
>> outright vandalism), so I will remove it unless you'd rather it stick
>> around until the conversation on the list gets going.
>
> I think I'd rather the test should stay there a bit longer. It
> highlights problems in pcase.el and ert.el which might get fixed sooner
> if the test is still there. _MIGHT_ (here's hoping!).
Good point. I've added a FIXME to remind myself or some future person to
delete the test once things have settled.
Cheers,
J.P.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#71178: Batch ert wrongly aborts a test run, and wrongly fails to say why.
2024-05-28 13:33 ` J.P.
@ 2024-06-05 22:13 ` J.P.
2024-10-28 18:10 ` Alan Mackenzie
0 siblings, 1 reply; 7+ messages in thread
From: J.P. @ 2024-06-05 22:13 UTC (permalink / raw)
To: Alan Mackenzie; +Cc: Stefan Monnier, 71178
"J.P." <jp@neverwas.me> writes:
>> I think I'd rather the test should stay there a bit longer. It
>> highlights problems in pcase.el and ert.el which might get fixed sooner
>> if the test is still there. _MIGHT_ (here's hoping!).
>
> Good point. I've added a FIXME to remind myself or some future person to
> delete the test once things have settled.
The issue of the large pcase expansion appears to have been addressed by
16fc5b6c0c7 * pcase.el (\`): Try and handle large patterns better
I have therefore deleted the offending test.
I'm leaving this bug open because its main concern is the absence of
adequate reporting under certain failure conditions. Thanks.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#71178: Batch ert wrongly aborts a test run, and wrongly fails to say why.
2024-06-05 22:13 ` J.P.
@ 2024-10-28 18:10 ` Alan Mackenzie
2024-10-28 18:20 ` J.P.
0 siblings, 1 reply; 7+ messages in thread
From: Alan Mackenzie @ 2024-10-28 18:10 UTC (permalink / raw)
To: J.P.; +Cc: acm, Stefan Monnier, 71178
Hello, J.P.
On Wed, Jun 05, 2024 at 15:13:29 -0700, J.P. wrote:
> "J.P." <jp@neverwas.me> writes:
> >> I think I'd rather the test should stay there a bit longer. It
> >> highlights problems in pcase.el and ert.el which might get fixed sooner
> >> if the test is still there. _MIGHT_ (here's hoping!).
> > Good point. I've added a FIXME to remind myself or some future person to
> > delete the test once things have settled.
> The issue of the large pcase expansion appears to have been addressed by
> 16fc5b6c0c7 * pcase.el (\`): Try and handle large patterns better
> I have therefore deleted the offending test.
> I'm leaving this bug open because its main concern is the absence of
> adequate reporting under certain failure conditions. Thanks.
Back in the springtime, I identified the cause of my particular bug,
namely the backtrace function trying to print a copy of the too big
structure which triggered the bug in the first place. This led to a
recursive error signalling.
Stefan Monnier amended pcase earlier on this year better to handle "big"
structures, and I think you deleted the ert test which triggered the
bug anyway.
The circumstances which triggered this bug don't seem to have occurred
in the last few months. So it seems it is now time to close this bug.
Would you have anything against me closing it as "won't fix"?
Thanks!
--
Alan Mackenzie (Nuremberg, Germany).
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#71178: Batch ert wrongly aborts a test run, and wrongly fails to say why.
2024-10-28 18:10 ` Alan Mackenzie
@ 2024-10-28 18:20 ` J.P.
0 siblings, 0 replies; 7+ messages in thread
From: J.P. @ 2024-10-28 18:20 UTC (permalink / raw)
To: Alan Mackenzie; +Cc: Stefan Monnier, 71178
Alan Mackenzie <acm@muc.de> writes:
> Stefan Monnier amended pcase earlier on this year better to handle "big"
> structures, and I think you deleted the ert test which triggered the
> bug anyway.
Right, I did indeed.
>
> The circumstances which triggered this bug don't seem to have occurred
> in the last few months.
That's great to hear.
> So it seems it is now time to close this bug. Would you have anything
> against me closing it as "won't fix"?
Not at all. Makes sense to me. Cheers.
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2024-10-28 18:20 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-05-24 19:23 bug#71178: Batch ert wrongly aborts a test run, and wrongly fails to say why Alan Mackenzie
2024-05-26 20:13 ` J.P.
2024-05-27 15:28 ` Alan Mackenzie
2024-05-28 13:33 ` J.P.
2024-06-05 22:13 ` J.P.
2024-10-28 18:10 ` Alan Mackenzie
2024-10-28 18:20 ` J.P.
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.