strategicmerge_test.go 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. /*
  2. Copyright 2019 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 kustomize
  14. import (
  15. "testing"
  16. "github.com/lithammer/dedent"
  17. "k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
  18. "k8s.io/apimachinery/pkg/runtime/schema"
  19. )
  20. func TestNewStategicMergeSliceFromBytes(t *testing.T) {
  21. var useCases = []struct {
  22. name string
  23. in string
  24. expectedPatches int
  25. expectedError bool
  26. }{
  27. {
  28. name: "empty",
  29. in: "",
  30. expectedPatches: 0,
  31. },
  32. {
  33. name: "single patch",
  34. in: dedent.Dedent(`
  35. apiVersion: v1
  36. kind: Pod
  37. metadata:
  38. name: kube-apiserver
  39. `),
  40. expectedPatches: 1,
  41. },
  42. {
  43. name: "two patches as separated yaml documents",
  44. in: dedent.Dedent(`
  45. apiVersion: v1
  46. kind: Pod
  47. metadata:
  48. name: kube-apiserver
  49. ---
  50. apiVersion: v1
  51. kind: Pod
  52. metadata:
  53. name: kube-apiserver
  54. `),
  55. expectedPatches: 2,
  56. },
  57. {
  58. name: "two patches as a k8s list",
  59. in: dedent.Dedent(`
  60. apiVersion: v1
  61. kind: List
  62. items:
  63. - apiVersion: v1
  64. kind: Pod
  65. metadata:
  66. name: kube-apiserver
  67. - apiVersion: v1
  68. kind: Pod
  69. metadata:
  70. name: kube-apiserver
  71. `),
  72. expectedPatches: 2,
  73. },
  74. {
  75. name: "nested k8s lists",
  76. in: dedent.Dedent(`
  77. apiVersion: v1
  78. kind: List
  79. items:
  80. - apiVersion: v1
  81. kind: Pod
  82. metadata:
  83. name: kube-apiserver
  84. - apiVersion: v1
  85. kind: List
  86. items:
  87. - apiVersion: v1
  88. kind: Pod
  89. metadata:
  90. name: kube-apiserver
  91. `),
  92. expectedPatches: 2,
  93. },
  94. {
  95. name: "invalid yaml",
  96. in: "$$$",
  97. expectedError: true,
  98. },
  99. {
  100. name: "invalid patch (missing kind)",
  101. in: dedent.Dedent(`
  102. apiVersion: v1
  103. #kind: Pod
  104. metadata:
  105. name: kube-apiserver
  106. `),
  107. expectedError: true,
  108. },
  109. {
  110. name: "invalid patch (missing name)",
  111. in: dedent.Dedent(`
  112. apiVersion: v1
  113. kind: Pod
  114. metadata:
  115. #name: kube-apiserver
  116. `),
  117. expectedError: true,
  118. },
  119. }
  120. for _, rt := range useCases {
  121. t.Run(rt.name, func(t *testing.T) {
  122. r, err := newStrategicMergeSliceFromBytes([]byte(rt.in))
  123. if err != nil {
  124. if !rt.expectedError {
  125. t.Errorf("newStrategicMergeSliceFromBytes returned unexpected error: %v", err)
  126. }
  127. return
  128. }
  129. if err == nil && rt.expectedError {
  130. t.Error("newStrategicMergeSliceFromBytes does not returned expected error")
  131. }
  132. if len(r) != rt.expectedPatches {
  133. t.Errorf("Expected %d strategic merge patches in the slice, actual %d", rt.expectedPatches, len(r))
  134. }
  135. })
  136. }
  137. }
  138. func TestFilterResource(t *testing.T) {
  139. in := dedent.Dedent(`
  140. apiVersion: v1
  141. kind: Pod
  142. metadata:
  143. name: kube-apiserver
  144. namespace: kube-system
  145. ---
  146. apiVersion: v1
  147. kind: Pod
  148. metadata:
  149. name: kube-scheduler
  150. namespace: kube-system
  151. ---
  152. apiVersion: v1
  153. kind: Pod
  154. metadata:
  155. name: kube-scheduler
  156. namespace: kube-system
  157. `)
  158. u, err := newStrategicMergeSliceFromBytes([]byte(in))
  159. if err != nil {
  160. t.Fatalf("newStategicMergeSliceFromBytes returned unexpected error: %v", err)
  161. }
  162. var useCases = []struct {
  163. name string
  164. rgvk schema.GroupVersionKind
  165. rnamespace string
  166. rname string
  167. expectedPatches int
  168. }{
  169. {
  170. name: "match 1",
  171. rgvk: schema.GroupVersionKind{Group: "", Version: "v1", Kind: "Pod"},
  172. rnamespace: "kube-system",
  173. rname: "kube-apiserver",
  174. expectedPatches: 1,
  175. },
  176. {
  177. name: "match 2",
  178. rgvk: schema.GroupVersionKind{Group: "", Version: "v1", Kind: "Pod"},
  179. rnamespace: "kube-system",
  180. rname: "kube-scheduler",
  181. expectedPatches: 2,
  182. },
  183. {
  184. name: "match 0 (wrong gvk)",
  185. rgvk: schema.GroupVersionKind{Group: "something", Version: "v1", Kind: "Pod"},
  186. rnamespace: "kube-system",
  187. rname: "kube-scheduler",
  188. expectedPatches: 0,
  189. },
  190. {
  191. name: "match 0 (wrong namespace)",
  192. rgvk: schema.GroupVersionKind{Group: "", Version: "v1", Kind: "Pod"},
  193. rnamespace: "kube-something",
  194. rname: "kube-scheduler",
  195. expectedPatches: 0,
  196. },
  197. {
  198. name: "match 0 (wrong namr)",
  199. rgvk: schema.GroupVersionKind{Group: "", Version: "v1", Kind: "Pod"},
  200. rnamespace: "kube-system",
  201. rname: "kube-something",
  202. expectedPatches: 0,
  203. },
  204. }
  205. for _, rt := range useCases {
  206. t.Run(rt.name, func(t *testing.T) {
  207. resource := &unstructured.Unstructured{}
  208. resource.SetGroupVersionKind(rt.rgvk)
  209. resource.SetNamespace(rt.rnamespace)
  210. resource.SetName(rt.rname)
  211. r := u.filterByResource(resource)
  212. if len(r) != rt.expectedPatches {
  213. t.Errorf("Expected %d strategic merge patches in the slice, actual %d", rt.expectedPatches, len(r))
  214. }
  215. })
  216. }
  217. }