mirror of
https://github.com/tahoe-lafs/tahoe-lafs.git
synced 2025-04-04 01:19:14 +00:00
Tests pass on Python 3.
This commit is contained in:
parent
f1128bfd2e
commit
c275f9ae54
@ -64,13 +64,14 @@ def list(options):
|
||||
print(quote_output(data, quotemarks=False), file=stderr)
|
||||
return 1
|
||||
|
||||
path = unicode(path, "utf-8")
|
||||
nodetype, d = parsed
|
||||
children = {}
|
||||
if nodetype == "dirnode":
|
||||
children = d['children']
|
||||
else:
|
||||
# paths returned from get_alias are always valid UTF-8
|
||||
childname = path.split("/")[-1].decode('utf-8')
|
||||
childname = path.split("/")[-1]
|
||||
children = {childname: (nodetype, d)}
|
||||
if "metadata" not in d:
|
||||
d["metadata"] = {}
|
||||
|
@ -1,3 +1,6 @@
|
||||
from future.utils import PY3
|
||||
from past.builtins import unicode
|
||||
|
||||
from twisted.trial import unittest
|
||||
from twisted.internet import defer
|
||||
|
||||
@ -8,30 +11,26 @@ from ..no_network import GridTestMixin
|
||||
from allmydata.util.encodingutil import quote_output, get_io_encoding
|
||||
from .common import CLITestMixin
|
||||
|
||||
|
||||
class List(GridTestMixin, CLITestMixin, unittest.TestCase):
|
||||
def test_list(self):
|
||||
self.basedir = "cli/List/list"
|
||||
self.set_up_grid()
|
||||
c0 = self.g.clients[0]
|
||||
small = "small"
|
||||
small = b"small"
|
||||
|
||||
# u"g\u00F6\u00F6d" might not be representable in the argv and/or output encodings.
|
||||
# It is initially included in the directory in any case.
|
||||
try:
|
||||
good_arg = u"g\u00F6\u00F6d".encode(get_io_encoding())
|
||||
except UnicodeEncodeError:
|
||||
good_arg = None
|
||||
good_arg = u"g\u00F6\u00F6d"
|
||||
good_out = u"g\u00F6\u00F6d"
|
||||
|
||||
try:
|
||||
good_out = u"g\u00F6\u00F6d".encode(get_io_encoding())
|
||||
except UnicodeEncodeError:
|
||||
good_out = None
|
||||
# On Python 2 we get bytes, so we need encoded version. On Python 3
|
||||
# stdio is unicode so can leave unchanged.
|
||||
good_out_encoded = good_out if PY3 else good_out.encode(get_io_encoding())
|
||||
|
||||
d = c0.create_dirnode()
|
||||
def _stash_root_and_create_file(n):
|
||||
self.rootnode = n
|
||||
self.rooturi = n.get_uri()
|
||||
return n.add_file(u"g\u00F6\u00F6d", upload.Data(small, convergence=""))
|
||||
self.rooturi = unicode(n.get_uri(), "utf-8")
|
||||
return n.add_file(u"g\u00F6\u00F6d", upload.Data(small, convergence=b""))
|
||||
d.addCallback(_stash_root_and_create_file)
|
||||
def _stash_goodcap(n):
|
||||
self.goodcap = n.get_uri()
|
||||
@ -47,15 +46,10 @@ class List(GridTestMixin, CLITestMixin, unittest.TestCase):
|
||||
d.addCallback(lambda ign: self.do_cli("ls"))
|
||||
def _check1(args):
|
||||
(rc, out, err) = args
|
||||
if good_out is None:
|
||||
self.failUnlessReallyEqual(rc, 1)
|
||||
self.failUnlessIn("files whose names could not be converted", err)
|
||||
self.failUnlessIn(quote_output(u"g\u00F6\u00F6d"), err)
|
||||
self.failUnlessReallyEqual(sorted(out.splitlines()), sorted(["0share", "1share"]))
|
||||
else:
|
||||
self.failUnlessReallyEqual(rc, 0)
|
||||
self.failUnlessReallyEqual(err, "")
|
||||
self.failUnlessReallyEqual(sorted(out.splitlines()), sorted(["0share", "1share", good_out]))
|
||||
self.failUnlessReallyEqual(rc, 0)
|
||||
self.assertEqual(len(err), 0, err)
|
||||
self.failUnlessReallyEqual(sorted(out.splitlines()),
|
||||
sorted(["0share", "1share", good_out_encoded]))
|
||||
d.addCallback(_check1)
|
||||
d.addCallback(lambda ign: self.do_cli("ls", "missing"))
|
||||
def _check2(args):
|
||||
@ -87,7 +81,7 @@ class List(GridTestMixin, CLITestMixin, unittest.TestCase):
|
||||
# listing a file (as dir/filename) should have the edge metadata,
|
||||
# including the filename
|
||||
self.failUnlessReallyEqual(rc, 0)
|
||||
self.failUnlessIn(good_out, out)
|
||||
self.failUnlessIn(good_out_encoded, out)
|
||||
self.failIfIn("-r-- %d -" % len(small), out,
|
||||
"trailing hyphen means unknown date")
|
||||
|
||||
@ -139,7 +133,7 @@ class List(GridTestMixin, CLITestMixin, unittest.TestCase):
|
||||
d.addCallback(lambda ign: self.do_cli("ls", "-l", self.rooturi + ":./good"))
|
||||
d.addCallback(_check4_ascii)
|
||||
|
||||
unknown_immcap = "imm.URI:unknown"
|
||||
unknown_immcap = b"imm.URI:unknown"
|
||||
def _create_unknown(ign):
|
||||
nm = c0.nodemaker
|
||||
kids = {u"unknownchild-imm": (nm.create_from_cap(unknown_immcap), {})}
|
||||
@ -226,8 +220,8 @@ class List(GridTestMixin, CLITestMixin, unittest.TestCase):
|
||||
# The uploaders may run at the same time, so we need two
|
||||
# MutableData instances or they'll fight over offsets &c and
|
||||
# break.
|
||||
mutable_data = MutableData("data" * 100000)
|
||||
mutable_data2 = MutableData("data" * 100000)
|
||||
mutable_data = MutableData(b"data" * 100000)
|
||||
mutable_data2 = MutableData(b"data" * 100000)
|
||||
# Add both kinds of mutable node.
|
||||
d1 = nm.create_mutable_file(mutable_data,
|
||||
version=MDMF_VERSION)
|
||||
@ -235,8 +229,8 @@ class List(GridTestMixin, CLITestMixin, unittest.TestCase):
|
||||
version=SDMF_VERSION)
|
||||
# Add an immutable node. We do this through the directory,
|
||||
# with add_file.
|
||||
immutable_data = upload.Data("immutable data" * 100000,
|
||||
convergence="")
|
||||
immutable_data = upload.Data(b"immutable data" * 100000,
|
||||
convergence=b"")
|
||||
d3 = n.add_file(u"immutable", immutable_data)
|
||||
ds = [d1, d2, d3]
|
||||
dl = defer.DeferredList(ds)
|
||||
@ -294,12 +288,12 @@ class List(GridTestMixin, CLITestMixin, unittest.TestCase):
|
||||
def _got_json(args):
|
||||
(rc, out, err) = args
|
||||
self.failUnlessEqual(rc, 0)
|
||||
self.failUnlessEqual(err, "")
|
||||
self.failUnlessIn(self._mdmf_uri, out)
|
||||
self.failUnlessIn(self._mdmf_readonly_uri, out)
|
||||
self.failUnlessIn(self._sdmf_uri, out)
|
||||
self.failUnlessIn(self._sdmf_readonly_uri, out)
|
||||
self.failUnlessIn(self._imm_uri, out)
|
||||
self.assertEqual(len(err), 0, err)
|
||||
self.failUnlessIn(unicode(self._mdmf_uri, "ascii"), out)
|
||||
self.failUnlessIn(unicode(self._mdmf_readonly_uri, "ascii"), out)
|
||||
self.failUnlessIn(unicode(self._sdmf_uri, "ascii"), out)
|
||||
self.failUnlessIn(unicode(self._sdmf_readonly_uri, "ascii"), out)
|
||||
self.failUnlessIn(unicode(self._imm_uri, "ascii"), out)
|
||||
self.failUnlessIn('"format": "SDMF"', out)
|
||||
self.failUnlessIn('"format": "MDMF"', out)
|
||||
d.addCallback(_got_json)
|
||||
|
Loading…
x
Reference in New Issue
Block a user