- Timestamp:
- 24 Sep 2014, 15:06:49 (10 years ago)
- Location:
- main/waeup.kofa/trunk/src/waeup/kofa/utils
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
main/waeup.kofa/trunk/src/waeup/kofa/utils/tests/test_utils.py
r11802 r11815 18 18 ## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 19 19 ## 20 import psutil 20 21 import unittest 21 22 from waeup.kofa.interfaces import IKofaUtils … … 26 27 class KofaUtilsTestCase(unittest.TestCase): 27 28 29 def get_cleared_util(self): 30 # Helper: get a `KofUtil` instance with all values of 31 # SYSTEM_MAX_LOAD dict set to ``None`` 32 util = KofaUtils() 33 for key, val in util.SYSTEM_MAX_LOAD.items(): 34 util.SYSTEM_MAX_LOAD[key] = None 35 return util 36 28 37 def test_iface(self): 29 38 # KofaUtils fullfill IKofaUtils expectations … … 31 40 verify.verifyClass(IKofaUtils, KofaUtils) 32 41 verify.verifyObject(IKofaUtils, utils) 42 43 def test_expensive_actions_allowed_swap_none(self): 44 # unset swap maximum values make KofUtils ignore swap values 45 utils = self.get_cleared_util() 46 utils.SYSTEM_MAX_LOAD['swap-mem'] = None 47 assert utils.expensive_actions_allowed() == True 48 49 @unittest.skipIf( 50 psutil.swap_memory().percent >= 99.0, 51 reason="System swap use over 99%. Cannot set higher allowed value.") 52 def test_expensive_actions_allowed_swap_ok(self): 53 # We can react to high swap values 54 utils = self.get_cleared_util() 55 utils.SYSTEM_MAX_LOAD['swap-mem'] = 99.0 # positive number 56 assert utils.expensive_actions_allowed() == True 57 utils.SYSTEM_MAX_LOAD['swap-mem'] = -1.0 # negative number 58 assert utils.expensive_actions_allowed() == True 59 60 @unittest.skipIf( 61 not psutil.swap_memory().percent, 62 reason="Can test swapping behavior only if actually swapping") 63 def test_expensive_actions_allowed_swap_too_much(self): 64 # We can react if too much swap is used 65 utils = self.get_cleared_util() 66 utils.SYSTEM_MAX_LOAD['swap-mem'] = 0.0 # positive number 67 assert utils.expensive_actions_allowed() == False 68 utils.SYSTEM_MAX_LOAD['swap-mem'] = -100.0 # negative number 69 assert utils.expensive_actions_allowed() == False -
main/waeup.kofa/trunk/src/waeup/kofa/utils/utils.py
r11814 r11815 19 19 """ 20 20 import grok 21 import psutil 21 22 import string 22 23 import pytz … … 305 306 """ 306 307 return payment.p_item 308 309 def expensive_actions_allowed(self, type=None, request=None): 310 """Tell, whether expensive actions are currently allowed. 311 312 Check system load/health (or other external circumstances) and 313 locally set values to see, whether expensive actions should be 314 allowed (`True`) or better avoided (`False`). 315 316 Use this to allow or forbid exports, report generations, or 317 similar actions. 318 """ 319 max_values = self.SYSTEM_MAX_LOAD 320 if max_values['swap-mem'] is not None: 321 swap_mem = psutil.swap_memory() 322 max_val = max_values['swap-mem'] 323 if isinstance(max_val, float): 324 if max_val < 0.0: 325 max_val += 100.0 326 if swap_mem.percent > max_val: 327 return False 328 else: 329 if max_val < 0: 330 max_val += swap_mem.total 331 if swap_mem.used > max_val: 332 return False 333 return True
Note: See TracChangeset for help on using the changeset viewer.