mirror of
https://github.com/openfaas/faas.git
synced 2025-06-09 00:36:46 +00:00
Previous PR from Simon or Ken broke build due to missing gofmt in the PR. This PR applies it to resolve the build issue. Signed-off-by: Alex Ellis (VMware) <alexellis2@gmail.com>
89 lines
2.4 KiB
Go
89 lines
2.4 KiB
Go
// Copyright (c) Alex Ellis 2017. All rights reserved.
|
|
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
|
|
|
package handlers
|
|
|
|
import (
|
|
"testing"
|
|
)
|
|
|
|
func TestDisabledScale(t *testing.T) {
|
|
minReplicas := uint64(1)
|
|
scalingFactor := uint64(0)
|
|
newReplicas := CalculateReplicas("firing", DefaultMinReplicas, DefaultMaxReplicas, minReplicas, scalingFactor)
|
|
if newReplicas != 0 {
|
|
t.Log("Expected not to scale")
|
|
t.Fail()
|
|
}
|
|
}
|
|
|
|
func TestParameterEdge(t *testing.T) {
|
|
minReplicas := uint64(0)
|
|
scalingFactor := uint64(0)
|
|
newReplicas := CalculateReplicas("firing", DefaultMinReplicas, DefaultMaxReplicas, minReplicas, scalingFactor)
|
|
if newReplicas != 0 {
|
|
t.Log("Expected not to scale")
|
|
t.Fail()
|
|
}
|
|
}
|
|
|
|
func TestMaxScale(t *testing.T) {
|
|
minReplicas := uint64(1)
|
|
scalingFactor := uint64(100)
|
|
newReplicas := CalculateReplicas("firing", DefaultMinReplicas, DefaultMaxReplicas, minReplicas, scalingFactor)
|
|
if newReplicas != 20 {
|
|
t.Log("Expected ceiling of 20 replicas")
|
|
t.Fail()
|
|
}
|
|
}
|
|
|
|
func TestInitialScale(t *testing.T) {
|
|
minReplicas := uint64(1)
|
|
scalingFactor := uint64(20)
|
|
newReplicas := CalculateReplicas("firing", DefaultMinReplicas, DefaultMaxReplicas, minReplicas, scalingFactor)
|
|
if newReplicas != 4 {
|
|
t.Log("Expected the increment to equal 4")
|
|
t.Fail()
|
|
}
|
|
}
|
|
|
|
func TestScale(t *testing.T) {
|
|
minReplicas := uint64(1)
|
|
scalingFactor := uint64(20)
|
|
newReplicas := CalculateReplicas("firing", 4, DefaultMaxReplicas, minReplicas, scalingFactor)
|
|
if newReplicas != 8 {
|
|
t.Log("Expected newReplicas to equal 8")
|
|
t.Fail()
|
|
}
|
|
}
|
|
|
|
func TestScaleCeiling(t *testing.T) {
|
|
minReplicas := uint64(1)
|
|
scalingFactor := uint64(20)
|
|
newReplicas := CalculateReplicas("firing", 20, DefaultMaxReplicas, minReplicas, scalingFactor)
|
|
if newReplicas != 20 {
|
|
t.Log("Expected ceiling of 20 replicas")
|
|
t.Fail()
|
|
}
|
|
}
|
|
|
|
func TestScaleCeilingEdge(t *testing.T) {
|
|
minReplicas := uint64(1)
|
|
scalingFactor := uint64(20)
|
|
newReplicas := CalculateReplicas("firing", 19, DefaultMaxReplicas, minReplicas, scalingFactor)
|
|
if newReplicas != 20 {
|
|
t.Log("Expected ceiling of 20 replicas")
|
|
t.Fail()
|
|
}
|
|
}
|
|
|
|
func TestBackingOff(t *testing.T) {
|
|
minReplicas := uint64(1)
|
|
scalingFactor := uint64(20)
|
|
newReplicas := CalculateReplicas("resolved", 8, DefaultMaxReplicas, minReplicas, scalingFactor)
|
|
if newReplicas != 1 {
|
|
t.Log("Expected backing off to 1 replica")
|
|
t.Fail()
|
|
}
|
|
}
|