tree: 979c73f210f9ab361dfa960b22a3fe00a399c708 [path history] [tgz]
  1. static/
  2. AUTHORS
  3. CONTRIBUTING.md
  4. CONTRIBUTORS
  5. Dockerfile
  6. LICENSE
  7. Makefile
  8. PATENTS
  9. README.md
  10. app.yaml
  11. cache.go
  12. client.go
  13. cloudbuild_trigger.json
  14. codereview.cfg
  15. edit.go
  16. edit.html
  17. enable-fake-time.patch
  18. fake_fs.lst
  19. fmt.go
  20. fmt_test.go
  21. go.mod
  22. go.sum
  23. logger.go
  24. main.go
  25. play.go
  26. play_test.go
  27. sandbox.go
  28. server.go
  29. server_test.go
  30. share.go
  31. store.go
  32. tests.go
  33. txtar.go
  34. txtar_test.go
  35. vet.go
README.md

playground

This subrepository holds the source for the Go playground: https://play.golang.org/

Building

# build the image
docker build -t playground .

Running

docker run --name=play --rm -d -p 8080:8080 playground
# run some Go code
cat /path/to/code.go | go run client.go | curl -s --upload-file - localhost:8080/compile

Deployment

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 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

Deployment Triggers

Playground releases are also triggered when new tags are pushed to Github. The Cloud Build trigger configuration is defined in cloudbuild_trigger.json.

Triggers can be updated by running the following Make target:

make update-cloudbuild-trigger

Contributing

To submit changes to this repository, see https://golang.org/doc/contribute.html.