changeset 1051:971b4d67e82a

serve: Fix problems with assets disappearing between servings. When an asset file changes, its source's pipeline is re-run. But that created a bake record that only had that pipeline's output, so the other outputs were incorrectly considered empty and therefore any stray files were removed. Now we copy over bake records for the pipelines we don't run.
author Ludovic Chabant <ludovic@chabant.com>
date Fri, 26 Jan 2018 18:05:02 -0800
parents e0796761cdcc
children f8572df0756e
files piecrust/baking/baker.py piecrust/pipelines/base.py piecrust/serving/procloop.py
diffstat 3 files changed, 19 insertions(+), 4 deletions(-) [+]
line wrap: on
line diff
--- a/piecrust/baking/baker.py	Fri Jan 26 18:02:07 2018 -0800
+++ b/piecrust/baking/baker.py	Fri Jan 26 18:05:02 2018 -0800
@@ -31,7 +31,8 @@
                  allowed_pipelines=None,
                  forbidden_pipelines=None,
                  allowed_sources=None,
-                 rotate_bake_records=True):
+                 rotate_bake_records=True,
+                 keep_unused_records=False):
         self.appfactory = appfactory
         self.app = app
         self.out_dir = out_dir
@@ -40,6 +41,7 @@
         self.forbidden_pipelines = forbidden_pipelines
         self.allowed_sources = allowed_sources
         self.rotate_bake_records = rotate_bake_records
+        self.keep_unused_records = keep_unused_records
 
     def bake(self):
         start_time = time.perf_counter()
@@ -108,7 +110,7 @@
         # Handle deletions, collapse records, etc.
         ppmngr.postJobRun()
         ppmngr.deleteStaleOutputs()
-        ppmngr.collapseRecords()
+        ppmngr.collapseRecords(self.keep_unused_records)
 
         # All done with the workers. Close the pool and get reports.
         pool_stats = pool.close()
--- a/piecrust/pipelines/base.py	Fri Jan 26 18:02:07 2018 -0800
+++ b/piecrust/pipelines/base.py	Fri Jan 26 18:05:02 2018 -0800
@@ -283,10 +283,22 @@
                         pass
                     logger.info('[delete] %s' % path)
 
-    def collapseRecords(self):
+    def collapseRecords(self, keep_unused_records=False):
+        seen_records = []
         for ppinfo in self.getPipelineInfos():
             ctx = PipelineCollapseRecordContext(ppinfo.record_history)
             ppinfo.pipeline.collapseRecords(ctx)
+            seen_records.append(ppinfo.pipeline.record_name)
+
+        if keep_unused_records:
+            cur_recs = self.record_histories.current
+            prev_recs = self.record_histories.previous
+            for prev_rec in prev_recs.records:
+                if prev_rec.name in seen_records:
+                    continue
+
+                logger.debug("Keeping record: %s" % prev_rec.name)
+                cur_recs.records.append(prev_rec)
 
     def shutdownPipelines(self):
         for ppinfo in self.getPipelineInfos():
--- a/piecrust/serving/procloop.py	Fri Jan 26 18:02:07 2018 -0800
+++ b/piecrust/serving/procloop.py	Fri Jan 26 18:05:02 2018 -0800
@@ -152,7 +152,8 @@
             self.appfactory, self._app, self.out_dir,
             allowed_pipelines=['asset'],
             allowed_sources=allowed_sources,
-            rotate_bake_records=False)
+            rotate_bake_records=False,
+            keep_unused_records=(allowed_sources is not None))
         records = baker.bake()
 
         self._onPipelinesRun(records)