Port to Python 3.
This commit is contained in:
parent
66f53fada8
commit
a2280b7660
|
@ -1,6 +1,15 @@
|
||||||
|
"""
|
||||||
|
Ported to Python 3.
|
||||||
|
"""
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
from __future__ import absolute_import
|
||||||
|
from __future__ import division
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
|
|
||||||
from past.builtins import unicode
|
from future.utils import PY2
|
||||||
|
if PY2:
|
||||||
|
from future.builtins import filter, map, zip, ascii, chr, hex, input, next, oct, open, pow, round, super, bytes, dict, list, object, range, str, max, min # noqa: F401
|
||||||
|
|
||||||
|
|
||||||
import os.path, re, fnmatch
|
import os.path, re, fnmatch
|
||||||
|
|
||||||
|
@ -38,7 +47,7 @@ class FileStoreOptions(BaseOptions):
|
||||||
|
|
||||||
# compute a node-url from the existing options, put in self['node-url']
|
# compute a node-url from the existing options, put in self['node-url']
|
||||||
if self['node-url']:
|
if self['node-url']:
|
||||||
if (not isinstance(self['node-url'], (bytes, unicode))
|
if (not isinstance(self['node-url'], (bytes, str))
|
||||||
or not NODEURL_RE.match(self['node-url'])):
|
or not NODEURL_RE.match(self['node-url'])):
|
||||||
msg = ("--node-url is required to be a string and look like "
|
msg = ("--node-url is required to be a string and look like "
|
||||||
"\"http://HOSTNAMEORADDR:PORT\", not: %r" %
|
"\"http://HOSTNAMEORADDR:PORT\", not: %r" %
|
||||||
|
@ -354,8 +363,9 @@ class BackupOptions(FileStoreOptions):
|
||||||
abs_filepath = argv_to_abspath(filepath)
|
abs_filepath = argv_to_abspath(filepath)
|
||||||
try:
|
try:
|
||||||
exclude_file = open(abs_filepath)
|
exclude_file = open(abs_filepath)
|
||||||
except:
|
except Exception as e:
|
||||||
raise BackupConfigurationError('Error opening exclude file %s.' % quote_local_unicode_path(abs_filepath))
|
raise BackupConfigurationError('Error opening exclude file %s. (Error: %s)' % (
|
||||||
|
quote_local_unicode_path(abs_filepath), e))
|
||||||
try:
|
try:
|
||||||
for line in exclude_file:
|
for line in exclude_file:
|
||||||
self.opt_exclude(line)
|
self.opt_exclude(line)
|
||||||
|
|
|
@ -9,9 +9,7 @@ from __future__ import unicode_literals
|
||||||
from future.utils import PY2
|
from future.utils import PY2
|
||||||
if PY2:
|
if PY2:
|
||||||
from future.builtins import filter, map, zip, ascii, chr, hex, input, next, oct, open, pow, round, super, bytes, dict, list, object, range, str, max, min # noqa: F401
|
from future.builtins import filter, map, zip, ascii, chr, hex, input, next, oct, open, pow, round, super, bytes, dict, list, object, range, str, max, min # noqa: F401
|
||||||
import __builtin__ as builtins
|
|
||||||
else:
|
|
||||||
import builtins
|
|
||||||
|
|
||||||
import os.path
|
import os.path
|
||||||
from six.moves import cStringIO as StringIO
|
from six.moves import cStringIO as StringIO
|
||||||
|
@ -430,7 +428,11 @@ class Backup(GridTestMixin, CLITestMixin, StallMixin, unittest.TestCase):
|
||||||
else:
|
else:
|
||||||
return original_open(name, *args)
|
return original_open(name, *args)
|
||||||
|
|
||||||
patcher = MonkeyPatcher((builtins, 'open', call_file))
|
if PY2:
|
||||||
|
from allmydata.scripts import cli as module_to_patch
|
||||||
|
else:
|
||||||
|
import builtins as module_to_patch
|
||||||
|
patcher = MonkeyPatcher((module_to_patch, 'open', call_file))
|
||||||
patcher.runWithPatches(parse_options, basedir, "backup", ['--exclude-from', unicode_to_argv(exclude_file), 'from', 'to'])
|
patcher.runWithPatches(parse_options, basedir, "backup", ['--exclude-from', unicode_to_argv(exclude_file), 'from', 'to'])
|
||||||
self.failUnless(ns.called)
|
self.failUnless(ns.called)
|
||||||
|
|
||||||
|
|
|
@ -89,7 +89,8 @@ PORTED_MODULES = [
|
||||||
"allmydata.nodemaker",
|
"allmydata.nodemaker",
|
||||||
"allmydata.scripts",
|
"allmydata.scripts",
|
||||||
"allmydata.scripts.admin",
|
"allmydata.scripts.admin",
|
||||||
"allmydata.scripts.backupdb",
|
"allmydata.scripts.backupdb"
|
||||||
|
"allmydata.scripts.cli",
|
||||||
"allmydata.scripts.create_node",
|
"allmydata.scripts.create_node",
|
||||||
"allmydata.scripts.runner",
|
"allmydata.scripts.runner",
|
||||||
"allmydata.scripts.types_",
|
"allmydata.scripts.types_",
|
||||||
|
|
Loading…
Reference in New Issue