megacli: prevent crash when drive temperature is N/A

Intel SSD do not report their temperature in MegaCLI output
Drive Temperature : N/A
This commit is contained in:
Alexis Letessier 2015-07-25 16:45:45 +02:00
parent aca4688dc3
commit 0028abc077
4 changed files with 41 additions and 9 deletions

3
collector/fixtures/megacli Executable file
View File

@ -0,0 +1,3 @@
#!/usr/bin/env bash
cat fixtures/megacli_disks.txt

View File

@ -83,7 +83,7 @@ Foreign State: None
Device Speed: Unknown
Link Speed: Unknown
Media Type: Hard Disk Device
Drive Temperature :37C (98.60 F)
Drive Temperature : N/A
PI Eligibility: No
Drive is formatted for PI information: No
PI: No PI

View File

@ -196,17 +196,18 @@ func (c *megaCliCollector) updateDisks() error {
for enc, encStats := range stats {
for slot, slotStats := range encStats {
encStr := strconv.Itoa(enc)
slotStr := strconv.Itoa(slot)
tStr := slotStats["Drive Temperature"]
if strings.Index(tStr, "C") > 0 {
tStr = tStr[:strings.Index(tStr, "C")]
t, err := strconv.ParseFloat(tStr, 64)
if err != nil {
return err
}
encStr := strconv.Itoa(enc)
slotStr := strconv.Itoa(slot)
c.driveTemperature.WithLabelValues(encStr, slotStr).Set(t)
}
for _, i := range counters {
counter, err := strconv.ParseFloat(slotStats[i], 64)

View File

@ -3,8 +3,11 @@
package collector
import (
"flag"
"os"
"testing"
"github.com/prometheus/client_golang/prometheus"
)
const (
@ -48,7 +51,32 @@ func TestMegaCliDisks(t *testing.T) {
t.Fatalf("Unexpected drive temperature: %s", stats[32][0]["Drive Temperature"])
}
if stats[32][1]["Drive Temperature"] != "N/A" {
t.Fatalf("Unexpected drive temperature: %s", stats[32][2]["Drive Temperature"])
}
if stats[32][3]["Predictive Failure Count"] != "23" {
t.Fatal()
}
}
func TestMegaCliCollectorDoesntCrash(t *testing.T) {
if err := flag.Set("collector.megacli.command", "./fixtures/megacli"); err != nil {
t.Fatal(err)
}
collector, err := NewMegaCliCollector()
if err != nil {
t.Fatal(err)
}
sink := make(chan prometheus.Metric)
go func() {
for {
<-sink
}
}()
err = collector.Update(sink)
if err != nil {
t.Fatal(err)
}
}