Feed errors that occur in the back end in the backend_status field
authorSapan Bhatia <gwsapan@gmail.com>
Tue, 29 Apr 2014 03:58:36 +0000 (23:58 -0400)
committerSapan Bhatia <gwsapan@gmail.com>
Tue, 29 Apr 2014 03:58:36 +0000 (23:58 -0400)
planetstack/observer/error_mapper.py [new file with mode: 0644]
planetstack/observer/syncstep.py

diff --git a/planetstack/observer/error_mapper.py b/planetstack/observer/error_mapper.py
new file mode 100644 (file)
index 0000000..a7daa59
--- /dev/null
@@ -0,0 +1,25 @@
+from planetstack.config import Config
+from util.logger import Logger, logging, logger
+
+class ErrorMapper:
+       def __init__(self, error_map_file):
+               self.error_map = {}
+               try:
+                       error_map_lines = open(error_map_file).read().splitlines()
+                       for l in error_map_lines:
+                               if (not l.startswith('#')):
+                                       splits = l.split('->')
+                                       k,v = map(lambda i:i.rstrip(),splits)
+                                       self.error_map[k]=v
+               except:
+                       logging.info('Could not read error map')
+
+
+       def map(self, error):
+               return self.error_map[error]
+
+
+
+
+
+
index fb8c77a..d367279 100644 (file)
@@ -3,6 +3,8 @@ import base64
 from datetime import datetime
 from planetstack.config import Config
 from util.logger import Logger, logging
+from observer.steps import *
+from observer.error_mapper import error_mapper
 
 logger = Logger(level=logging.INFO)
 
@@ -33,6 +35,8 @@ class SyncStep:
         """
         dependencies = []
         self.driver = args.get('driver')
+        self.error_map = args.get('error_map')
+
         try:
             self.soft_deadline = int(self.get_prop('soft_deadline_seconds'))
         except:
@@ -59,7 +63,14 @@ class SyncStep:
                 self.sync_record(o)
                 o.enacted = datetime.now() # Is this the same timezone? XXX
                 o.save(update_fields=['enacted'])
-            except:
+            except Exception,e:
+                try:
+                    o.backend_status = self.error_map.map(str(e))
+                except:
+                    o.backend_status = str(e)
+
+                o.save(update_fields=['backend_status'])
+
                 logger.log_exc("sync step failed!")
                 failed.append(o)