Unit testing for pcp module.
Added unit tests to test code in def/ module. Currently, AverageNodePowerHistory(...) assumes that the DRAM power readings are being monitored. In addition, it also assumes that the host servers are dual socket machines. However, this assumption might not always hold true. Thus, added a TODO to fix this.
This commit is contained in:
parent
b27966dc3a
commit
91e06fab4f
3 changed files with 100 additions and 0 deletions
|
@ -41,6 +41,7 @@ func AverageNodePowerHistory(history *ring.Ring) float64 {
|
|||
return 0.0
|
||||
}
|
||||
|
||||
// TODO (pkaushik) handle cases when DRAM power is not being monitored.
|
||||
count /= 4 // Two PKGs, two DRAM for all nodes currently.
|
||||
|
||||
return (total / count)
|
||||
|
|
49
pcp/utils_test.go
Normal file
49
pcp/utils_test.go
Normal file
|
@ -0,0 +1,49 @@
|
|||
// Copyright (C) 2018 spdf
|
||||
//
|
||||
// This file is part of Elektron.
|
||||
//
|
||||
// Elektron is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
//
|
||||
// Elektron is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with Elektron. If not, see <http://www.gnu.org/licenses/>.
|
||||
//
|
||||
|
||||
package pcp
|
||||
|
||||
import (
|
||||
"container/ring"
|
||||
"github.com/stretchr/testify/assert"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestAverageNodePowerHistory(t *testing.T) {
|
||||
// Creating a ring to hold 5 seconds of node power readings.
|
||||
// Note that as we're considering both CPU and DRAM packages, this amounts to 20 entries
|
||||
// in the ring.
|
||||
nodePowerRecordings := ring.New(20)
|
||||
for i := 1; i <= 20; i++ {
|
||||
nodePowerRecordings.Value = float64(i)
|
||||
nodePowerRecordings = nodePowerRecordings.Next()
|
||||
}
|
||||
|
||||
assert.Equal(t, 42.0, AverageNodePowerHistory(nodePowerRecordings))
|
||||
}
|
||||
|
||||
func TestAverageClusterPowerHistory(t *testing.T) {
|
||||
// Creating a ring to hold 5 seconds of cluster power consumption.
|
||||
clusterPowerRecordings := ring.New(5)
|
||||
for i := 1; i <= 5; i++ {
|
||||
clusterPowerRecordings.Value = float64(i)
|
||||
clusterPowerRecordings = clusterPowerRecordings.Next()
|
||||
}
|
||||
|
||||
assert.Equal(t, 3.0, AverageClusterPowerHistory(clusterPowerRecordings))
|
||||
}
|
50
pcp/victim_test.go
Normal file
50
pcp/victim_test.go
Normal file
|
@ -0,0 +1,50 @@
|
|||
// Copyright (C) 2018 spdf
|
||||
//
|
||||
// This file is part of Elektron.
|
||||
//
|
||||
// Elektron is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation, either version 3 of the License, or
|
||||
// (at your option) any later version.
|
||||
//
|
||||
// Elektron is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with Elektron. If not, see <http://www.gnu.org/licenses/>.
|
||||
//
|
||||
|
||||
package pcp
|
||||
|
||||
import (
|
||||
"github.com/stretchr/testify/assert"
|
||||
"sort"
|
||||
"testing"
|
||||
)
|
||||
|
||||
// TestVictimSorter tests whether victim nodes are sorted in the non-increasing
|
||||
// order of Watts consumption.
|
||||
func TestVictimSorter(t *testing.T) {
|
||||
victims := []Victim{
|
||||
{Watts: 10.0, Host: "host1"},
|
||||
{Watts: 20.0, Host: "host2"},
|
||||
{Watts: 30.0, Host: "host3"},
|
||||
{Watts: 40.0, Host: "host4"},
|
||||
}
|
||||
|
||||
sort.Sort(VictimSorter(victims))
|
||||
|
||||
expectedVictimsOrder := []Victim{
|
||||
{Watts: 40.0, Host: "host4"},
|
||||
{Watts: 30.0, Host: "host3"},
|
||||
{Watts: 20.0, Host: "host2"},
|
||||
{Watts: 10.0, Host: "host1"},
|
||||
}
|
||||
|
||||
for i, v := range expectedVictimsOrder {
|
||||
assert.Equal(t, v.Watts, victims[i].Watts, "failed to sorted victims")
|
||||
assert.Equal(t, v.Host, victims[i].Host, "failed to sorted victims")
|
||||
}
|
||||
}
|
Reference in a new issue