securityContext.yaml 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497
  1. suite: pod securityContext test
  2. templates:
  3. - common.yaml
  4. tests:
  5. - it: should pass with securityContext from "global"
  6. set:
  7. securityContext:
  8. pod:
  9. fsGroup: 1000
  10. fsGroupChangePolicy: OnRootMismatch
  11. supplementalGroups:
  12. - 1000
  13. - 1001
  14. sysctls:
  15. - name: some_name
  16. value: "some_value"
  17. - name: some_other_name
  18. value: "some_other_value"
  19. workload:
  20. workload-name1:
  21. enabled: true
  22. primary: true
  23. type: Deployment
  24. podSpec: {}
  25. asserts:
  26. - documentIndex: &deploymentDoc 0
  27. isKind:
  28. of: Deployment
  29. - documentIndex: *deploymentDoc
  30. equal:
  31. path: spec.template.spec.securityContext
  32. value:
  33. fsGroup: 1000
  34. fsGroupChangePolicy: OnRootMismatch
  35. supplementalGroups:
  36. - 1000
  37. - 1001
  38. sysctls:
  39. - name: some_name
  40. value: "some_value"
  41. - name: some_other_name
  42. value: "some_other_value"
  43. - it: should pass with securityContext from "global" and partial override with "pod"
  44. set:
  45. securityContext:
  46. pod:
  47. fsGroup: 1000
  48. fsGroupChangePolicy: OnRootMismatch
  49. supplementalGroups:
  50. - 1000
  51. - 1001
  52. sysctls:
  53. - name: some_name
  54. value: "some_value"
  55. - name: some_other_name
  56. value: "some_other_value"
  57. workload:
  58. workload-name1:
  59. enabled: true
  60. primary: true
  61. type: Deployment
  62. podSpec:
  63. securityContext:
  64. fsGroup: 1001
  65. asserts:
  66. - documentIndex: *deploymentDoc
  67. isKind:
  68. of: Deployment
  69. - documentIndex: *deploymentDoc
  70. equal:
  71. path: spec.template.spec.securityContext
  72. value:
  73. fsGroup: 1001
  74. fsGroupChangePolicy: OnRootMismatch
  75. supplementalGroups:
  76. - 1000
  77. - 1001
  78. sysctls:
  79. - name: some_name
  80. value: "some_value"
  81. - name: some_other_name
  82. value: "some_other_value"
  83. - it: should pass with securityContext from "global" and full override with "pod"
  84. set:
  85. some_sysctl_name: some_name
  86. some_sysctl_value: 2
  87. securityContext:
  88. pod:
  89. fsGroup: 1000
  90. fsGroupChangePolicy: OnRootMismatch
  91. supplementalGroups:
  92. - 1000
  93. - 1001
  94. sysctls:
  95. - name: some_name
  96. value: "some_value"
  97. - name: some_other_name
  98. value: "some_other_value"
  99. workload:
  100. workload-name1:
  101. enabled: true
  102. primary: true
  103. type: Deployment
  104. podSpec:
  105. securityContext:
  106. fsGroup: 1001
  107. fsGroupChangePolicy: Always
  108. supplementalGroups:
  109. - 1002
  110. - 1003
  111. sysctls:
  112. - name: "{{ .Values.some_sysctl_name }}"
  113. value: "{{ .Values.some_sysctl_value }}"
  114. - name: some_other_name
  115. value: "some_different_value"
  116. asserts:
  117. - documentIndex: *deploymentDoc
  118. isKind:
  119. of: Deployment
  120. - documentIndex: *deploymentDoc
  121. equal:
  122. path: spec.template.spec.securityContext
  123. value:
  124. fsGroup: 1001
  125. fsGroupChangePolicy: Always
  126. supplementalGroups:
  127. - 1002
  128. - 1003
  129. sysctls:
  130. - name: some_name
  131. value: "2"
  132. - name: some_other_name
  133. value: "some_different_value"
  134. - it: should pass with sysctls automatically appended based on services
  135. set:
  136. some_sysctl_name: some_name
  137. some_sysctl_value: 2
  138. workload:
  139. workload-name1:
  140. enabled: true
  141. primary: true
  142. type: Deployment
  143. podSpec:
  144. securityContext:
  145. fsGroup: 1001
  146. fsGroupChangePolicy: Always
  147. supplementalGroups:
  148. - 1002
  149. - 1003
  150. sysctls:
  151. - name: "{{ .Values.some_sysctl_name }}"
  152. value: "{{ .Values.some_sysctl_value }}"
  153. - name: some_other_name
  154. value: "some_different_value"
  155. workload-name2:
  156. enabled: true
  157. type: Deployment
  158. podSpec: {}
  159. service:
  160. service-name1:
  161. enabled: true
  162. primary: true
  163. type: ClusterIP
  164. ports:
  165. port-name:
  166. enabled: true
  167. primary: true
  168. port: 80
  169. service-name2:
  170. enabled: true
  171. type: ClusterIP
  172. ports:
  173. port-name:
  174. enabled: true
  175. primary: true
  176. port: 53
  177. service-name3:
  178. enabled: true
  179. type: ClusterIP
  180. targetSelector: workload-name2
  181. ports:
  182. port-name:
  183. enabled: true
  184. primary: true
  185. port: 443
  186. asserts:
  187. - documentIndex: *deploymentDoc
  188. isKind:
  189. of: Deployment
  190. - documentIndex: *deploymentDoc
  191. equal:
  192. path: spec.template.spec.securityContext
  193. value:
  194. fsGroup: 1001
  195. fsGroupChangePolicy: Always
  196. supplementalGroups:
  197. - 1002
  198. - 1003
  199. sysctls:
  200. - name: some_name
  201. value: "2"
  202. - name: some_other_name
  203. value: "some_different_value"
  204. - name: net.ipv4.ip_unprivileged_port_start
  205. value: "53"
  206. - documentIndex: &otherdeploymentDoc 1
  207. isKind:
  208. of: Deployment
  209. - documentIndex: *otherdeploymentDoc
  210. equal:
  211. path: spec.template.spec.securityContext
  212. value:
  213. fsGroup: 568
  214. fsGroupChangePolicy: OnRootMismatch
  215. supplementalGroups: []
  216. sysctls:
  217. - name: net.ipv4.ip_unprivileged_port_start
  218. value: "443"
  219. - it: should pass with no sysctls port_start automatically appended based on services when port is higher than 1024
  220. set:
  221. workload:
  222. workload-name1:
  223. enabled: true
  224. primary: true
  225. type: Deployment
  226. podSpec: {}
  227. service:
  228. service-name1:
  229. enabled: true
  230. primary: true
  231. type: ClusterIP
  232. ports:
  233. port-name:
  234. enabled: true
  235. primary: true
  236. port: 25000
  237. targetPort: 3000
  238. asserts:
  239. - documentIndex: &deploymentDoc 0
  240. isKind:
  241. of: Deployment
  242. - documentIndex: *deploymentDoc
  243. equal:
  244. path: spec.template.spec.securityContext
  245. value:
  246. fsGroup: 568
  247. fsGroupChangePolicy: OnRootMismatch
  248. supplementalGroups: []
  249. sysctls: []
  250. - it: should pass with with gpu assigned to primary pod
  251. set:
  252. workload:
  253. workload-name1:
  254. enabled: true
  255. primary: true
  256. type: Deployment
  257. podSpec:
  258. securityContext:
  259. supplementalGroups:
  260. - 1000
  261. workload-name2:
  262. enabled: true
  263. primary: false
  264. type: Deployment
  265. podSpec: {}
  266. scaleGPU:
  267. - gpu:
  268. nvidia: "1"
  269. asserts:
  270. - documentIndex: &deploymentDoc 0
  271. isKind:
  272. of: Deployment
  273. - documentIndex: *deploymentDoc
  274. equal:
  275. path: spec.template.spec.securityContext
  276. value:
  277. fsGroup: 568
  278. fsGroupChangePolicy: OnRootMismatch
  279. supplementalGroups:
  280. - 1000
  281. - 44
  282. sysctls: []
  283. - documentIndex: &otherDeploymentDoc 1
  284. isKind:
  285. of: Deployment
  286. - documentIndex: *otherDeploymentDoc
  287. equal:
  288. path: spec.template.spec.securityContext
  289. value:
  290. fsGroup: 568
  291. fsGroupChangePolicy: OnRootMismatch
  292. supplementalGroups: []
  293. sysctls: []
  294. - it: should pass with with gpu assigned to specific pod
  295. set:
  296. workload:
  297. workload-name1:
  298. enabled: true
  299. primary: true
  300. type: Deployment
  301. podSpec:
  302. securityContext:
  303. supplementalGroups:
  304. - 1000
  305. workload-name2:
  306. enabled: true
  307. primary: false
  308. type: Deployment
  309. podSpec: {}
  310. scaleGPU:
  311. - gpu:
  312. nvidia: "1"
  313. targetSelector:
  314. workload-name1:
  315. - container-name1
  316. asserts:
  317. - documentIndex: &deploymentDoc 0
  318. isKind:
  319. of: Deployment
  320. - documentIndex: *deploymentDoc
  321. equal:
  322. path: spec.template.spec.securityContext
  323. value:
  324. fsGroup: 568
  325. fsGroupChangePolicy: OnRootMismatch
  326. supplementalGroups:
  327. - 1000
  328. - 44
  329. sysctls: []
  330. - documentIndex: &otherDeploymentDoc 1
  331. isKind:
  332. of: Deployment
  333. - documentIndex: *otherDeploymentDoc
  334. equal:
  335. path: spec.template.spec.securityContext
  336. value:
  337. fsGroup: 568
  338. fsGroupChangePolicy: OnRootMismatch
  339. supplementalGroups: []
  340. sysctls: []
  341. - it: should pass with with gpu assigned to multiple pod
  342. set:
  343. workload:
  344. workload-name1:
  345. enabled: true
  346. primary: true
  347. type: Deployment
  348. podSpec:
  349. securityContext:
  350. supplementalGroups:
  351. - 1000
  352. workload-name2:
  353. enabled: true
  354. primary: false
  355. type: Deployment
  356. podSpec: {}
  357. scaleGPU:
  358. - gpu:
  359. nvidia: "1"
  360. targetSelector:
  361. workload-name1:
  362. - container-name1
  363. workload-name2:
  364. - container-name1
  365. asserts:
  366. - documentIndex: &deploymentDoc 0
  367. isKind:
  368. of: Deployment
  369. - documentIndex: *deploymentDoc
  370. equal:
  371. path: spec.template.spec.securityContext
  372. value:
  373. fsGroup: 568
  374. fsGroupChangePolicy: OnRootMismatch
  375. supplementalGroups:
  376. - 1000
  377. - 44
  378. sysctls: []
  379. - documentIndex: &otherDeploymentDoc 1
  380. isKind:
  381. of: Deployment
  382. - documentIndex: *otherDeploymentDoc
  383. equal:
  384. path: spec.template.spec.securityContext
  385. value:
  386. fsGroup: 568
  387. fsGroupChangePolicy: OnRootMismatch
  388. supplementalGroups:
  389. - 44
  390. sysctls: []
  391. # Failures
  392. - it: should fail with empty securityContext from "global"
  393. set:
  394. securityContext:
  395. pod: null
  396. workload:
  397. workload-name1:
  398. enabled: true
  399. primary: true
  400. type: Deployment
  401. podSpec: {}
  402. asserts:
  403. - failedTemplate:
  404. errorMessage: Pod - Expected non-empty <.Values.securityContext.pod>
  405. - it: should fail with empty fsGroup
  406. set:
  407. securityContext:
  408. pod:
  409. fsGroup: ""
  410. workload:
  411. workload-name1:
  412. enabled: true
  413. primary: true
  414. type: Deployment
  415. podSpec: {}
  416. asserts:
  417. - failedTemplate:
  418. errorMessage: Pod - Expected non-empty <fsGroup>
  419. - it: should fail with empty fsGroupChangePolicy
  420. set:
  421. securityContext:
  422. pod:
  423. fsGroup: 568
  424. fsGroupChangePolicy: ""
  425. workload:
  426. workload-name1:
  427. enabled: true
  428. primary: true
  429. type: Deployment
  430. podSpec: {}
  431. asserts:
  432. - failedTemplate:
  433. errorMessage: Pod - Expected non-empty <fsGroupChangePolicy>
  434. - it: should fail with invalid fsGroupChangePolicy
  435. set:
  436. securityContext:
  437. pod:
  438. fsGroup: 568
  439. fsGroupChangePolicy: invalid
  440. workload:
  441. workload-name1:
  442. enabled: true
  443. primary: true
  444. type: Deployment
  445. podSpec: {}
  446. asserts:
  447. - failedTemplate:
  448. errorMessage: Pod - Expected <fsGroupChangePolicy> to be one of [Always, OnRootMismatch], but got [invalid]
  449. - it: should fail with empty name in sysctls
  450. set:
  451. securityContext:
  452. pod:
  453. fsGroup: 568
  454. fsGroupChangePolicy: OnRootMismatch
  455. sysctls:
  456. - name: ""
  457. value: "some_value"
  458. workload:
  459. workload-name1:
  460. enabled: true
  461. primary: true
  462. type: Deployment
  463. podSpec: {}
  464. asserts:
  465. - failedTemplate:
  466. errorMessage: Pod - Expected non-empty <name> in <sysctls>
  467. - it: should fail with empty value in sysctls
  468. set:
  469. securityContext:
  470. pod:
  471. fsGroup: 568
  472. fsGroupChangePolicy: OnRootMismatch
  473. sysctls:
  474. - name: some_name
  475. value: ""
  476. workload:
  477. workload-name1:
  478. enabled: true
  479. primary: true
  480. type: Deployment
  481. podSpec: {}
  482. asserts:
  483. - failedTemplate:
  484. errorMessage: Pod - Expected non-empty <value> in <sysctls>