helpers_test.go 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253
  1. /*
  2. Copyright 2015 The Kubernetes Authors.
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. */
  13. package resource
  14. import (
  15. "testing"
  16. "github.com/stretchr/testify/assert"
  17. "k8s.io/api/core/v1"
  18. "k8s.io/apimachinery/pkg/api/resource"
  19. )
  20. func TestResourceHelpers(t *testing.T) {
  21. cpuLimit := resource.MustParse("10")
  22. memoryLimit := resource.MustParse("10G")
  23. resourceSpec := v1.ResourceRequirements{
  24. Limits: v1.ResourceList{
  25. v1.ResourceCPU: cpuLimit,
  26. v1.ResourceMemory: memoryLimit,
  27. },
  28. }
  29. if res := resourceSpec.Limits.Cpu(); res.Cmp(cpuLimit) != 0 {
  30. t.Errorf("expected cpulimit %v, got %v", cpuLimit, res)
  31. }
  32. if res := resourceSpec.Limits.Memory(); res.Cmp(memoryLimit) != 0 {
  33. t.Errorf("expected memorylimit %v, got %v", memoryLimit, res)
  34. }
  35. resourceSpec = v1.ResourceRequirements{
  36. Limits: v1.ResourceList{
  37. v1.ResourceMemory: memoryLimit,
  38. },
  39. }
  40. if res := resourceSpec.Limits.Cpu(); res.Value() != 0 {
  41. t.Errorf("expected cpulimit %v, got %v", 0, res)
  42. }
  43. if res := resourceSpec.Limits.Memory(); res.Cmp(memoryLimit) != 0 {
  44. t.Errorf("expected memorylimit %v, got %v", memoryLimit, res)
  45. }
  46. }
  47. func TestDefaultResourceHelpers(t *testing.T) {
  48. resourceList := v1.ResourceList{}
  49. if resourceList.Cpu().Format != resource.DecimalSI {
  50. t.Errorf("expected %v, actual %v", resource.DecimalSI, resourceList.Cpu().Format)
  51. }
  52. if resourceList.Memory().Format != resource.BinarySI {
  53. t.Errorf("expected %v, actual %v", resource.BinarySI, resourceList.Memory().Format)
  54. }
  55. }
  56. func TestExtractResourceValue(t *testing.T) {
  57. cases := []struct {
  58. fs *v1.ResourceFieldSelector
  59. pod *v1.Pod
  60. cName string
  61. expectedValue string
  62. expectedError error
  63. }{
  64. {
  65. fs: &v1.ResourceFieldSelector{
  66. Resource: "limits.cpu",
  67. },
  68. cName: "foo",
  69. pod: getPod("foo", "", "9", "", ""),
  70. expectedValue: "9",
  71. },
  72. {
  73. fs: &v1.ResourceFieldSelector{
  74. Resource: "requests.cpu",
  75. },
  76. cName: "foo",
  77. pod: getPod("foo", "", "", "", ""),
  78. expectedValue: "0",
  79. },
  80. {
  81. fs: &v1.ResourceFieldSelector{
  82. Resource: "requests.cpu",
  83. },
  84. cName: "foo",
  85. pod: getPod("foo", "8", "", "", ""),
  86. expectedValue: "8",
  87. },
  88. {
  89. fs: &v1.ResourceFieldSelector{
  90. Resource: "requests.cpu",
  91. },
  92. cName: "foo",
  93. pod: getPod("foo", "100m", "", "", ""),
  94. expectedValue: "1",
  95. },
  96. {
  97. fs: &v1.ResourceFieldSelector{
  98. Resource: "requests.cpu",
  99. Divisor: resource.MustParse("100m"),
  100. },
  101. cName: "foo",
  102. pod: getPod("foo", "1200m", "", "", ""),
  103. expectedValue: "12",
  104. },
  105. {
  106. fs: &v1.ResourceFieldSelector{
  107. Resource: "requests.memory",
  108. },
  109. cName: "foo",
  110. pod: getPod("foo", "", "", "100Mi", ""),
  111. expectedValue: "104857600",
  112. },
  113. {
  114. fs: &v1.ResourceFieldSelector{
  115. Resource: "requests.memory",
  116. Divisor: resource.MustParse("1Mi"),
  117. },
  118. cName: "foo",
  119. pod: getPod("foo", "", "", "100Mi", "1Gi"),
  120. expectedValue: "100",
  121. },
  122. {
  123. fs: &v1.ResourceFieldSelector{
  124. Resource: "limits.memory",
  125. },
  126. cName: "foo",
  127. pod: getPod("foo", "", "", "10Mi", "100Mi"),
  128. expectedValue: "104857600",
  129. },
  130. {
  131. fs: &v1.ResourceFieldSelector{
  132. Resource: "limits.cpu",
  133. },
  134. cName: "init-foo",
  135. pod: getPod("foo", "", "9", "", ""),
  136. expectedValue: "9",
  137. },
  138. {
  139. fs: &v1.ResourceFieldSelector{
  140. Resource: "requests.cpu",
  141. },
  142. cName: "init-foo",
  143. pod: getPod("foo", "", "", "", ""),
  144. expectedValue: "0",
  145. },
  146. {
  147. fs: &v1.ResourceFieldSelector{
  148. Resource: "requests.cpu",
  149. },
  150. cName: "init-foo",
  151. pod: getPod("foo", "8", "", "", ""),
  152. expectedValue: "8",
  153. },
  154. {
  155. fs: &v1.ResourceFieldSelector{
  156. Resource: "requests.cpu",
  157. },
  158. cName: "init-foo",
  159. pod: getPod("foo", "100m", "", "", ""),
  160. expectedValue: "1",
  161. },
  162. {
  163. fs: &v1.ResourceFieldSelector{
  164. Resource: "requests.cpu",
  165. Divisor: resource.MustParse("100m"),
  166. },
  167. cName: "init-foo",
  168. pod: getPod("foo", "1200m", "", "", ""),
  169. expectedValue: "12",
  170. },
  171. {
  172. fs: &v1.ResourceFieldSelector{
  173. Resource: "requests.memory",
  174. },
  175. cName: "init-foo",
  176. pod: getPod("foo", "", "", "100Mi", ""),
  177. expectedValue: "104857600",
  178. },
  179. {
  180. fs: &v1.ResourceFieldSelector{
  181. Resource: "requests.memory",
  182. Divisor: resource.MustParse("1Mi"),
  183. },
  184. cName: "init-foo",
  185. pod: getPod("foo", "", "", "100Mi", "1Gi"),
  186. expectedValue: "100",
  187. },
  188. {
  189. fs: &v1.ResourceFieldSelector{
  190. Resource: "limits.memory",
  191. },
  192. cName: "init-foo",
  193. pod: getPod("foo", "", "", "10Mi", "100Mi"),
  194. expectedValue: "104857600",
  195. },
  196. }
  197. as := assert.New(t)
  198. for idx, tc := range cases {
  199. actual, err := ExtractResourceValueByContainerName(tc.fs, tc.pod, tc.cName)
  200. if tc.expectedError != nil {
  201. as.Equal(tc.expectedError, err, "expected test case [%d] to fail with error %v; got %v", idx, tc.expectedError, err)
  202. } else {
  203. as.Nil(err, "expected test case [%d] to not return an error; got %v", idx, err)
  204. as.Equal(tc.expectedValue, actual, "expected test case [%d] to return %q; got %q instead", idx, tc.expectedValue, actual)
  205. }
  206. }
  207. }
  208. func getPod(cname, cpuRequest, cpuLimit, memoryRequest, memoryLimit string) *v1.Pod {
  209. resources := v1.ResourceRequirements{
  210. Limits: make(v1.ResourceList),
  211. Requests: make(v1.ResourceList),
  212. }
  213. if cpuLimit != "" {
  214. resources.Limits[v1.ResourceCPU] = resource.MustParse(cpuLimit)
  215. }
  216. if memoryLimit != "" {
  217. resources.Limits[v1.ResourceMemory] = resource.MustParse(memoryLimit)
  218. }
  219. if cpuRequest != "" {
  220. resources.Requests[v1.ResourceCPU] = resource.MustParse(cpuRequest)
  221. }
  222. if memoryRequest != "" {
  223. resources.Requests[v1.ResourceMemory] = resource.MustParse(memoryRequest)
  224. }
  225. return &v1.Pod{
  226. Spec: v1.PodSpec{
  227. Containers: []v1.Container{
  228. {
  229. Name: cname,
  230. Resources: resources,
  231. },
  232. },
  233. InitContainers: []v1.Container{
  234. {
  235. Name: "init-" + cname,
  236. Resources: resources,
  237. },
  238. },
  239. },
  240. }
  241. }