commit | 8d6785105d617f1b809c3d951b31a2d99eaecfee | [log] [tgz] |
---|---|---|
author | Dmitri Shuralyov <dmitshur@golang.org> | Fri Jan 12 19:50:10 2024 -0500 |
committer | Gopher Robot <gobot@golang.org> | Tue Jan 16 17:21:54 2024 +0000 |
tree | 726125b422eb941bc54846f41e4ee06b2af3330e | |
parent | af6601c481a00e8e6c374ae605426ec4eed63508 [diff] |
deploy: prune old App Engine versions for 2 more playgrounds CL 398574 added a step to use versionprune and prune old versions of the gotip playground. Apply the same change to the other two for the same reason. Also switch from 'go install' to 'go run' to simplify the invocation, and use a single dash in flags as is canonical style for Go commands. While here, also improve consistency between these files: • apply the change in CL 480275 to deploy.json too • use 'sh' everywhere, instead of a mix of 'bash' and 'sh' • drop GO111MODULE=on since it's the default For golang/go#59303. Change-Id: I921e768d15743a7a93ece8a1f671eaa0ee2e328a Reviewed-on: https://go-review.googlesource.com/c/playground/+/555656 Reviewed-by: Robert Findley <rfindley@google.com> Reviewed-by: Dmitri Shuralyov <dmitshur@google.com> Run-TryBot: Dmitri Shuralyov <dmitshur@golang.org> Auto-Submit: Dmitri Shuralyov <dmitshur@golang.org> TryBot-Result: Gopher Robot <gobot@golang.org>
This subrepository holds the source for the Go playground: https://go.dev/play/
# build the image docker build -t golang/playground .
docker run --name=play --rm -p 8080:8080 golang/playground & # run some Go code cat /path/to/code.go | go run client.go | curl -s --upload-file - localhost:8080/compile
To run the “gotip” version of the playground, set GOTIP=true
in your environment (via -e GOTIP=true
if using docker run
).
Playground releases automatically triggered when new Go repository tags are pushed to GitHub, or when master is pushed on the playground repository.
For details, see deploy/go_trigger.yaml, deploy/playground_trigger.yaml, and deploy/deploy.json.
Changes to the trigger configuration can be made to the YAML files, or in the GCP UI, which should be kept in sync using the push-cloudbuild-triggers
and pull-cloudbuild-triggers
make targets.
The Cloud Build configuration will always build and deploy with the latest supported release of Go.
gcloud --project=golang-org builds submit --config deploy/deploy.json .
To deploy the “Go tip” version of the playground, which uses the latest development build, use deploy_gotip.json
instead:
gcloud --project=golang-org builds submit --config deploy/deploy_gotip.json .
Building the playground Docker container takes more than the default 10 minute time limit of cloud build, so increase its timeout first (note, app/cloud_build_timeout
is a global configuration value):
gcloud config set app/cloud_build_timeout 1200 # 20 mins
Alternatively, to avoid Cloud Build and build locally:
make docker docker tag golang/playground:latest gcr.io/golang-org/playground:latest docker push gcr.io/golang-org/playground:latest gcloud --project=golang-org --account=you@google.com app deploy app.yaml --image-url=gcr.io/golang-org/playground:latest
Then:
gcloud --project=golang-org --account=you@google.com app deploy app.yaml
To submit changes to this repository, see https://golang.org/doc/contribute.html.