pulumi/tests/testdata/codegen/kubernetes-pod-pp/python/kubernetes-pod.py

47 lines
1.2 KiB
Python
Raw Permalink Normal View History

import pulumi
import pulumi_kubernetes as kubernetes
bar = kubernetes.core.v1.Pod("bar",
api_version="v1",
metadata={
"namespace": "foo",
"name": "bar",
"labels": {
"app_kubernetes_io_name": "cilium-agent",
"app_kubernetes_io_part_of": "cilium",
"k8s_app": "cilium",
[program-gen/csharp,python] Allow object keys to be template expressions (#15000) # Description I've noticed while working with PCL generated from Kubernetes manifests that when an object property key is quoted for example `{ "key" = value }` instead of `{ key = value }` then program-gen for csharp and python _panic_ because they assume the object keys to be strictly a literal value expression and this type assertion fails: ```go lit := item.Key.(*model.LiteralValueExpression) ``` This PR fixes this panic and allows program-gen to handle cases where the object keys are `TemplateExpression` assuming that it has one part which is a literal value expression (handling cases like `{ "key" = value }`) ## Checklist - [ ] I have run `make tidy` to update any new dependencies - [ ] I have run `make lint` to verify my code passes the lint check - [ ] I have formatted my code using `gofumpt` <!--- Please provide details if the checkbox below is to be left unchecked. --> - [x] I have added tests that prove my fix is effective or that my feature works <!--- User-facing changes require a CHANGELOG entry. --> - [x] I have run `make changelog` and committed the `changelog/pending/<file>` documenting my change <!-- If the change(s) in this PR is a modification of an existing call to the Pulumi Cloud, then the service should honor older versions of the CLI where this change would not exist. You must then bump the API version in /pkg/backend/httpstate/client/api.go, as well as add it to the service. --> - [ ] Yes, there are changes in this PR that warrants bumping the Pulumi Cloud API version <!-- @Pulumi employees: If yes, you must submit corresponding changes in the service repo. -->
2023-12-23 11:26:01 +00:00
},
},
spec={
"containers": [
{
"name": "nginx",
"image": "nginx:1.14-alpine",
"ports": [{
"container_port": 80,
}],
"resources": {
"limits": {
"memory": "20Mi",
"cpu": "0.2",
},
},
},
{
"name": "nginx2",
"image": "nginx:1.14-alpine",
"ports": [{
"container_port": 80,
}],
"resources": {
"limits": {
"memory": "20Mi",
"cpu": "0.2",
},
},
},
],
})
# Test that we can assign from a constant without type errors
kind = bar.kind