From 0a85d913cc4497606fbbad99e5db8222b2f70799 Mon Sep 17 00:00:00 2001
From: Darko Poljak <foss@ungleich.com>
Date: Thu, 27 Jul 2017 09:49:06 +0200
Subject: [PATCH] Optimize dir transfer.

---
 cdist/exec/remote.py | 20 +++++++++++---------
 1 file changed, 11 insertions(+), 9 deletions(-)

diff --git a/cdist/exec/remote.py b/cdist/exec/remote.py
index 7a1fab3d..8b10b324 100644
--- a/cdist/exec/remote.py
+++ b/cdist/exec/remote.py
@@ -139,12 +139,16 @@ class Remote(object):
                 _wrap_addr(self.target_host[0]), destination)])
             self._run_command(command)
 
-    def _transfer_dir_sequential(self, source, destination):
+    def _transfer_dir_commands(self, source, destination):
         for f in glob.glob1(source, '*'):
             command = self._copy.split()
             path = os.path.join(source, f)
             command.extend([path, '{0}:{1}'.format(
                 _wrap_addr(self.target_host[0]), destination)])
+            yield command
+
+    def _transfer_dir_sequential(self, source, destination):
+        for command in self._transfer_dir_commands:
             self._run_command(command)
 
     def _transfer_dir_parallel(self, source, destination, jobs):
@@ -155,14 +159,12 @@ class Remote(object):
             multiprocessing.get_start_method()))
         self.log.trace(("Starting multiprocessing Pool for parallel "
                         "remote transfer"))
-        args = []
-        for f in glob.glob1(source, '*'):
-            command = self._copy.split()
-            path = os.path.join(source, f)
-            command.extend([path, '{0}:{1}'.format(
-                _wrap_addr(self.target_host[0]), destination)])
-            args.append((command, ))
-        mp_pool_run(self._run_command, args, jobs=jobs)
+        args = [(command, ) for command in self._transfer_dir_commands]
+        if len(args) == 1:
+            self.log.debug("Only one dir entry, transfering sequentially")
+            self._run_command(args[0])
+        else:
+            mp_pool_run(self._run_command, args, jobs=jobs)
         self.log.trace(("Multiprocessing for parallel transfer "
                         "finished"))