#14471: Exception KeyError: in WeakValueDictionary remove ignored
---------------------------+------------------------------------------------
Reporter: vbraun | Owner: rlm
Type: defect | Status: new
Priority: major | Milestone: sage-5.10
Component: memleak | Resolution:
Keywords: | Work issues:
Report Upstream: N/A | Reviewers:
Authors: | Merged in:
Dependencies: | Stopgaps:
---------------------------+------------------------------------------------
Description changed by vbraun:
Old description:
> Under some circumstances the !WeakValueDictionary remove callback is
> being called when the internal dictionary is in a bad state. The attached
> patch to demonstrate the issue just calls `hasattr` from the displayhook,
> which ends up generating weak references somewhere. The exact place for
> where the exception occurs depends on the garbage collector, but I always
> do get some unwanted exceptions with it.
> {{{
> sage -t devel/sage/sage/matrix/matrix0.pyx
> Exception KeyError: (((<class 'sage.matrix.matrix_space.MatrixSpace'>,
> Callable function ring with arguments (x, y), 2, 2, False), ()),) in
> <function remove at 0x18d8758> ignored
> **********************************************************************
> File "devel/sage/sage/matrix/matrix0.pyx", line 3370, in
> sage.matrix.matrix0.Matrix.is_hermitian
> Failed example:
> B.is_hermitian()
> Expected:
> True
> Got:
> Exception KeyError: (((<class 'sage.categories.algebras.Algebras'>,
> Callable function ring with arguments (x, y)), ()),) in <function remove
> at 0x18d8758> ignored
> True
> }}}
New description:
Under some circumstances the !WeakValueDictionary remove callback is being
called when the internal dictionary is in a bad state. The attached patch
[attachment:trac_14471_demonstrate.patch] to demonstrate the issue just
calls `hasattr` from the displayhook, which ends up generating weak
references somewhere. The exact place for where the exception occurs
depends on the garbage collector, but I always do get some unwanted
exceptions with it.
{{{
sage -t devel/sage/sage/matrix/matrix0.pyx
Exception KeyError: (((<class 'sage.matrix.matrix_space.MatrixSpace'>,
Callable function ring with arguments (x, y), 2, 2, False), ()),) in
<function remove at 0x18d8758> ignored
**********************************************************************
File "devel/sage/sage/matrix/matrix0.pyx", line 3370, in
sage.matrix.matrix0.Matrix.is_hermitian
Failed example:
B.is_hermitian()
Expected:
True
Got:
Exception KeyError: (((<class 'sage.categories.algebras.Algebras'>,
Callable function ring with arguments (x, y)), ()),) in <function remove
at 0x18d8758> ignored
True
}}}
--
--
Ticket URL: <http://trac.sagemath.org/sage_trac/ticket/14471#comment:1>
Sage <http://www.sagemath.org>
Sage: Creating a Viable Open Source Alternative to Magma, Maple, Mathematica,
and MATLAB
--
You received this message because you are subscribed to the Google Groups
"sage-trac" group.
To unsubscribe from this group and stop receiving emails from it, send an email
to [email protected].
To post to this group, send email to [email protected].
Visit this group at http://groups.google.com/group/sage-trac?hl=en.
For more options, visit https://groups.google.com/groups/opt_out.