diff options
| author | Aurélien Bompard | 2015-02-20 16:42:40 +0100 |
|---|---|---|
| committer | Aurélien Bompard | 2015-02-20 16:42:40 +0100 |
| commit | ab75b8cfa107a1fd22d3ccd7311bd3a9135189e9 (patch) | |
| tree | f382807e798238c50d7e788518a354f4150c0bdc | |
| parent | 68c6596d7d280be39809f958a4ceac430e324cd6 (diff) | |
| download | mailman-ab75b8cfa107a1fd22d3ccd7311bd3a9135189e9.tar.gz mailman-ab75b8cfa107a1fd22d3ccd7311bd3a9135189e9.tar.zst mailman-ab75b8cfa107a1fd22d3ccd7311bd3a9135189e9.zip | |
| -rw-r--r-- | src/mailman/commands/cli_import.py | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/src/mailman/commands/cli_import.py b/src/mailman/commands/cli_import.py index 30aeb7894..50d4f1864 100644 --- a/src/mailman/commands/cli_import.py +++ b/src/mailman/commands/cli_import.py @@ -35,6 +35,14 @@ from zope.interface import implementer +# Mock the Bouncer class from Mailman 2.1, we don't use it but there are +# instances in the pickled config files +class Bouncer: + class _BounceInfo: + pass + + + @implementer(ICLISubCommand) class Import21: """Import Mailman 2.1 list data.""" @@ -74,10 +82,11 @@ class Import21: assert len(args.pickle_file) == 1, ( 'Unexpected positional arguments: %s' % args.pickle_file) filename = args.pickle_file[0] + sys.modules["Mailman.Bouncer"] = Bouncer with open(filename, 'rb') as fp: while True: try: - config_dict = pickle.load(fp) + config_dict = pickle.load(fp, encoding="utf-8", errors="ignore") except EOFError: break except pickle.UnpicklingError: @@ -94,3 +103,4 @@ class Import21: except Import21Error as error: print(error, file=sys.stderr) sys.exit(1) + del sys.modules["Mailman.Bouncer"] |
