Merge pull request #86266 from zowoq/minikube

minikube, docker-machine-{hyperkit,kvm2}: use makefile
This commit is contained in:
Mario Rodas 2020-04-29 19:15:46 -05:00 committed by GitHub
commit 2d7e0098f1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 47 additions and 52 deletions

View File

@ -1,19 +1,20 @@
{ lib, buildGoModule, minikube }: { lib, buildGoModule, minikube }:
buildGoModule rec { buildGoModule rec {
inherit (minikube) version src nativeBuildInputs buildInputs goPackagePath preBuild; inherit (minikube) version src nativeBuildInputs buildInputs modSha256 commit;
pname = "docker-machine-hyperkit"; pname = "docker-machine-hyperkit";
subPackages = [ "cmd/drivers/hyperkit" ];
modSha256 = minikube.go-modules.outputHash; buildPhase = ''
make docker-machine-driver-hyperkit COMMIT=${commit}
'';
postInstall = '' installPhase = ''
mv $out/bin/hyperkit $out/bin/docker-machine-driver-hyperkit install out/docker-machine-driver-hyperkit -Dt $out/bin
''; '';
meta = with lib; { meta = with lib; {
homepage = "https://github.com/kubernetes/minikube/blob/master/docs/drivers.md"; homepage = "https://minikube.sigs.k8s.io/docs/drivers/hyperkit";
description = "HyperKit driver for docker-machine."; description = "HyperKit driver for docker-machine.";
license = licenses.asl20; license = licenses.asl20;
maintainers = with maintainers; [ atkinschang ]; maintainers = with maintainers; [ atkinschang ];

View File

@ -1,22 +1,27 @@
{ lib, buildGoModule, minikube }: { lib, buildGoModule, minikube }:
buildGoModule rec { buildGoModule rec {
inherit (minikube) version src nativeBuildInputs buildInputs goPackagePath preBuild; inherit (minikube) version src nativeBuildInputs buildInputs modSha256 commit;
pname = "docker-machine-kvm2"; pname = "docker-machine-kvm2";
subPackages = [ "cmd/drivers/kvm" ];
modSha256 = minikube.go-modules.outputHash; postPatch = ''
sed -i '/GOARCH=$*/d' Makefile
'';
postInstall = '' buildPhase = ''
mv $out/bin/kvm $out/bin/docker-machine-driver-kvm2 make docker-machine-driver-kvm2 COMMIT=${commit}
'';
installPhase = ''
install out/docker-machine-driver-kvm2 -Dt $out/bin
''; '';
meta = with lib; { meta = with lib; {
homepage = "https://github.com/kubernetes/minikube/blob/master/docs/drivers.md"; homepage = "https://minikube.sigs.k8s.io/docs/drivers/kvm2";
description = "KVM2 driver for docker-machine."; description = "KVM2 driver for docker-machine.";
license = licenses.asl20; license = licenses.asl20;
maintainers = with maintainers; [ tadfisher atkinschang ]; maintainers = with maintainers; [ tadfisher atkinschang ];
platforms = platforms.unix; platforms = platforms.linux;
}; };
} }

View File

@ -1,67 +1,56 @@
{ stdenv { stdenv
, buildGoModule , buildGoModule
, fetchFromGitHub , fetchFromGitHub
, pkgconfig
, makeWrapper
, go-bindata , go-bindata
, installShellFiles
, pkg-config
, which
, libvirt , libvirt
, vmnet , vmnet
}: }:
buildGoModule rec { buildGoModule rec {
pname = "minikube"; pname = "minikube";
version = "1.9.2"; version = "1.9.2";
# for -ldflags
commit = "1b78a7b8a99ad6a3c62b8d22f57120d614d17935";
goPackagePath = "k8s.io/minikube"; # for -ldflags
subPackages = [ "cmd/minikube" ]; commit = "1b78a7b8a99ad6a3c62b8d22f57120d614d17935";
modSha256 = "1pxs6myszgma3rzz0nhfjbnylv6m0xzlinvmlg0c4ijvkkzxg3v5";
modSha256 = "1pxs6myszgma3rzz0nhfjbnylv6m0xzlinvmlg0c4ijvkkzxg3v5";
src = fetchFromGitHub { src = fetchFromGitHub {
owner = "kubernetes"; owner = "kubernetes";
repo = "minikube"; repo = "minikube";
rev = "v${version}"; rev = "v${version}";
sha256 = "025v45427d885qkjjg7ig8fgrvjalnf1lajsj0cnbwbih2m69svg"; sha256 = "025v45427d885qkjjg7ig8fgrvjalnf1lajsj0cnbwbih2m69svg";
}; };
nativeBuildInputs = [ pkgconfig go-bindata makeWrapper ]; nativeBuildInputs = [ go-bindata installShellFiles pkg-config which ];
buildInputs = stdenv.lib.optionals stdenv.isLinux [ libvirt ]
++ stdenv.lib.optionals stdenv.isDarwin [ vmnet ];
preBuild = '' buildInputs = if stdenv.isDarwin then [ vmnet ] else if stdenv.isLinux then [ libvirt ] else null;
go-bindata -nomemcopy -o pkg/minikube/assets/assets.go -pkg assets deploy/addons/...
go-bindata -nomemcopy -o pkg/minikube/translate/translations.go -pkg translate translations/...
VERSION_MAJOR=$(grep "^VERSION_MAJOR" Makefile | sed "s/^.*\s//") buildPhase = ''
VERSION_MINOR=$(grep "^VERSION_MINOR" Makefile | sed "s/^.*\s//") make COMMIT=${commit}
ISO_VERSION=v$VERSION_MAJOR.$VERSION_MINOR.0
ISO_BUCKET=$(grep "^ISO_BUCKET" Makefile | sed "s/^.*\s//")
export buildFlagsArray="-ldflags=\
-X ${goPackagePath}/pkg/version.version=v${version} \
-X ${goPackagePath}/pkg/version.isoVersion=$ISO_VERSION \
-X ${goPackagePath}/pkg/version.isoPath=$ISO_BUCKET \
-X ${goPackagePath}/pkg/version.gitCommitID=${commit} \
-X ${goPackagePath}/pkg/drivers/kvm.version=v${version} \
-X ${goPackagePath}/pkg/drivers/kvm.gitCommitID=${commit} \
-X ${goPackagePath}/pkg/drivers/hyperkit.version=v${version} \
-X ${goPackagePath}/pkg/drivers/hyperkit.gitCommitID=${commit}"
''; '';
postInstall = '' installPhase = ''
mkdir -p $out/share/bash-completion/completions/ install out/minikube -Dt $out/bin
MINIKUBE_WANTUPDATENOTIFICATION=false MINIKUBE_WANTKUBECTLDOWNLOADMSG=false HOME=$PWD $out/bin/minikube completion bash > $out/share/bash-completion/completions/minikube
mkdir -p $out/share/zsh/site-functions/ export HOME=$PWD
MINIKUBE_WANTUPDATENOTIFICATION=false MINIKUBE_WANTKUBECTLDOWNLOADMSG=false HOME=$PWD $out/bin/minikube completion zsh > $out/share/zsh/site-functions/_minikube export MINIKUBE_WANTUPDATENOTIFICATION=false
export MINIKUBE_WANTKUBECTLDOWNLOADMSG=false
for shell in bash zsh; do
$out/bin/minikube completion $shell > minikube.$shell
installShellCompletion minikube.$shell
done
''; '';
meta = with stdenv.lib; { meta = with stdenv.lib; {
homepage = "https://github.com/kubernetes/minikube"; homepage = "https://minikube.sigs.k8s.io";
description = "A tool that makes it easy to run Kubernetes locally"; description = "A tool that makes it easy to run Kubernetes locally";
license = licenses.asl20; license = licenses.asl20;
maintainers = with maintainers; [ ebzzry copumpkin vdemeester atkinschang ]; maintainers = with maintainers; [ ebzzry copumpkin vdemeester atkinschang ];
platforms = with platforms; unix; platforms = platforms.unix;
}; };
} }