bat/tests/syntax-tests/source/Rego/src_test.rego

182 lines
4.3 KiB
Rego

package k8sazureprocmount
test_input_container_not_proc_mount_allowed {
input := { "review": input_review, "parameters": input_parameters_default}
results := violation with input as input
count(results) == 0
}
test_input_container_proc_mount_not_allowed {
input := { "review": input_review_unmasked, "parameters": input_parameters_default}
results := violation with input as input
count(results) == 1
}
test_input_container_proc_mount_not_allowed_null_param {
input := { "review": input_review_unmasked, "parameters": null }
results := violation with input as input
count(results) == 1
}
test_input_container_proc_mount_not_allowed_missing_param {
input := { "review": input_review_unmasked }
results := violation with input as input
count(results) == 1
}
test_input_container_many_not_proc_mount_allowed {
input := { "review": input_review_many, "parameters": input_parameters_default}
results := violation with input as input
count(results) == 0
}
test_input_container_many_mixed_proc_mount_not_allowed {
input := { "review": input_review_many_mixed, "parameters": input_parameters_default}
results := violation with input as input
count(results) == 1
}
test_input_container_many_mixed_proc_mount_not_allowed_two {
input := { "review": input_review_many_mixed_two, "parameters": input_parameters_default}
results := violation with input as input
count(results) == 2
}
test_input_container_proc_mount_case_insensitive {
input := { "review": input_review, "parameters": input_parameters_default_lower}
results := violation with input as input
count(results) == 0
}
test_input_container_not_proc_mount_unmasked {
input := { "review": input_review, "parameters": input_parameters_unmasked}
results := violation with input as input
count(results) == 0
}
test_input_container_proc_mount_unmasked {
input := { "review": input_review_unmasked, "parameters": input_parameters_unmasked}
results := violation with input as input
count(results) == 0
}
test_input_container_many_mixed_proc_mount_allowed_two {
input := { "review": input_review_many_mixed_two, "parameters": input_parameters_unmasked}
results := violation with input as input
count(results) == 0
}
input_review = {
"object": {
"metadata": {
"name": "nginx"
},
"spec": {
"containers": input_containers_one
}
}
}
input_review_unmasked = {
"object": {
"metadata": {
"name": "nginx"
},
"spec": {
"containers": input_containers_one_unmasked
}
}
}
input_review_many = {
"object": {
"metadata": {
"name": "nginx"
},
"spec": {
"containers": input_containers_many,
"initContainers": input_containers_one
}
}
}
input_review_many_mixed = {
"object": {
"metadata": {
"name": "nginx"
},
"spec": {
"containers": input_containers_many,
"initContainers": input_containers_one_unmasked
}
}
}
input_review_many_mixed_two = {
"object": {
"metadata": {
"name": "nginx"
},
"spec": {
"containers": input_containers_many_mixed,
"initContainers": input_containers_one_unmasked
}
}
}
input_containers_one = [
{
"name": "nginx",
"image": "nginx",
"securityContext": {
"procMount": "Default"
}
}]
input_containers_one_unmasked = [
{
"name": "nginx",
"image": "nginx",
"securityContext": {
"procMount": "Unmasked"
}
}]
input_containers_many = [
{
"name": "nginx",
"image": "nginx",
"securityContext": {
"procMount": "Default"
}
},
{
"name": "nginx1",
"image": "nginx"
},
{
"name": "nginx2",
"image": "nginx",
"securityContext": {
"runAsUser": "1000"
}
}]
input_containers_many_mixed = [
{
"name": "nginx",
"image": "nginx",
"securityContext": {
"procMount": "Default"
}
},
{
"name": "nginx1",
"image": "nginx",
"securityContext": {
"procMount": "Unmasked"
}
}]
input_parameters_default = {
"procMount": "Default"
}
input_parameters_default_lower = {
"procMount": "default"
}
input_parameters_unmasked = {
"procMount": "Unmasked"
}