Skip to content

Latest commit

 

History

History
146 lines (94 loc) · 4.88 KB

README.md

File metadata and controls

146 lines (94 loc) · 4.88 KB

ETI sre-go-helloworld

  • Jenkins: Build Status
  • ArgoCD: ArgoCD Status

This is a "boilerplate" go microservice with following example showcase features:

  • CI/CD Setup
  • Config Management
  • Secrets Management
  • Database Access
  • Go Private Modules
  • sre-go-logger
  • idpadapter

Quick Start

How to use sre-go-helloworld as a template

  1. Create a new repo from the template sre-go-helloworld repo by clicking on the Use this template button on the upper right.
    • Select eti as the Owner and choose a short unique name for the repo (e.g., <CEC_ID>app). This repo name will be used as the default name for your new application.
    • Select Public visibility
  2. Clone the new repo to your local development environment.
    git clone [email protected]:eti/<YOUR_APP_NAME>.git
    
  3. cd into the repo and run the runme.sh to reconfigure the repo for your new application.
    ./runme.sh
  4. The previous step should have created a new branch (named <your app name>-<random string>). Create a PR from that branch and merge it.
  5. Reach out to SRE team in the Ask ET&I SRE space to request a fully automated CI/CD pipeline for your new application

After the SRE creates the CI/CD pipeline and deploys your application, you can navigate to https://<YOUR_APP_NAME>.int.dev.eticloud.io/ to see your deployed application.

See the Troubleshooting page if you run into any issues.

sre-go-helloworld developer setup

Local Development

How to retrieve artifactory encrypted password

export ARTIFACTORY_USER=<YOUR USERNAME>
export ARTIFACTORY_PASSWORD=<YOUR Encrypted Artifactory Password>
make

Build and Run Docker

./build-docker.sh

docker run --name postgres -e POSTGRES_DB=helloworld -e POSTGRES_PASSWORD=strongpassword -d postgres
docker run -it -p 5000:5000 -e DB_CONNECTION_INFO=/tmp/dbconfig.json -e DB_NAME=helloworld -v $PWD/build/:/tmp/  --link postgres:postgre sre-go-helloworld

Additional Setup Instructions for Lab VM before build

Skip this step if is not building on Lab VM (i.e. rcdn6-vmXX-YYY).

export DOCKER_BLD_ARGS="https_proxy=http://proxy.esl.cisco.com:80"

Create a credentials file for artifactory in ~/.nyota/credentials with content:

artifactory_user=yourCECID
artifactory_password=yourPASSWORD

and run after:

chmod 400 ~/.nyota/credentials

Quick links

Instructions for Developers

Install git hook to autoformat and run tests

From the main directory, run:

ln -s $(pwd)/githooks/pre-commit .git/hooks/pre-commit`

Source Code Structure

/src/pkg

This will contain the libraries internal to the app

/docs

If you need the swag tool, install it using command:

   go get -u github.com/swaggo/swag/cmd/swag

This contains the rest api specifications in JSON/ yaml. This specifications would be used for api documentation. Generated from handler comments using command:

swag init --parseDependency --parseInternal

Then, if you want to play with the API, run the swagger docker container using:

docker run --name swagger_ui -p 8080:8080 -d swaggerapi/swagger-ui

Open a browser to the swagger UI http://localhost:8080/, put http://localhost:5000/docs in the input field and click on explore button.

/test

This contains all the tests and dependent mock functions.

/deployments

This contains system and container orchestration, deployment configurations and templates.

/githooks

This will have git hooks e.g. go_fmt, staticcheck etc.

main.go

This is the main package for the microservice.