Add color to sensors

This commit is contained in:
Nicolas Hennion 2012-12-21 21:45:53 +01:00
parent 2fd4779f2b
commit c3b42a5fc0
3 changed files with 87 additions and 12 deletions

5
NEWS
View File

@ -3,8 +3,11 @@ Version 1.5.2
* Add sensors module (enable it with -e option) * Add sensors module (enable it with -e option)
* Improve CPU stats (IO wait, Nice, IRQ) * Improve CPU stats (IO wait, Nice, IRQ)
* More stats in lower space (yes it is possible) * More stats in lower space (yes it's possible)
* Refactor processes list and count (lower CPU/MEM footprint) * Refactor processes list and count (lower CPU/MEM footprint)
* Add functions to the RCP method
* Completed unit test
* and fixes...
Version 1.5.1 Version 1.5.1
============= =============

View File

@ -209,9 +209,10 @@ class glancesLimits:
# Exemple: # Exemple:
# limits_list['STD'] = [50, 70, 90] # limits_list['STD'] = [50, 70, 90]
#_______________________________CAREFUL WARNING CRITICAL #_______________________CAREFUL WARNING CRITICAL
__limits_list = {'STD': [50, 70, 90], __limits_list = {'STD': [50, 70, 90],
'LOAD': [0.7, 1.0, 5.0]} 'LOAD': [0.7, 1.0, 5.0],
'TEMP': [50, 70, 80]}
def __init__(self, careful=50, warning=70, critical=90): def __init__(self, careful=50, warning=70, critical=90):
self.__limits_list['STD'] = [careful, warning, critical] self.__limits_list['STD'] = [careful, warning, critical]
@ -234,6 +235,15 @@ class glancesLimits:
def getLOADCritical(self, core=1): def getLOADCritical(self, core=1):
return self.__limits_list['LOAD'][2] * core return self.__limits_list['LOAD'][2] * core
def getTEMPCareful(self):
return self.__limits_list['TEMP'][0]
def getTEMPWarning(self):
return self.__limits_list['TEMP'][1]
def getTEMPCritical(self):
return self.__limits_list['TEMP'][2]
class glancesLogs: class glancesLogs:
""" """
@ -1290,6 +1300,28 @@ class glancesScreen:
def __getProcessColor(self, current=0, max=100): def __getProcessColor(self, current=0, max=100):
return self.__getColor2(current, max) return self.__getColor2(current, max)
def __getSensorsAlert(self, current=0):
# Alert for Sensors (temperature in degre)
# If current < CAREFUL then alert = OK
# If current > CAREFUL then alert = CAREFUL
# If current > WARNING then alert = WARNING
# If current > CRITICALthen alert = CRITICAL
if current > limits.getTEMPCritical():
return 'CRITICAL'
elif current > limits.getTEMPWarning():
return 'WARNING'
elif current > limits.getTEMPCareful():
return 'CAREFUL'
return 'OK'
def __getSensorsColor(self, current=0):
"""
Return color for Sensors temperature (non logged stats)
"""
return self.__colors_list2[self.__getSensorsAlert(current)]
def __catchKey(self): def __catchKey(self):
# Get key # Get key
self.pressedkey = self.term_window.getch() self.pressedkey = self.term_window.getch()
@ -1878,7 +1910,8 @@ class glancesScreen:
sensors[i]['label'], 21) sensors[i]['label'], 21)
self.term_window.addnstr( self.term_window.addnstr(
self.sensors_y + 1 + i, self.sensors_x + 20, self.sensors_y + 1 + i, self.sensors_x + 20,
format(sensors[i]['value'], '>3'), 3) format(sensors[i]['value'], '>3'), 3,
self.__getSensorsColor(sensors[i]['value']))
ret = ret + 1 ret = ret + 1
return ret return ret
return 0 return 0

View File

@ -37,44 +37,83 @@ class TestGlancesStat(unittest.TestCase):
def test_Glances_getSystem(self): def test_Glances_getSystem(self):
self.stats.update() self.stats.update()
system = self.stats.getSystem() system = self.stats.getSystem()
print("System info: %s" % system) #~ print("System info: %s" % system)
self.assertTrue(type(system) == dict)
self.assertTrue(len(system) > 1) self.assertTrue(len(system) > 1)
def test_Glances_getCore(self): def test_Glances_getCore(self):
self.stats.update() self.stats.update()
core = self.stats.getCore() core = self.stats.getCore()
print("CPU Core number: %s" % core) #~ print("CPU Core number: %s" % core)
self.assertTrue(type(core) == int)
self.assertEqual(core, multiprocessing.cpu_count()) self.assertEqual(core, multiprocessing.cpu_count())
def test_Glances_getCpu(self): def test_Glances_getCpu(self):
self.stats.update() self.stats.update()
cpu = self.stats.getCpu() cpu = self.stats.getCpu()
print("CPU stat %s:" % cpu) #~ print("CPU stat %s:" % cpu)
self.assertTrue(type(cpu) == dict)
self.assertTrue(len(cpu) > 1) self.assertTrue(len(cpu) > 1)
def test_Glances_getPerCpu(self): def test_Glances_getPerCpu(self):
self.stats.update() self.stats.update()
percpu = self.stats.getPerCpu() percpu = self.stats.getPerCpu()
print("PerCPU stat %s:" % percpu) #~ print("PerCPU stat %s:" % percpu)
self.assertTrue(type(percpu) == list)
self.assertEqual(len(percpu), multiprocessing.cpu_count()) self.assertEqual(len(percpu), multiprocessing.cpu_count())
def test_Glances_getMem(self): def test_Glances_getMem(self):
self.stats.update() self.stats.update()
mem = self.stats.getMem() mem = self.stats.getMem()
print("Mem stat %s:" % mem) #~ print("Mem stat %s:" % mem)
self.assertTrue(type(mem) == dict)
self.assertTrue(len(mem) > 2) self.assertTrue(len(mem) > 2)
def test_Glances_getMemSwap(self): def test_Glances_getMemSwap(self):
self.stats.update() self.stats.update()
memswap = self.stats.getMemSwap() memswap = self.stats.getMemSwap()
print("MemSwap stat %s:" % memswap) #~ print("MemSwap stat %s:" % memswap)
self.assertTrue(type(memswap) == dict)
self.assertTrue(len(memswap) > 2) self.assertTrue(len(memswap) > 2)
def test_Glances_getNetwork(self): def test_Glances_getNetwork(self):
self.stats.update() self.stats.update()
net = self.stats.getNetwork() net = self.stats.getNetwork()
print("Network stat %s:" % net) #~ print("Network stat %s:" % net)
self.assertTrue(len(net) > 1) self.assertTrue(type(net) == list)
self.assertTrue(len(net) > 0)
def test_Glances_getDiskIO(self):
self.stats.update()
diskio = self.stats.getDiskIO()
#~ print("DiskIO stat %s:" % diskio)
self.assertTrue(type(diskio) == list)
self.assertTrue(len(diskio) > 0)
def test_Glances_getFs(self):
self.stats.update()
fs = self.stats.getFs()
#~ print("File system stat %s:" % fs)
self.assertTrue(type(fs) == list)
self.assertTrue(len(fs) > 0)
def test_Glances_getProcess(self):
self.stats.update()
pc = self.stats.getProcessCount()
pl = self.stats.getProcessList()
#~ print("Processes stat %s:" % pc)
#~ print("Processes list %s:" % pl)
self.assertTrue(type(pc) == dict)
self.assertTrue(len(pc) > 2)
self.assertTrue(type(pl) == list)
self.assertTrue(len(pl) > 0)
def test_Glances_getSensors(self):
self.stats.update()
sensors = self.stats.getSensors()
#~ print("Optionnal sensors stat %s:" % sensors)
self.assertTrue(type(sensors) == list)
#~ self.assertTrue(len(sensors) > 0)
if __name__ == '__main__': if __name__ == '__main__':