tolerate simplejson-2.0.0 and newer, which frequently return bytestrings instead of unicode objects. Closes #523

This commit is contained in:
Brian Warner 2008-09-30 15:21:06 -07:00
parent 1a3f154c21
commit 935d185696
6 changed files with 28 additions and 11 deletions

View File

@ -222,7 +222,9 @@ class TahoeDirectorySource:
nodetype, d = parsed nodetype, d = parsed
assert nodetype == "dirnode" assert nodetype == "dirnode"
self.mutable = d.get("mutable", False) # older nodes don't provide it self.mutable = d.get("mutable", False) # older nodes don't provide it
self.children_d = d["children"] self.children_d = dict( [(unicode(name),value)
for (name,value)
in d["children"].iteritems()] )
self.children = None self.children = None
def init_from_parsed(self, parsed): def init_from_parsed(self, parsed):
@ -230,7 +232,9 @@ class TahoeDirectorySource:
self.writecap = ascii_or_none(d.get("rw_uri")) self.writecap = ascii_or_none(d.get("rw_uri"))
self.readcap = ascii_or_none(d.get("ro_uri")) self.readcap = ascii_or_none(d.get("ro_uri"))
self.mutable = d.get("mutable", False) # older nodes don't provide it self.mutable = d.get("mutable", False) # older nodes don't provide it
self.children_d = d["children"] self.children_d = dict( [(unicode(name),value)
for (name,value)
in d["children"].iteritems()] )
self.children = None self.children = None
def populate(self, recurse): def populate(self, recurse):
@ -294,7 +298,9 @@ class TahoeDirectoryTarget:
self.writecap = ascii_or_none(d.get("rw_uri")) self.writecap = ascii_or_none(d.get("rw_uri"))
self.readcap = ascii_or_none(d.get("ro_uri")) self.readcap = ascii_or_none(d.get("ro_uri"))
self.mutable = d.get("mutable", False) # older nodes don't provide it self.mutable = d.get("mutable", False) # older nodes don't provide it
self.children_d = d["children"] self.children_d = dict( [(unicode(name),value)
for (name,value)
in d["children"].iteritems()] )
self.children = None self.children = None
def init_from_grid(self, writecap, readcap): def init_from_grid(self, writecap, readcap):
@ -308,7 +314,9 @@ class TahoeDirectoryTarget:
nodetype, d = parsed nodetype, d = parsed
assert nodetype == "dirnode" assert nodetype == "dirnode"
self.mutable = d.get("mutable", False) # older nodes don't provide it self.mutable = d.get("mutable", False) # older nodes don't provide it
self.children_d = d["children"] self.children_d = dict( [(unicode(name),value)
for (name,value)
in d["children"].iteritems()] )
self.children = None self.children = None
def just_created(self, writecap): def just_created(self, writecap):

View File

@ -53,6 +53,7 @@ def list(options):
rows = [] rows = []
for name in childnames: for name in childnames:
name = unicode(name)
child = children[name] child = children[name]
childtype = child[0] childtype = child[0]
ctime = child[1]["metadata"].get("ctime") ctime = child[1]["metadata"].get("ctime")

View File

@ -25,8 +25,8 @@ def mv(options, mode="move"):
data = urllib.urlopen(from_url + "?t=json").read() data = urllib.urlopen(from_url + "?t=json").read()
nodetype, attrs = simplejson.loads(data) nodetype, attrs = simplejson.loads(data)
cap = attrs.get("rw_uri") or attrs["ro_uri"] cap = attrs.get("rw_uri") or attrs["ro_uri"]
# simplejson always returns unicode, but we know that it's really just an # simplejson sometimes returns unicode, but we know that it's really just
# ASCII file-cap. # an ASCII file-cap.
cap = str(cap) cap = str(cap)
# now get the target # now get the target

View File

@ -115,7 +115,10 @@ def listdir(nodeurl, root, vdrive_pathname):
assert nodetype == "dirnode" assert nodetype == "dirnode"
global directories_read global directories_read
directories_read += 1 directories_read += 1
return d['children'] children = dict( [(unicode(name),value)
for (name,value)
in d["children"].iteritems()] )
return children
def choose_random_descendant(server_url, root, pathname=""): def choose_random_descendant(server_url, root, pathname=""):

View File

@ -197,7 +197,7 @@ class WebMixin(object):
def failUnlessIsBarJSON(self, res): def failUnlessIsBarJSON(self, res):
data = simplejson.loads(res) data = simplejson.loads(res)
self.failUnless(isinstance(data, list)) self.failUnless(isinstance(data, list))
self.failUnlessEqual(data[0], "filenode") self.failUnlessEqual(data[0], u"filenode")
self.failUnless(isinstance(data[1], dict)) self.failUnless(isinstance(data[1], dict))
self.failIf(data[1]["mutable"]) self.failIf(data[1]["mutable"])
self.failIf("rw_uri" in data[1]) # immutable self.failIf("rw_uri" in data[1]) # immutable
@ -214,11 +214,13 @@ class WebMixin(object):
self.failUnlessEqual(data[1]["rw_uri"], self._foo_uri) self.failUnlessEqual(data[1]["rw_uri"], self._foo_uri)
self.failUnlessEqual(data[1]["ro_uri"], self._foo_readonly_uri) self.failUnlessEqual(data[1]["ro_uri"], self._foo_readonly_uri)
kidnames = sorted(data[1]["children"]) kidnames = sorted([unicode(n) for n in data[1]["children"]])
self.failUnlessEqual(kidnames, self.failUnlessEqual(kidnames,
[u"bar.txt", u"blockingfile", u"empty", [u"bar.txt", u"blockingfile", u"empty",
u"n\u00fc.txt", u"sub"]) u"n\u00fc.txt", u"sub"])
kids = data[1]["children"] kids = dict( [(unicode(name),value)
for (name,value)
in data[1]["children"].iteritems()] )
self.failUnlessEqual(kids[u"sub"][0], "dirnode") self.failUnlessEqual(kids[u"sub"][0], "dirnode")
self.failUnless("metadata" in kids[u"sub"][1]) self.failUnless("metadata" in kids[u"sub"][1])
self.failUnless("ctime" in kids[u"sub"][1]["metadata"]) self.failUnless("ctime" in kids[u"sub"][1]["metadata"])
@ -1226,7 +1228,9 @@ class Web(WebMixin, unittest.TestCase):
def _check_page_json(res): def _check_page_json(res):
parsed = simplejson.loads(res) parsed = simplejson.loads(res)
self.failUnlessEqual(parsed[0], "dirnode") self.failUnlessEqual(parsed[0], "dirnode")
children = parsed[1]["children"] children = dict( [(unicode(name),value)
for (name,value)
in parsed[1]["children"].iteritems()] )
self.failUnless("new.txt" in children) self.failUnless("new.txt" in children)
new_json = children["new.txt"] new_json = children["new.txt"]
self.failUnlessEqual(new_json[0], "filenode") self.failUnlessEqual(new_json[0], "filenode")

View File

@ -372,6 +372,7 @@ class DirectoryNodeHandler(RenderMixin, rend.Page, ReplaceMeMixin):
raise raise
cs = [] cs = []
for name, (file_or_dir, mddict) in children.iteritems(): for name, (file_or_dir, mddict) in children.iteritems():
name = unicode(name) # simplejson-2.0.1 returns str *or* unicode
cap = str(mddict.get('rw_uri') or mddict.get('ro_uri')) cap = str(mddict.get('rw_uri') or mddict.get('ro_uri'))
cs.append((name, cap, mddict.get('metadata'))) cs.append((name, cap, mddict.get('metadata')))
d = self.node.set_children(cs, replace) d = self.node.set_children(cs, replace)