Skip to content

Commit

Permalink
Go tutorial and reference
Browse files Browse the repository at this point in the history
  • Loading branch information
javierdelapuente committed Oct 2, 2024
1 parent 422a2e9 commit 47903ac
Show file tree
Hide file tree
Showing 11 changed files with 607 additions and 13 deletions.
71 changes: 71 additions & 0 deletions docs/reference/extensions/go-framework.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
.. _go-framework-reference:

go-framework
----------------

The Go extension streamlines the process of building Go application
rocks.

The extension builds and copies the Go binary file to the rock,
inside the ``/app`` directory. By default, the base ``bare`` is used,
that generates a lightweight image.


.. note::
The Go extension is compatible with the ``bare`` and ``[email protected]``
bases.

Project requirements
====================

To use the ``go-framework`` extension, there must be a ``go.mod`` file
in the root directory of the project.


``parts`` > ``go-framework/install-app`` > ``organize``
=========================================================

If the main package is in the base directory and the rockcraft name
attribute is equal to the go module name, the name of the binary will
be selected correctly, otherwise you can adjust it.

You can use this field to specify a different binary to be used as the
main application, without having to override the service command. For example,
if your Go application container a ``main`` package in the directory
``cmd/anotherserver``, the name of the binary will be ``anotherserver``
and you can override the main application to use the binary with the
next snippet:

.. code-block:: yaml
parts:
go-framework/install-app:
organize:
bin/anotherserver: usr/local/bin/<rockcraft project name>
``parts`` > ``go-framework/assets`` > ``assets``
=========================================================


Some files, if they exist, are included by default. These include:
``migrate``, ``migrate.sh``, ``templates/`` and ``static/``.

You can customise the files to include overriding the ``stage`` property
of the ``go-framework/assets`` part:

.. code-block:: yaml
parts:
go-framework/assets:
stage:
- app/migrate
- app/migrate.sh
- app/static
- app/another_file_or_directory
Useful links
============

- :ref:`build-a-rock-for-a-go-application`
1 change: 1 addition & 0 deletions docs/reference/extensions/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -13,3 +13,4 @@ initiating a new rock.

flask-framework
django-framework
go-framework
3 changes: 3 additions & 0 deletions docs/reference/rockcraft.yaml.rst
Original file line number Diff line number Diff line change
Expand Up @@ -263,6 +263,9 @@ Extensions to enable when building the ROCK.
Currently supported extensions:

- ``flask-framework``
- ``django-framework``
- ``go-framework``
- ``fastapi-framework``

Example
=======
Expand Down
4 changes: 4 additions & 0 deletions docs/tutorial/code/go/anotherserver_part
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
parts:
go-framework/install-app:
organize:
bin/anotherserver: usr/local/bin/go-hello-world
18 changes: 18 additions & 0 deletions docs/tutorial/code/go/cmd/anotherserver/main.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
package main

import (
"fmt"
"log"
"net/http"
)

func helloWorld(w http.ResponseWriter, req *http.Request) {
log.Printf("anotherserver hello world request")
fmt.Fprintf(w, "Hello World from anotherserver")
}

func main() {
log.Printf("starting anotherserver hello world application")
http.HandleFunc("/", helloWorld)
http.ListenAndServe(":8000", nil)
}
18 changes: 18 additions & 0 deletions docs/tutorial/code/go/main.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
package main

import (
"fmt"
"log"
"net/http"
)

func helloWorld(w http.ResponseWriter, req *http.Request) {
log.Printf("new hello world request")
fmt.Fprintf(w, "Hello World")
}

func main() {
log.Printf("starting hello world application")
http.HandleFunc("/", helloWorld)
http.ListenAndServe(":8000", nil)
}
109 changes: 109 additions & 0 deletions docs/tutorial/code/go/task.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,109 @@
###########################################
# IMPORTANT
# Comments matter!
# The docs use the wrapping comments as
# markers for including said instructions
# as snippets in the docs.
###########################################
summary: Getting started with Go tutorial

environment:

execute: |
set -x
# [docs:install-go]
sudo snap install go --classic
# [docs:install-go-end]
# [docs:mod-init-go]
go mod init go-hello-world
go mod tidy
# [docs:mod-init-go-end]
# [docs:go-build]
go build .
# [docs:go-build-end]
./go-hello-world &
retry -n 5 --wait 2 curl localhost:8000
# [docs:curl-go]
curl localhost:8000
# [docs:curl-go-end]
kill $!
# [docs:create-rockcraft-yaml]
rockcraft init --profile go-framework
# [docs:create-rockcraft-yaml-end]
sed -i "s/name: .*/name: go-hello-world/g" rockcraft.yaml
# [docs:pack]
ROCKCRAFT_ENABLE_EXPERIMENTAL_EXTENSIONS=true rockcraft pack
# [docs:pack-end]
# [docs:ls-rock]
ls *.rock -l --block-size=MB
# [docs:ls-rock-end]
# [docs:skopeo-copy]
sudo rockcraft.skopeo --insecure-policy \
copy oci-archive:go-hello-world_0.1_amd64.rock \
docker-daemon:go-hello-world:0.1
# [docs:skopeo-copy-end]
# [docs:docker-images]
sudo docker images go-hello-world:0.1
# [docs:docker-images-end]
# [docs:docker-run]
sudo docker run --rm -d -p 8000:8000 \
--name go-hello-world go-hello-world:0.1
# [docs:docker-run-end]
retry -n 5 --wait 2 curl localhost:8000
# [docs:curl-go-rock]
curl localhost:8000
# [docs:curl-go-rock-end]
[ "$(curl localhost:8000)" = "Hello World" ]
# [docs:get-logs]
sudo docker exec go-hello-world pebble logs go
# [docs:get-logs-end]
# [docs:stop-docker]
sudo docker stop go-hello-world
sudo docker rmi go-hello-world:0.1
# [docs:stop-docker-end]
## Part 2 of the tutorial
sed -i "s/version: .*/version: 0.2/g" rockcraft.yaml
cat anotherserver_part >> rockcraft.yaml
# [docs:docker-run-update]
ROCKCRAFT_ENABLE_EXPERIMENTAL_EXTENSIONS=true rockcraft pack
sudo rockcraft.skopeo --insecure-policy \
copy oci-archive:go-hello-world_0.2_amd64.rock \
docker-daemon:go-hello-world:0.2
sudo docker images go-hello-world:0.2
sudo docker run --rm -d -p 8000:8000 \
--name go-hello-world go-hello-world:0.2
# [docs:docker-run-update-end]
retry -n 5 --wait 2 curl localhost:8000
# [docs:curl-anotherserver]
curl localhost:8000
# [docs:curl-anotherserver-end]
[ "$(curl localhost:8000)" = "Hello World from anotherserver" ]
# [docs:stop-docker-updated]
sudo docker stop go-hello-world
sudo docker rmi go-hello-world:0.2
# [docs:stop-docker-updated-end]
# [docs:cleanup]
# delete all the files created during the tutorial
rm go.mod rockcraft.yaml main.go go-hello-world \
go-hello-world_0.1_amd64.rock \
go-hello-world_0.2_amd64.rock
# [docs:cleanup-end]
Loading

0 comments on commit 47903ac

Please sign in to comment.