From 8c7ee46610ffe1fa174374894d2cec59b83e3505 Mon Sep 17 00:00:00 2001 From: Julien Poissonnier Date: Wed, 17 Jul 2024 13:23:20 +0200 Subject: [PATCH] Use dictionary literals for python examples Updates the following examples to use typed dictionaries * aws-py-s3-folder * kubernetes-py-exposed-deployment * kubernetes-py-guestbook/simple --- aws-py-s3-folder/__main__.py | 62 ++-- kubernetes-py-exposed-deployment/README.md | 2 +- kubernetes-py-exposed-deployment/__main__.py | 73 ++-- .../requirements.txt | 4 +- kubernetes-py-guestbook/simple/__main__.py | 322 ++++++++++-------- .../simple/requirements.txt | 4 +- 6 files changed, 249 insertions(+), 218 deletions(-) diff --git a/aws-py-s3-folder/__main__.py b/aws-py-s3-folder/__main__.py index c2703f955..9a124ccdb 100644 --- a/aws-py-s3-folder/__main__.py +++ b/aws-py-s3-folder/__main__.py @@ -5,46 +5,52 @@ from pulumi import FileAsset, Output, export, ResourceOptions from pulumi_aws import s3 -web_bucket = s3.Bucket('s3-website-bucket', - website=s3.BucketWebsiteArgs( - index_document="index.html", - )) +web_bucket = s3.Bucket( + "s3-website-bucket", + website={ + "index_document": "index.html", + }, +) public_access_block = s3.BucketPublicAccessBlock( - 'public-access-block', - bucket=web_bucket.id, - block_public_acls=False) + "public-access-block", bucket=web_bucket.id, block_public_acls=False +) content_dir = "www" for file in os.listdir(content_dir): filepath = os.path.join(content_dir, file) mime_type, _ = mimetypes.guess_type(filepath) - obj = s3.BucketObject(file, - bucket=web_bucket.id, - source=FileAsset(filepath), - content_type=mime_type) + obj = s3.BucketObject( + file, bucket=web_bucket.id, source=FileAsset(filepath), content_type=mime_type + ) + def public_read_policy_for_bucket(bucket_name): - return Output.json_dumps({ - "Version": "2012-10-17", - "Statement": [{ - "Effect": "Allow", - "Principal": "*", - "Action": [ - "s3:GetObject" + return Output.json_dumps( + { + "Version": "2012-10-17", + "Statement": [ + { + "Effect": "Allow", + "Principal": "*", + "Action": ["s3:GetObject"], + "Resource": [ + Output.format("arn:aws:s3:::{0}/*", bucket_name), + ], + } ], - "Resource": [ - Output.format("arn:aws:s3:::{0}/*", bucket_name), - ] - }] - }) + } + ) + bucket_name = web_bucket.id -bucket_policy = s3.BucketPolicy("bucket-policy", +bucket_policy = s3.BucketPolicy( + "bucket-policy", bucket=bucket_name, - policy=public_read_policy_for_bucket(bucket_name), - opts=ResourceOptions(depends_on=[public_access_block])) + policy=public_read_policy_for_bucket(bucket_name), + opts=ResourceOptions(depends_on=[public_access_block]), +) # Export the name of the bucket -export('bucket_name', web_bucket.id) -export('website_url', web_bucket.website_endpoint) +export("bucket_name", web_bucket.id) +export("website_url", web_bucket.website_endpoint) diff --git a/kubernetes-py-exposed-deployment/README.md b/kubernetes-py-exposed-deployment/README.md index 03761557a..a7ed24444 100644 --- a/kubernetes-py-exposed-deployment/README.md +++ b/kubernetes-py-exposed-deployment/README.md @@ -74,7 +74,7 @@ case `35.226.79.225`. It is exported with a stack output variable, `frontend_ip` and `grep` to retrieve the `` of the site the proxy points at. > _Note_: minikube does not support type `LoadBalancer`; if you are deploying to minikube, make sure -> to run `kubectl port-forward service/frontend 8080:80` to forward the cluster port to the local +> to run `kubectl port-forward $(kubectl get service -l app=nginx -o name) 8080:80` to forward the cluster port to the local > machine and access the service via `localhost:8080`. ```sh diff --git a/kubernetes-py-exposed-deployment/__main__.py b/kubernetes-py-exposed-deployment/__main__.py index 97d93e6d8..63c348b7d 100644 --- a/kubernetes-py-exposed-deployment/__main__.py +++ b/kubernetes-py-exposed-deployment/__main__.py @@ -1,4 +1,4 @@ -"""Copyright 2016-2019, Pulumi Corporation. All rights reserved.""" +"""Copyright 2016-2024, Pulumi Corporation. All rights reserved.""" import pulumi import pulumi_kubernetes as k8s @@ -9,48 +9,49 @@ """nginx container, replicated 1 time.""" app_name = "nginx" -app_labels = { "app": app_name } +app_labels = {"app": app_name} nginx = k8s.apps.v1.Deployment( - app_name, - spec=k8s.apps.v1.DeploymentSpecArgs( - replicas=1, - selector=k8s.meta.v1.LabelSelectorArgs(match_labels=app_labels), - template=k8s.core.v1.PodTemplateSpecArgs( - metadata=k8s.meta.v1.ObjectMetaArgs(labels=app_labels), - spec=k8s.core.v1.PodSpecArgs( - containers=[ - k8s.core.v1.ContainerArgs( - name=app_name, - image="nginx:1.15-alpine", - ) - ] - ), - ), - ) - ) + app_name, + spec={ + "replicas": 1, + "selector": {"match_labels": app_labels}, + "template": { + "metadata": {"labels": app_labels}, + "spec": { + "containers": [ + { + "name": app_name, + "image": "nginx:1.16-alpine", + } + ] + }, + }, + }, +) """Allocate an IP to the nginx Deployment.""" frontend = k8s.core.v1.Service( - app_name, - metadata=k8s.meta.v1.ObjectMetaArgs( - labels=app_labels), - spec=k8s.core.v1.ServiceSpecArgs( - selector=app_labels, - ports=[ - k8s.core.v1.ServicePortArgs( - port=80, - target_port=80, - protocol="TCP" - ) - ], - type="ClusterIP" if is_minikube == "true" else "LoadBalancer", - ), - ) + app_name, + metadata={"labels": app_labels}, + spec={ + "selector": app_labels, + "ports": [{"port": 80, "target_port": 80, "protocol": "TCP"}], + "type": "ClusterIP" if is_minikube == "true" else "LoadBalancer", + }, +) # """When "done", this will print the public IP.""" if is_minikube == "true": - pulumi.export("frontend_IP", frontend.spec.apply(lambda s: s.cluster_ip)) + pulumi.export("frontend_IP", frontend.spec.apply(lambda s: s.cluster_ip)) else: - pulumi.export("frontend_IP", frontend.status.apply(lambda s: s.load_balancer.ingress[0].ip)) + pulumi.export( + "frontend_IP", + frontend.status.apply( + lambda s: s + and s.load_balancer + and s.load_balancer.ingress + and s.load_balancer.ingress[0].ip + ), + ) diff --git a/kubernetes-py-exposed-deployment/requirements.txt b/kubernetes-py-exposed-deployment/requirements.txt index b408ae4f4..372fc114d 100644 --- a/kubernetes-py-exposed-deployment/requirements.txt +++ b/kubernetes-py-exposed-deployment/requirements.txt @@ -1,2 +1,2 @@ -pulumi>=3.5.1,<4.0.0 -pulumi-kubernetes>=3.4.0,<4.0.0 +pulumi>=3.124.0,<4.0.0 +pulumi-kubernetes>=4.15.0,<5.0.0 diff --git a/kubernetes-py-guestbook/simple/__main__.py b/kubernetes-py-guestbook/simple/__main__.py index 24cffab38..85bc5f776 100644 --- a/kubernetes-py-guestbook/simple/__main__.py +++ b/kubernetes-py-guestbook/simple/__main__.py @@ -1,4 +1,4 @@ -# Copyright 2016-2020, Pulumi Corporation. +# Copyright 2016-2024, Pulumi Corporation. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -15,15 +15,15 @@ import pulumi from pulumi_kubernetes.apps.v1 import Deployment, DeploymentSpecArgs from pulumi_kubernetes.core.v1 import ( - ContainerArgs, - ContainerPortArgs, - EnvVarArgs, - PodSpecArgs, - PodTemplateSpecArgs, - ResourceRequirementsArgs, - Service, - ServicePortArgs, - ServiceSpecArgs, + ContainerArgs, + ContainerPortArgs, + EnvVarArgs, + PodSpecArgs, + PodTemplateSpecArgs, + ResourceRequirementsArgs, + Service, + ServicePortArgs, + ServiceSpecArgs, ) from pulumi_kubernetes.meta.v1 import LabelSelectorArgs, ObjectMetaArgs @@ -33,167 +33,191 @@ isMinikube = config.get_bool("isMinikube") redis_leader_labels = { - "app": "redis-leader", + "app": "redis-leader", } redis_leader_deployment = Deployment( - "redis-leader", - spec=DeploymentSpecArgs( - selector=LabelSelectorArgs( - match_labels=redis_leader_labels, - ), - replicas=1, - template=PodTemplateSpecArgs( - metadata=ObjectMetaArgs( - labels=redis_leader_labels, - ), - spec=PodSpecArgs( - containers=[ContainerArgs( - name="redis-leader", - image="redis", - resources=ResourceRequirementsArgs( - requests={ - "cpu": "100m", - "memory": "100Mi", - }, - ), - ports=[ContainerPortArgs( - container_port=6379, - )], - )], - ), - ), - )) + "redis-leader", + spec={ + "selector": { + "match_labels": redis_leader_labels, + }, + "replicas": 1, + "template": { + "metadata": { + "labels": redis_leader_labels, + }, + "spec": { + "containers": [ + { + "name": "redis-leader", + "image": "redis", + "resources": { + "requests": { + "cpu": "100m", + "memory": "100Mi", + }, + }, + "ports": [ + { + "container_port": 6379, + } + ], + } + ], + }, + }, + }, +) redis_leader_service = Service( - "redis-leader", - metadata=ObjectMetaArgs( - name="redis-leader", - labels=redis_leader_labels - ), - spec=ServiceSpecArgs( - ports=[ServicePortArgs( - port=6379, - target_port=6379, - )], - selector=redis_leader_labels - )) + "redis-leader", + metadata={"name": "redis-leader", "labels": redis_leader_labels}, + spec={ + "ports": [ + { + "port": 6379, + "target_port": 6379, + } + ], + "selector": redis_leader_labels, + }, +) redis_replica_labels = { - "app": "redis-replica", + "app": "redis-replica", } redis_replica_deployment = Deployment( - "redis-replica", - spec=DeploymentSpecArgs( - selector=LabelSelectorArgs( - match_labels=redis_replica_labels - ), - replicas=1, - template=PodTemplateSpecArgs( - metadata=ObjectMetaArgs( - labels=redis_replica_labels, - ), - spec=PodSpecArgs( - containers=[ContainerArgs( - name="redis-replica", - image="pulumi/guestbook-redis-replica", - resources=ResourceRequirementsArgs( - requests={ - "cpu": "100m", - "memory": "100Mi", - }, - ), - env=[EnvVarArgs( - name="GET_HOSTS_FROM", - value="dns", - # If your cluster config does not include a dns service, then to instead access an environment - # variable to find the leader's host, comment out the 'value: dns' line above, and - # uncomment the line below: - # value: "env" - )], - ports=[ContainerPortArgs( - container_port=6379, - )], - )], - ), - ), - )) + "redis-replica", + spec={ + "selector": {"match_labels": redis_replica_labels}, + "replicas": 1, + "template": { + "metadata": { + "labels": redis_replica_labels, + }, + "spec": { + "containers": [ + { + "name": "redis-replica", + "image": "pulumi/guestbook-redis-replica", + "resources": { + "requests": { + "cpu": "100m", + "memory": "100Mi", + }, + }, + "env": [ + { + "name": "GET_HOSTS_FROM", + "value": "dns", + # If your cluster config does not include a dns service, then to instead access an environment + # variable to find the leader's host, comment out the 'value: dns' line above, and + # uncomment the line below: + # value: "env" + } + ], + "ports": [ + { + "container_port": 6379, + } + ], + } + ], + }, + }, + }, +) redis_replica_service = Service( - "redis-replica", - metadata=ObjectMetaArgs( - name="redis-replica", - labels=redis_replica_labels - ), - spec=ServiceSpecArgs( - ports=[ServicePortArgs( - port=6379, - target_port=6379, - )], - selector=redis_replica_labels - )) + "redis-replica", + metadata=ObjectMetaArgs(name="redis-replica", labels=redis_replica_labels), + spec=ServiceSpecArgs( + ports=[ + ServicePortArgs( + port=6379, + target_port=6379, + ) + ], + selector=redis_replica_labels, + ), +) # Frontend frontend_labels = { - "app": "frontend", + "app": "frontend", } frontend_deployment = Deployment( - "frontend", - spec=DeploymentSpecArgs( - selector=LabelSelectorArgs( - match_labels=frontend_labels, - ), - replicas=3, - template=PodTemplateSpecArgs( - metadata=ObjectMetaArgs( - labels=frontend_labels, - ), - spec=PodSpecArgs( - containers=[ContainerArgs( - name="php-redis", - image="pulumi/guestbook-php-redis", - resources=ResourceRequirementsArgs( - requests={ - "cpu": "100m", - "memory": "100Mi", - }, - ), - env=[EnvVarArgs( - name="GET_HOSTS_FROM", - value="dns", - # If your cluster config does not include a dns service, then to instead access an environment - # variable to find the leader's host, comment out the 'value: dns' line above, and - # uncomment the line below: - # "value": "env" - )], - ports=[ContainerPortArgs( - container_port=80, - )], - )], - ), - ), - )) + "frontend", + spec=DeploymentSpecArgs( + selector=LabelSelectorArgs( + match_labels=frontend_labels, + ), + replicas=3, + template=PodTemplateSpecArgs( + metadata=ObjectMetaArgs( + labels=frontend_labels, + ), + spec=PodSpecArgs( + containers=[ + ContainerArgs( + name="php-redis", + image="pulumi/guestbook-php-redis", + resources=ResourceRequirementsArgs( + requests={ + "cpu": "100m", + "memory": "100Mi", + }, + ), + env=[ + EnvVarArgs( + name="GET_HOSTS_FROM", + value="dns", + # If your cluster config does not include a dns service, then to instead access an environment + # variable to find the leader's host, comment out the 'value: dns' line above, and + # uncomment the line below: + # "value": "env" + ) + ], + ports=[ + ContainerPortArgs( + container_port=80, + ) + ], + ) + ], + ), + ), + ), +) frontend_service = Service( - "frontend", - metadata=ObjectMetaArgs( - name="frontend", - labels=frontend_labels, - ), - spec=ServiceSpecArgs( - type="ClusterIP" if isMinikube else "LoadBalancer", - ports=[ServicePortArgs( - port=80 - )], - selector=frontend_labels, - )) + "frontend", + metadata={ + "name": "frontend", + "labels": frontend_labels, + }, + spec={ + "type": "ClusterIP" if isMinikube else "LoadBalancer", + "ports": [{"port": 80}], + "selector": frontend_labels, + }, +) frontend_ip = "" if isMinikube: - frontend_ip = frontend_service.spec.apply(lambda spec: spec.cluster_ip or "") + frontend_ip = frontend_service.spec.apply(lambda spec: spec.cluster_ip or "") else: - ingress = frontend_service.status.apply(lambda status: status.load_balancer.ingress[0]) - frontend_ip = ingress.apply(lambda ingress: ingress.ip or ingress.hostname or "") + ingress = frontend_service.status.apply( + lambda status: ( + status.load_balancer.ingress[0] + if status and status.load_balancer and status.load_balancer.ingress + else None + ) + ) + frontend_ip = ingress.apply( + lambda ingress: ingress and (ingress.ip or ingress.hostname) or "" + ) pulumi.export("frontend_ip", frontend_ip) diff --git a/kubernetes-py-guestbook/simple/requirements.txt b/kubernetes-py-guestbook/simple/requirements.txt index b408ae4f4..372fc114d 100644 --- a/kubernetes-py-guestbook/simple/requirements.txt +++ b/kubernetes-py-guestbook/simple/requirements.txt @@ -1,2 +1,2 @@ -pulumi>=3.5.1,<4.0.0 -pulumi-kubernetes>=3.4.0,<4.0.0 +pulumi>=3.124.0,<4.0.0 +pulumi-kubernetes>=4.15.0,<5.0.0