fa5436e0a7
GitOrigin-RevId: e8057b67ebf307f01bdcc8fba94d94f75039d1f6
72 lines
2.3 KiB
Nix
72 lines
2.3 KiB
Nix
{ lib
|
|
, buildGoModule
|
|
, fetchFromGitHub
|
|
, git
|
|
, installShellFiles
|
|
}:
|
|
|
|
buildGoModule rec {
|
|
pname = "ko";
|
|
version = "0.15.4";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "ko-build";
|
|
repo = pname;
|
|
rev = "refs/tags/v${version}";
|
|
hash = "sha256-MeFoy2WoPsJIgUhpzt/4sEP6J9lM4nsSAK2VZiTS7jo=";
|
|
};
|
|
|
|
vendorHash = "sha256-n/NbbitSyjl05gESPVG3Uv2ek1U0Cd2fQqcxBhDKULU=";
|
|
|
|
nativeBuildInputs = [ installShellFiles ];
|
|
|
|
# Pin so that we don't build the several other development tools
|
|
subPackages = ".";
|
|
|
|
ldflags = [ "-s" "-w" "-X github.com/google/ko/pkg/commands.Version=${version}" ];
|
|
|
|
checkFlags = [
|
|
# requires docker daemon
|
|
"-skip=TestNewPublisherCanPublish"
|
|
];
|
|
|
|
nativeCheckInputs = [ git ];
|
|
preCheck = ''
|
|
# Feed in all the tests for testing
|
|
# This is because subPackages above limits what is built to just what we
|
|
# want but also limits the tests
|
|
getGoDirs() {
|
|
go list ./...
|
|
}
|
|
|
|
# resolves some complaints from ko
|
|
export GOROOT="$(go env GOROOT)"
|
|
git init
|
|
|
|
# ko tests will fail if any of those env are set, as ko tries
|
|
# to make sure it can build and target multiple GOOS/GOARCH
|
|
unset GOOS GOARCH GOARM
|
|
'';
|
|
|
|
postInstall = ''
|
|
installShellCompletion --cmd ko \
|
|
--bash <($out/bin/ko completion bash) \
|
|
--fish <($out/bin/ko completion fish) \
|
|
--zsh <($out/bin/ko completion zsh)
|
|
'';
|
|
|
|
meta = with lib; {
|
|
homepage = "https://github.com/ko-build/ko";
|
|
changelog = "https://github.com/ko-build/ko/releases/tag/v${version}";
|
|
description = "Build and deploy Go applications on Kubernetes";
|
|
mainProgram = "ko";
|
|
longDescription = ''
|
|
ko is a simple, fast container image builder for Go applications.
|
|
It's ideal for use cases where your image contains a single Go application without any/many dependencies on the OS base image (e.g. no cgo, no OS package dependencies).
|
|
ko builds images by effectively executing go build on your local machine, and as such doesn't require docker to be installed. This can make it a good fit for lightweight CI/CD use cases.
|
|
ko also includes support for simple YAML templating which makes it a powerful tool for Kubernetes applications.
|
|
'';
|
|
license = licenses.asl20;
|
|
maintainers = with maintainers; [ nickcao jk vdemeester developer-guy ];
|
|
};
|
|
}
|