Skip to content

Latest commit

 

History

History
71 lines (55 loc) · 1.95 KB

README.md

File metadata and controls

71 lines (55 loc) · 1.95 KB

go-demo-app

CodeQL Build, Test, Deploy

This is a simple go webapp for demonstrating how to use GitHub Actions to deploy to Cloud.gov.

Dependencies

Clone the repository

Clone the repository and cd into it:

git clone https://github.com/maheese/go-demo-app
cd go-demo-app

Testing the app

You can run the dummy unit tests.

$ go test ''
ok      /go-demo-app       0.413s

Running the app locally

You can access the app at http://localhost:8080

$ go build
$ ./go-demo-app.exe
Listening on port 8080

Pushing the app to cloud.gov locally

$ cf push .
Pushing app . to org / space ...
Applying manifest manifest.yml...
Manifest applied
Packaging files to upload...
Uploading files...
 3.61 MiB / 3.61 MiB  100.00% 2s
 ....

GitHub Actions

There is a demo workflow in this repository that will build, test, and deploy the app to cloud.gov when a pull request is created or changes are pushed to main. The worflow uses the cg-cli-tools action. In order to use this action you will need to create a service account in cloud.gov and store the username and password as secrets in GitHub. You can use the following command to create the service account:

$ cf create-service cloud-gov-service-account space-deployer my-service-account

Once you've created the service account you can bind a service key to it and obtain the credentials.

$ cf create-service-key my-service-account my-service-key
$ cf service-key my-service-account my-service-key

{
 "password": "oYasdflhhhhin9oijjhdliecV",
 "username": "yyyyyy-aabb-1234-fe9uytjyutt321000"
}