web download-status: tolerate DYHBs that haven't retired yet. Fixes #1160.

Also add a better unit test for it.
This commit is contained in:
Brian Warner 2010-08-09 15:03:42 -07:00
parent 5267fc17fe
commit dc1afc81bb
2 changed files with 43 additions and 4 deletions

View File

@ -1,5 +1,5 @@
import os.path, re, urllib import os.path, re, urllib, time
import simplejson import simplejson
from StringIO import StringIO from StringIO import StringIO
from twisted.application import service from twisted.application import service
@ -74,9 +74,40 @@ class FakeUploader(service.Service):
def get_helper_info(self): def get_helper_info(self):
return (None, False) return (None, False)
def build_one_ds():
ds = DownloadStatus("storage_index", 1234)
now = time.time()
ds.add_segment_request(0, now)
# segnum, when, start,len, decodetime
ds.add_segment_delivery(0, now+1, 0, 100, 0.5)
ds.add_segment_request(1, now+2)
ds.add_segment_error(1, now+3)
e = ds.add_dyhb_sent("serverid_a", now)
e.finished([1,2], now+1)
e = ds.add_dyhb_sent("serverid_b", now+2) # left unfinished
e = ds.add_read_event(0, 120, now)
e.update(60, 0.5, 0.1) # bytes, decrypttime, pausetime
e.finished(now+1)
e = ds.add_read_event(120, 30, now+2) # left unfinished
e = ds.add_request_sent("serverid_a", 1, 100, 20, now)
e.finished(20, now+1)
e = ds.add_request_sent("serverid_a", 1, 120, 30, now+1) # left unfinished
# make sure that add_read_event() can come first too
ds1 = DownloadStatus("storage_index", 1234)
e = ds1.add_read_event(0, 120, now)
e.update(60, 0.5, 0.1) # bytes, decrypttime, pausetime
e.finished(now+1)
return ds
class FakeHistory: class FakeHistory:
_all_upload_status = [upload.UploadStatus()] _all_upload_status = [upload.UploadStatus()]
_all_download_status = [DownloadStatus("storage_index", 1234)] _all_download_status = [build_one_ds()]
_all_mapupdate_statuses = [servermap.UpdateStatus()] _all_mapupdate_statuses = [servermap.UpdateStatus()]
_all_publish_statuses = [publish.PublishStatus()] _all_publish_statuses = [publish.PublishStatus()]
_all_retrieve_statuses = [retrieve.RetrieveStatus()] _all_retrieve_statuses = [retrieve.RetrieveStatus()]
@ -516,6 +547,11 @@ class Web(WebMixin, WebErrorMixin, testutil.StallMixin, testutil.ReallyEqualMixi
def _check_dl(res): def _check_dl(res):
self.failUnless("File Download Status" in res, res) self.failUnless("File Download Status" in res, res)
d.addCallback(_check_dl) d.addCallback(_check_dl)
d.addCallback(lambda res: self.GET("/status/down-%d?t=json" % dl_num))
def _check_dl_json(res):
data = simplejson.loads(res)
self.failUnless(isinstance(data, dict))
d.addCallback(_check_dl_json)
d.addCallback(lambda res: self.GET("/status/up-%d" % ul_num)) d.addCallback(lambda res: self.GET("/status/up-%d" % ul_num))
def _check_ul(res): def _check_ul(res):
self.failUnless("File Upload Status" in res, res) self.failUnless("File Upload Status" in res, res)

View File

@ -413,7 +413,11 @@ class DownloadStatusPage(DownloadResultsRendererMixin, rend.Page):
for d_ev in dyhb_events: for d_ev in dyhb_events:
(serverid, sent, shnums, received) = d_ev (serverid, sent, shnums, received) = d_ev
serverid_s = idlib.shortnodeid_b2a(serverid) serverid_s = idlib.shortnodeid_b2a(serverid)
rtt = None
if received is not None:
rtt = received - sent rtt = received - sent
if not shnums:
shnums = []
t[T.tr(style="background: %s" % self.color(serverid))[ t[T.tr(style="background: %s" % self.color(serverid))[
[T.td[serverid_s], T.td[srt(sent)], T.td[srt(received)], [T.td[serverid_s], T.td[srt(sent)], T.td[srt(received)],
T.td[",".join([str(shnum) for shnum in shnums])], T.td[",".join([str(shnum) for shnum in shnums])],
@ -427,7 +431,6 @@ class DownloadStatusPage(DownloadResultsRendererMixin, rend.Page):
T.td["speed"]]] T.td["speed"]]]
for r_ev in self.download_status.read_events: for r_ev in self.download_status.read_events:
(start, length, requesttime, finishtime, bytes, decrypt, paused) = r_ev (start, length, requesttime, finishtime, bytes, decrypt, paused) = r_ev
#print r_ev
if finishtime is not None: if finishtime is not None:
rtt = finishtime - requesttime - paused rtt = finishtime - requesttime - paused
speed = self.render_rate(None, 1.0 * bytes / rtt) speed = self.render_rate(None, 1.0 * bytes / rtt)