Adding unit tests for server/utils.go
Signed-off-by: Liu Chang <liuchang@qiniu.com>
This commit is contained in:
parent
070b8bfdc5
commit
42800cc96b
2 changed files with 114 additions and 0 deletions
4
server/fixtures/resolv.conf
Normal file
4
server/fixtures/resolv.conf
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
search 192.30.253.113 192.30.252.153
|
||||||
|
nameserver cri-o.io
|
||||||
|
nameserver github.com
|
||||||
|
options timeout:5 attempts:3
|
110
server/utils_test.go
Normal file
110
server/utils_test.go
Normal file
|
@ -0,0 +1,110 @@
|
||||||
|
package server
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
defaultDNSPath = "/etc/resolv.conf"
|
||||||
|
testDNSPath = "fixtures/resolv_test.conf"
|
||||||
|
dnsPath = "fixtures/resolv.conf"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestParseDNSOptions(t *testing.T) {
|
||||||
|
testCases := []struct {
|
||||||
|
Servers, Searches, Options []string
|
||||||
|
Path string
|
||||||
|
Want string
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
[]string{},
|
||||||
|
[]string{},
|
||||||
|
[]string{},
|
||||||
|
testDNSPath, defaultDNSPath,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
[]string{"cri-o.io", "github.com"},
|
||||||
|
[]string{"192.30.253.113", "192.30.252.153"},
|
||||||
|
[]string{"timeout:5", "attempts:3"},
|
||||||
|
testDNSPath, dnsPath,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, c := range testCases {
|
||||||
|
if err := parseDNSOptions(c.Servers, c.Searches,
|
||||||
|
c.Options, c.Path); err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
expect, _ := ioutil.ReadFile(c.Want)
|
||||||
|
result, _ := ioutil.ReadFile(c.Path)
|
||||||
|
if string(expect) != string(result) {
|
||||||
|
t.Errorf("expect %v: \n but got : %v", string(expect), string(result))
|
||||||
|
}
|
||||||
|
os.Remove(c.Path)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestSysctlsFromPodAnnotations(t *testing.T) {
|
||||||
|
testCases := []struct {
|
||||||
|
Annotations map[string]string
|
||||||
|
SafeSysctls []Sysctl
|
||||||
|
UnsafeSysctls []Sysctl
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
map[string]string{
|
||||||
|
"foo-": "bar",
|
||||||
|
SysctlsPodAnnotationKey: "kernel.shmmax=100000000,safe=20000000",
|
||||||
|
},
|
||||||
|
[]Sysctl{
|
||||||
|
{"kernel.shmmax", "100000000"},
|
||||||
|
{"safe", "20000000"},
|
||||||
|
},
|
||||||
|
[]Sysctl{},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
map[string]string{
|
||||||
|
UnsafeSysctlsPodAnnotationKey: "kernel.shmmax=10,unsafe=20",
|
||||||
|
},
|
||||||
|
[]Sysctl{},
|
||||||
|
[]Sysctl{
|
||||||
|
{"kernel.shmmax", "10"},
|
||||||
|
{"unsafe", "20"},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
map[string]string{
|
||||||
|
"bar..": "42",
|
||||||
|
SysctlsPodAnnotationKey: "kernel.shmmax=20000000,safe=40000000",
|
||||||
|
UnsafeSysctlsPodAnnotationKey: "kernel.shmmax=10,unsafe=20",
|
||||||
|
},
|
||||||
|
[]Sysctl{
|
||||||
|
{"kernel.shmmax", "20000000"},
|
||||||
|
{"safe", "40000000"},
|
||||||
|
},
|
||||||
|
[]Sysctl{
|
||||||
|
{"kernel.shmmax", "10"},
|
||||||
|
{"unsafe", "20"},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, c := range testCases {
|
||||||
|
safe, unsafe, err := SysctlsFromPodAnnotations(c.Annotations)
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
}
|
||||||
|
for index, sysctl := range safe {
|
||||||
|
if sysctl.Name != safe[index].Name || sysctl.Value != safe[index].Value {
|
||||||
|
t.Errorf("Expect safe: %v, but got: %v\n", safe[index], sysctl)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for index, sysctl := range unsafe {
|
||||||
|
if sysctl.Name != unsafe[index].Name || sysctl.Value != unsafe[index].Value {
|
||||||
|
t.Errorf("Expect unsafe: %v, but got: %v\n", safe[index], sysctl)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue