Merge pull request #1600 from TomChv/europa/port-go-package
Port go package to universe
This commit is contained in:
commit
97151b911d
@ -1,4 +1,5 @@
|
||||
# generated by dagger
|
||||
dagger.lock
|
||||
alpha.dagger.io
|
||||
universe.dagger.io
|
||||
dagger.io
|
||||
universe.dagger.io
|
50
pkg/universe.dagger.io/go/build.cue
Normal file
50
pkg/universe.dagger.io/go/build.cue
Normal file
@ -0,0 +1,50 @@
|
||||
package go
|
||||
|
||||
import (
|
||||
"dagger.io/dagger"
|
||||
)
|
||||
|
||||
// Build a go binary
|
||||
#Build: {
|
||||
// Source code
|
||||
source: dagger.#FS
|
||||
|
||||
// Target package to build
|
||||
package: *"." | string
|
||||
|
||||
// Target architecture
|
||||
arch: *"amd64" | string
|
||||
|
||||
// Target OS
|
||||
os: *"linux" | string
|
||||
|
||||
// Build tags to use for building
|
||||
tags: *"" | string
|
||||
|
||||
// LDFLAGS to use for linking
|
||||
ldflags: *"" | string
|
||||
|
||||
env: [string]: string
|
||||
|
||||
container: #Container & {
|
||||
"source": source
|
||||
"env": {
|
||||
env
|
||||
GOOS: os
|
||||
GOARCH: arch
|
||||
}
|
||||
command: {
|
||||
args: [package]
|
||||
flags: {
|
||||
build: true
|
||||
"-v": true
|
||||
"-tags": tags
|
||||
"-ldflags": ldflags
|
||||
"-o": "/output/"
|
||||
}
|
||||
}
|
||||
export: directories: "/output/": _
|
||||
}
|
||||
|
||||
binary: container.export.directories."/output/".contents
|
||||
}
|
44
pkg/universe.dagger.io/go/container.cue
Normal file
44
pkg/universe.dagger.io/go/container.cue
Normal file
@ -0,0 +1,44 @@
|
||||
// Go operation
|
||||
package go
|
||||
|
||||
import (
|
||||
"dagger.io/dagger"
|
||||
"universe.dagger.io/docker"
|
||||
)
|
||||
|
||||
// A standalone go environment to run go command
|
||||
#Container: {
|
||||
// Container app name
|
||||
name: *"go_builder" | string
|
||||
|
||||
// Source code
|
||||
source: dagger.#FS
|
||||
|
||||
// Use go image
|
||||
_image: #Image
|
||||
|
||||
_sourcePath: "/src"
|
||||
_cachePath: "/root/.cache/gocache"
|
||||
|
||||
docker.#Run & {
|
||||
input: *_image.output | docker.#Image
|
||||
workdir: "/src"
|
||||
command: name: "go"
|
||||
mounts: {
|
||||
"source": {
|
||||
dest: _sourcePath
|
||||
contents: source
|
||||
}
|
||||
"go assets cache": {
|
||||
contents: dagger.#CacheDir & {
|
||||
id: "\(name)_assets"
|
||||
}
|
||||
dest: _cachePath
|
||||
}
|
||||
}
|
||||
env: {
|
||||
CGO_ENABLED: "0"
|
||||
GOMODCACHE: _cachePath
|
||||
}
|
||||
}
|
||||
}
|
37
pkg/universe.dagger.io/go/image.cue
Normal file
37
pkg/universe.dagger.io/go/image.cue
Normal file
@ -0,0 +1,37 @@
|
||||
package go
|
||||
|
||||
import (
|
||||
"universe.dagger.io/docker"
|
||||
)
|
||||
|
||||
// Go image default version
|
||||
#DefaultVersion: "1.16"
|
||||
|
||||
// Build a go base image
|
||||
#Image: {
|
||||
version: *#DefaultVersion | string
|
||||
|
||||
packages: [pkgName=string]: version: string | *""
|
||||
|
||||
// FIXME Basically a copy of alpine.#Build with a different image
|
||||
// Should we create a special definition?
|
||||
docker.#Build & {
|
||||
steps: [
|
||||
docker.#Pull & {
|
||||
source: "index.docker.io/golang:\(version)-alpine"
|
||||
},
|
||||
for pkgName, pkg in packages {
|
||||
docker.#Run & {
|
||||
command: {
|
||||
name: "apk"
|
||||
args: ["add", "\(pkgName)\(pkg.version)"]
|
||||
flags: {
|
||||
"-U": true
|
||||
"--no-cache": true
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
]
|
||||
}
|
||||
}
|
17
pkg/universe.dagger.io/go/test.cue
Normal file
17
pkg/universe.dagger.io/go/test.cue
Normal file
@ -0,0 +1,17 @@
|
||||
package go
|
||||
|
||||
// Test a go package
|
||||
#Test: {
|
||||
// Package to test
|
||||
package: *"." | string
|
||||
|
||||
#Container & {
|
||||
command: {
|
||||
args: [package]
|
||||
flags: {
|
||||
test: true
|
||||
"-v": true
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
43
pkg/universe.dagger.io/go/test/build.cue
Normal file
43
pkg/universe.dagger.io/go/test/build.cue
Normal file
@ -0,0 +1,43 @@
|
||||
package go
|
||||
|
||||
import (
|
||||
"dagger.io/dagger"
|
||||
"universe.dagger.io/go"
|
||||
"universe.dagger.io/docker"
|
||||
"universe.dagger.io/alpine"
|
||||
)
|
||||
|
||||
dagger.#Plan & {
|
||||
inputs: directories: testhello: path: "./data/hello"
|
||||
|
||||
actions: tests: build: {
|
||||
_baseImage: alpine.#Build
|
||||
|
||||
simple: {
|
||||
build: go.#Build & {
|
||||
source: inputs.directories.testhello.contents
|
||||
}
|
||||
|
||||
exec: docker.#Run & {
|
||||
input: _baseImage.output
|
||||
command: {
|
||||
name: "/bin/sh"
|
||||
args: ["-c", "/bin/hello >> /output.txt"]
|
||||
}
|
||||
env: NAME: "dagger"
|
||||
mounts: binary: {
|
||||
dest: "/bin/hello"
|
||||
contents: build.binary
|
||||
source: "/test"
|
||||
}
|
||||
}
|
||||
|
||||
verify: dagger.#ReadFile & {
|
||||
input: exec.output.rootfs
|
||||
path: "/output.txt"
|
||||
} & {
|
||||
contents: "Hi dagger!"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
30
pkg/universe.dagger.io/go/test/container.cue
Normal file
30
pkg/universe.dagger.io/go/test/container.cue
Normal file
@ -0,0 +1,30 @@
|
||||
package go
|
||||
|
||||
import (
|
||||
"dagger.io/dagger"
|
||||
"universe.dagger.io/go"
|
||||
"universe.dagger.io/alpine"
|
||||
)
|
||||
|
||||
dagger.#Plan & {
|
||||
actions: tests: container: {
|
||||
_source: dagger.#Scratch & {}
|
||||
|
||||
simple: go.#Container & {
|
||||
source: _source
|
||||
command: args: ["version"]
|
||||
}
|
||||
|
||||
overide: {
|
||||
base: alpine.#Build & {
|
||||
packages: go: _
|
||||
}
|
||||
|
||||
command: go.#Container & {
|
||||
input: base.output
|
||||
source: _source
|
||||
command: args: ["version"]
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
3
pkg/universe.dagger.io/go/test/data/hello/go.mod
Normal file
3
pkg/universe.dagger.io/go/test/data/hello/go.mod
Normal file
@ -0,0 +1,3 @@
|
||||
module dagger.io/test
|
||||
|
||||
go 1.17
|
@ -0,0 +1,7 @@
|
||||
package greeting
|
||||
|
||||
import "fmt"
|
||||
|
||||
func Greeting(name string) string {
|
||||
return fmt.Sprintf("Hi %s!", name)
|
||||
}
|
@ -0,0 +1,13 @@
|
||||
package greeting
|
||||
|
||||
import "testing"
|
||||
|
||||
func TestGreeting(t *testing.T) {
|
||||
name := "Dagger Test"
|
||||
expect := "Hi Dagger Test!"
|
||||
value := Greeting(name)
|
||||
|
||||
if expect != value {
|
||||
t.Fatalf("Hello(%s) = '%s', expected '%s'", name, value, expect)
|
||||
}
|
||||
}
|
16
pkg/universe.dagger.io/go/test/data/hello/main.go
Normal file
16
pkg/universe.dagger.io/go/test/data/hello/main.go
Normal file
@ -0,0 +1,16 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"os"
|
||||
|
||||
"dagger.io/test/greeting"
|
||||
)
|
||||
|
||||
func main() {
|
||||
name := os.Getenv("NAME")
|
||||
if name == "" {
|
||||
name = "John Doe"
|
||||
}
|
||||
fmt.Printf(greeting.Greeting(name))
|
||||
}
|
44
pkg/universe.dagger.io/go/test/image.cue
Normal file
44
pkg/universe.dagger.io/go/test/image.cue
Normal file
@ -0,0 +1,44 @@
|
||||
package go
|
||||
|
||||
import (
|
||||
"dagger.io/dagger"
|
||||
"universe.dagger.io/go"
|
||||
"universe.dagger.io/docker"
|
||||
)
|
||||
|
||||
dagger.#Plan & {
|
||||
actions: tests: image: {
|
||||
_source: dagger.#Scratch & {}
|
||||
|
||||
simple: {
|
||||
_image: go.#Image & {}
|
||||
|
||||
verify: docker.#Run & {
|
||||
input: _image.output
|
||||
command: {
|
||||
name: "/bin/sh"
|
||||
args: ["-c", """
|
||||
go version | grep "1.16"
|
||||
"""]
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
custom: {
|
||||
_image: go.#Image & {
|
||||
version: "1.17"
|
||||
packages: bash: _
|
||||
}
|
||||
|
||||
verify: docker.#Run & {
|
||||
input: _image.output
|
||||
command: {
|
||||
name: "/bin/bash"
|
||||
args: ["-c", """
|
||||
go version | grep "1.17"
|
||||
"""]
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
10
pkg/universe.dagger.io/go/test/test.bats
Normal file
10
pkg/universe.dagger.io/go/test/test.bats
Normal file
@ -0,0 +1,10 @@
|
||||
setup() {
|
||||
load '../../bats_helpers'
|
||||
|
||||
common_setup
|
||||
}
|
||||
|
||||
@test "bash" {
|
||||
dagger up
|
||||
}
|
||||
|
15
pkg/universe.dagger.io/go/test/test.cue
Normal file
15
pkg/universe.dagger.io/go/test/test.cue
Normal file
@ -0,0 +1,15 @@
|
||||
package go
|
||||
|
||||
import (
|
||||
"dagger.io/dagger"
|
||||
"universe.dagger.io/go"
|
||||
)
|
||||
|
||||
dagger.#Plan & {
|
||||
inputs: directories: testhello: path: "./data/hello"
|
||||
|
||||
actions: tests: test: simple: go.#Test & {
|
||||
source: inputs.directories.testhello.contents
|
||||
package: "./greeting"
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user