Skip to content

Commit

Permalink
u-u: import "email.genators" package early as workaround
Browse files Browse the repository at this point in the history
This commit works around an issue when python itself is upgraded
by u-u and the content of email.message now needs a newer email.errors
but u-u already (implicitely) loaded that module so there is a
old version in sys.modules. So instead import email.generators early
so that it is available in memory and there is no mismatch.

See python/cpython#124170 and
https://bugs.launchpad.net/ubuntu/+source/python3.8/+bug/2080940
for details.

Unfortunately while this commit fixes the autopkgtest failure that
is now triggered by this the real issue that the users see is not
fixed because the "old" unattended-upgrades will perform the upgrade
and it will upgrade both the problematic python and the fixed u-u
but because u-u does not re-exec the "old" u-u still runs and the
fixed code from u-u will not be used.

Thanks to Julian Klode for his excellent analysis.
  • Loading branch information
mvo5 committed Nov 10, 2024
1 parent edb2f8b commit ca9c9e0
Showing 1 changed file with 3 additions and 0 deletions.
3 changes: 3 additions & 0 deletions unattended-upgrade
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,9 @@ import copy
import datetime
import errno
import email.charset
# workaround LP:2080940, email.errors changes as part of a security
# update in python itself but is lazy loaded so import early to ensure
import email.generator
import fcntl
import fnmatch
import gettext
Expand Down

0 comments on commit ca9c9e0

Please sign in to comment.