mutable checker: even more tests. Everything in ICheckerResults should be covered now, except for immutable-verify which is incomplete
This commit is contained in:
parent
84a5778507
commit
7fb3308498
|
@ -244,7 +244,14 @@ class MutableChecker:
|
||||||
data["count-corrupt-shares"] = 0
|
data["count-corrupt-shares"] = 0
|
||||||
data["list-corrupt-shares"] = []
|
data["list-corrupt-shares"] = []
|
||||||
|
|
||||||
# TODO: sharemap
|
sharemap = {}
|
||||||
|
for verinfo in vmap:
|
||||||
|
for (shnum, peerid, timestamp) in vmap[verinfo]:
|
||||||
|
shareid = "%s-sh%d" % (smap.summarize_version(verinfo), shnum)
|
||||||
|
if shareid not in sharemap:
|
||||||
|
sharemap[shareid] = []
|
||||||
|
sharemap[shareid].append(base32.b2a(peerid))
|
||||||
|
data["sharemap"] = sharemap
|
||||||
data["servers-responding"] = [base32.b2a(serverid)
|
data["servers-responding"] = [base32.b2a(serverid)
|
||||||
for serverid in smap.reachable_peers]
|
for serverid in smap.reachable_peers]
|
||||||
|
|
||||||
|
|
|
@ -2042,16 +2042,18 @@ class DeepCheck(SystemTestMixin, unittest.TestCase):
|
||||||
self.failUnlessEqual(sorted(d["servers-responding"]),
|
self.failUnlessEqual(sorted(d["servers-responding"]),
|
||||||
sorted([idlib.nodeid_b2a(c.nodeid)
|
sorted([idlib.nodeid_b2a(c.nodeid)
|
||||||
for c in self.clients]), where)
|
for c in self.clients]), where)
|
||||||
#self.failUnless("sharemap" in d)
|
self.failUnless("sharemap" in d, where)
|
||||||
self.failUnlessEqual(d["count-wrong-shares"], 0, where)
|
self.failUnlessEqual(d["count-wrong-shares"], 0, where)
|
||||||
self.failUnlessEqual(d["count-recoverable-versions"], 1, where)
|
self.failUnlessEqual(d["count-recoverable-versions"], 1, where)
|
||||||
self.failUnlessEqual(d["count-unrecoverable-versions"], 0, where)
|
self.failUnlessEqual(d["count-unrecoverable-versions"], 0, where)
|
||||||
|
|
||||||
|
|
||||||
def check_and_repair_is_healthy(self, cr, where):
|
def check_and_repair_is_healthy(self, cr, n, where):
|
||||||
self.failUnless(ICheckAndRepairResults.providedBy(cr), where)
|
self.failUnless(ICheckAndRepairResults.providedBy(cr), where)
|
||||||
self.failUnless(cr.get_pre_repair_results().is_healthy(), where)
|
self.failUnless(cr.get_pre_repair_results().is_healthy(), where)
|
||||||
|
#self.check_is_healthy(cr.get_pre_repair_results(), n, where)
|
||||||
self.failUnless(cr.get_post_repair_results().is_healthy(), where)
|
self.failUnless(cr.get_post_repair_results().is_healthy(), where)
|
||||||
|
#self.check_is_healthy(cr.get_post_repair_results(), n, where)
|
||||||
self.failIf(cr.get_repair_attempted(), where)
|
self.failIf(cr.get_repair_attempted(), where)
|
||||||
|
|
||||||
def deep_check_is_healthy(self, cr, num_healthy, where):
|
def deep_check_is_healthy(self, cr, num_healthy, where):
|
||||||
|
@ -2099,21 +2101,21 @@ class DeepCheck(SystemTestMixin, unittest.TestCase):
|
||||||
|
|
||||||
# and check_and_repair(), which should be a nop
|
# and check_and_repair(), which should be a nop
|
||||||
d.addCallback(lambda ign: self.root.check_and_repair())
|
d.addCallback(lambda ign: self.root.check_and_repair())
|
||||||
d.addCallback(self.check_and_repair_is_healthy, "root")
|
d.addCallback(self.check_and_repair_is_healthy, self.root, "root")
|
||||||
d.addCallback(lambda ign: self.mutable.check_and_repair())
|
d.addCallback(lambda ign: self.mutable.check_and_repair())
|
||||||
d.addCallback(self.check_and_repair_is_healthy, "mutable")
|
d.addCallback(self.check_and_repair_is_healthy, self.mutable, "mutable")
|
||||||
d.addCallback(lambda ign: self.large.check_and_repair())
|
d.addCallback(lambda ign: self.large.check_and_repair())
|
||||||
d.addCallback(self.check_and_repair_is_healthy, "large")
|
d.addCallback(self.check_and_repair_is_healthy, self.large, "large")
|
||||||
d.addCallback(lambda ign: self.small.check_and_repair())
|
d.addCallback(lambda ign: self.small.check_and_repair())
|
||||||
d.addCallback(self.failUnlessEqual, None, "small")
|
d.addCallback(self.failUnlessEqual, None, "small")
|
||||||
|
|
||||||
# check_and_repair(verify=True)
|
# check_and_repair(verify=True)
|
||||||
d.addCallback(lambda ign: self.root.check_and_repair(verify=True))
|
d.addCallback(lambda ign: self.root.check_and_repair(verify=True))
|
||||||
d.addCallback(self.check_and_repair_is_healthy, "root")
|
d.addCallback(self.check_and_repair_is_healthy, self.root, "root")
|
||||||
d.addCallback(lambda ign: self.mutable.check_and_repair(verify=True))
|
d.addCallback(lambda ign: self.mutable.check_and_repair(verify=True))
|
||||||
d.addCallback(self.check_and_repair_is_healthy, "mutable")
|
d.addCallback(self.check_and_repair_is_healthy, self.mutable, "mutable")
|
||||||
d.addCallback(lambda ign: self.large.check_and_repair(verify=True))
|
d.addCallback(lambda ign: self.large.check_and_repair(verify=True))
|
||||||
d.addCallback(self.check_and_repair_is_healthy, "large")
|
d.addCallback(self.check_and_repair_is_healthy, self.large, "large")
|
||||||
d.addCallback(lambda ign: self.small.check_and_repair(verify=True))
|
d.addCallback(lambda ign: self.small.check_and_repair(verify=True))
|
||||||
d.addCallback(self.failUnlessEqual, None, "small")
|
d.addCallback(self.failUnlessEqual, None, "small")
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue