From: Daira Hopwood Date: Tue, 3 Nov 2015 15:38:55 +0000 (+0000) Subject: Add _advance_clock callback and remove 'immediate' attribute. X-Git-Url: https://git.rkrishnan.org/specifications/%5B/%5D%20/architecture.txt?a=commitdiff_plain;h=444ed2cf3a2e30c3501ba794c81609683f9023c0;p=tahoe-lafs%2Ftahoe-lafs.git Add _advance_clock callback and remove 'immediate' attribute. Signed-off-by: Daira Hopwood --- diff --git a/src/allmydata/frontends/magic_folder.py b/src/allmydata/frontends/magic_folder.py index 532d2de8..026f7de2 100644 --- a/src/allmydata/frontends/magic_folder.py +++ b/src/allmydata/frontends/magic_folder.py @@ -51,7 +51,6 @@ class MagicFolder(service.MultiService): service.MultiService.__init__(self) - immediate = clock is not None clock = clock or reactor db = magicfolderdb.get_magicfolderdb(dbfile, create_version=(magicfolderdb.SCHEMA_v1, 1)) if db is None: @@ -64,7 +63,7 @@ class MagicFolder(service.MultiService): upload_dirnode = self._client.create_node_from_uri(upload_dircap) collective_dirnode = self._client.create_node_from_uri(collective_dircap) - self.uploader = Uploader(client, local_path_u, db, upload_dirnode, pending_delay, clock, immediate) + self.uploader = Uploader(client, local_path_u, db, upload_dirnode, pending_delay, clock) self.downloader = Downloader(client, local_path_u, db, collective_dirnode, upload_dirnode.get_readonly_uri(), clock) def startService(self): @@ -165,12 +164,11 @@ class QueueMixin(HookMixin): class Uploader(QueueMixin): - def __init__(self, client, local_path_u, db, upload_dirnode, pending_delay, clock, - immediate=False): + def __init__(self, client, local_path_u, db, upload_dirnode, pending_delay, clock): QueueMixin.__init__(self, client, local_path_u, db, 'uploader', 0, clock) self.is_ready = False - self._immediate = immediate + self._advance_clock = lambda: None if not IDirectoryNode.providedBy(upload_dirnode): raise AssertionError("The URI in '%s' does not refer to a directory." @@ -282,15 +280,10 @@ class Uploader(QueueMixin): self._deque.append(relpath_u) self._count('objects_queued') if self.is_ready: - if self._immediate: # for tests - self._turn_deque() - else: - self._clock.callLater(0, self._turn_deque) + self._clock.callLater(0, self._turn_deque) + self._advance_clock() - if self._immediate: - _do_append() - else: - self._clock.callLater(self._pending_delay, _do_append) + self._clock.callLater(self._pending_delay, _do_append) def _when_queue_is_empty(self): return defer.succeed(None) diff --git a/src/allmydata/test/test_cli_magic_folder.py b/src/allmydata/test/test_cli_magic_folder.py index e7f2c511..7a85fc81 100644 --- a/src/allmydata/test/test_cli_magic_folder.py +++ b/src/allmydata/test/test_cli_magic_folder.py @@ -112,7 +112,9 @@ class MagicFolderCLITestMixin(CLITestMixin, GridTestMixin): def init_magicfolder(self, client_num, upload_dircap, collective_dircap, local_magic_dir, clock): dbfile = abspath_expanduser_unicode(u"magicfolderdb.sqlite", base=self.get_clientdir(i=client_num)) magicfolder = MagicFolder(self.get_client(client_num), upload_dircap, collective_dircap, local_magic_dir, - dbfile, pending_delay=0.2, clock=clock) + dbfile, pending_delay=0.2, clock=clock) + + magicfolder.uploader._advance_clock = lambda: clock.advance(0) magicfolder.setServiceParent(self.get_client(client_num)) magicfolder.ready()