Merge pull request #86266 from zowoq/minikube

minikube, docker-machine-{hyperkit,kvm2}: use makefile

authored by Mario Rodas and committed by GitHub 2d7e0098 40b3995d

+46 -51
+7 -6
pkgs/applications/networking/cluster/docker-machine/hyperkit.nix
··· 1 1 { lib, buildGoModule, minikube }: 2 2 3 3 buildGoModule rec { 4 - inherit (minikube) version src nativeBuildInputs buildInputs goPackagePath preBuild; 4 + inherit (minikube) version src nativeBuildInputs buildInputs modSha256 commit; 5 5 6 6 pname = "docker-machine-hyperkit"; 7 - subPackages = [ "cmd/drivers/hyperkit" ]; 8 7 9 - modSha256 = minikube.go-modules.outputHash; 8 + buildPhase = '' 9 + make docker-machine-driver-hyperkit COMMIT=${commit} 10 + ''; 10 11 11 - postInstall = '' 12 - mv $out/bin/hyperkit $out/bin/docker-machine-driver-hyperkit 12 + installPhase = '' 13 + install out/docker-machine-driver-hyperkit -Dt $out/bin 13 14 ''; 14 15 15 16 meta = with lib; { 16 - homepage = "https://github.com/kubernetes/minikube/blob/master/docs/drivers.md"; 17 + homepage = "https://minikube.sigs.k8s.io/docs/drivers/hyperkit"; 17 18 description = "HyperKit driver for docker-machine."; 18 19 license = licenses.asl20; 19 20 maintainers = with maintainers; [ atkinschang ];
+12 -7
pkgs/applications/networking/cluster/docker-machine/kvm2.nix
··· 1 1 { lib, buildGoModule, minikube }: 2 2 3 3 buildGoModule rec { 4 - inherit (minikube) version src nativeBuildInputs buildInputs goPackagePath preBuild; 4 + inherit (minikube) version src nativeBuildInputs buildInputs modSha256 commit; 5 5 6 6 pname = "docker-machine-kvm2"; 7 - subPackages = [ "cmd/drivers/kvm" ]; 8 7 9 - modSha256 = minikube.go-modules.outputHash; 8 + postPatch = '' 9 + sed -i '/GOARCH=$*/d' Makefile 10 + ''; 11 + 12 + buildPhase = '' 13 + make docker-machine-driver-kvm2 COMMIT=${commit} 14 + ''; 10 15 11 - postInstall = '' 12 - mv $out/bin/kvm $out/bin/docker-machine-driver-kvm2 16 + installPhase = '' 17 + install out/docker-machine-driver-kvm2 -Dt $out/bin 13 18 ''; 14 19 15 20 meta = with lib; { 16 - homepage = "https://github.com/kubernetes/minikube/blob/master/docs/drivers.md"; 21 + homepage = "https://minikube.sigs.k8s.io/docs/drivers/kvm2"; 17 22 description = "KVM2 driver for docker-machine."; 18 23 license = licenses.asl20; 19 24 maintainers = with maintainers; [ tadfisher atkinschang ]; 20 - platforms = platforms.unix; 25 + platforms = platforms.linux; 21 26 }; 22 27 }
+27 -38
pkgs/applications/networking/cluster/minikube/default.nix
··· 1 1 { stdenv 2 2 , buildGoModule 3 3 , fetchFromGitHub 4 - , pkgconfig 5 - , makeWrapper 6 4 , go-bindata 5 + , installShellFiles 6 + , pkg-config 7 + , which 7 8 , libvirt 8 9 , vmnet 9 10 }: 10 11 11 12 buildGoModule rec { 12 - pname = "minikube"; 13 + pname = "minikube"; 13 14 version = "1.9.2"; 15 + 14 16 # for -ldflags 15 - commit = "1b78a7b8a99ad6a3c62b8d22f57120d614d17935"; 17 + commit = "1b78a7b8a99ad6a3c62b8d22f57120d614d17935"; 16 18 17 - goPackagePath = "k8s.io/minikube"; 18 - subPackages = [ "cmd/minikube" ]; 19 - modSha256 = "1pxs6myszgma3rzz0nhfjbnylv6m0xzlinvmlg0c4ijvkkzxg3v5"; 19 + modSha256 = "1pxs6myszgma3rzz0nhfjbnylv6m0xzlinvmlg0c4ijvkkzxg3v5"; 20 20 21 21 src = fetchFromGitHub { 22 - owner = "kubernetes"; 23 - repo = "minikube"; 24 - rev = "v${version}"; 22 + owner = "kubernetes"; 23 + repo = "minikube"; 24 + rev = "v${version}"; 25 25 sha256 = "025v45427d885qkjjg7ig8fgrvjalnf1lajsj0cnbwbih2m69svg"; 26 26 }; 27 27 28 - nativeBuildInputs = [ pkgconfig go-bindata makeWrapper ]; 29 - buildInputs = stdenv.lib.optionals stdenv.isLinux [ libvirt ] 30 - ++ stdenv.lib.optionals stdenv.isDarwin [ vmnet ]; 28 + nativeBuildInputs = [ go-bindata installShellFiles pkg-config which ]; 31 29 32 - preBuild = '' 33 - go-bindata -nomemcopy -o pkg/minikube/assets/assets.go -pkg assets deploy/addons/... 34 - go-bindata -nomemcopy -o pkg/minikube/translate/translations.go -pkg translate translations/... 30 + buildInputs = if stdenv.isDarwin then [ vmnet ] else if stdenv.isLinux then [ libvirt ] else null; 35 31 36 - VERSION_MAJOR=$(grep "^VERSION_MAJOR" Makefile | sed "s/^.*\s//") 37 - VERSION_MINOR=$(grep "^VERSION_MINOR" Makefile | sed "s/^.*\s//") 38 - ISO_VERSION=v$VERSION_MAJOR.$VERSION_MINOR.0 39 - ISO_BUCKET=$(grep "^ISO_BUCKET" Makefile | sed "s/^.*\s//") 32 + buildPhase = '' 33 + make COMMIT=${commit} 34 + ''; 40 35 41 - export buildFlagsArray="-ldflags=\ 42 - -X ${goPackagePath}/pkg/version.version=v${version} \ 43 - -X ${goPackagePath}/pkg/version.isoVersion=$ISO_VERSION \ 44 - -X ${goPackagePath}/pkg/version.isoPath=$ISO_BUCKET \ 45 - -X ${goPackagePath}/pkg/version.gitCommitID=${commit} \ 46 - -X ${goPackagePath}/pkg/drivers/kvm.version=v${version} \ 47 - -X ${goPackagePath}/pkg/drivers/kvm.gitCommitID=${commit} \ 48 - -X ${goPackagePath}/pkg/drivers/hyperkit.version=v${version} \ 49 - -X ${goPackagePath}/pkg/drivers/hyperkit.gitCommitID=${commit}" 50 - ''; 36 + installPhase = '' 37 + install out/minikube -Dt $out/bin 51 38 52 - postInstall = '' 53 - mkdir -p $out/share/bash-completion/completions/ 54 - MINIKUBE_WANTUPDATENOTIFICATION=false MINIKUBE_WANTKUBECTLDOWNLOADMSG=false HOME=$PWD $out/bin/minikube completion bash > $out/share/bash-completion/completions/minikube 39 + export HOME=$PWD 40 + export MINIKUBE_WANTUPDATENOTIFICATION=false 41 + export MINIKUBE_WANTKUBECTLDOWNLOADMSG=false 55 42 56 - mkdir -p $out/share/zsh/site-functions/ 57 - MINIKUBE_WANTUPDATENOTIFICATION=false MINIKUBE_WANTKUBECTLDOWNLOADMSG=false HOME=$PWD $out/bin/minikube completion zsh > $out/share/zsh/site-functions/_minikube 43 + for shell in bash zsh; do 44 + $out/bin/minikube completion $shell > minikube.$shell 45 + installShellCompletion minikube.$shell 46 + done 58 47 ''; 59 48 60 49 meta = with stdenv.lib; { 61 - homepage = "https://github.com/kubernetes/minikube"; 50 + homepage = "https://minikube.sigs.k8s.io"; 62 51 description = "A tool that makes it easy to run Kubernetes locally"; 63 - license = licenses.asl20; 52 + license = licenses.asl20; 64 53 maintainers = with maintainers; [ ebzzry copumpkin vdemeester atkinschang ]; 65 - platforms = with platforms; unix; 54 + platforms = platforms.unix; 66 55 }; 67 56 }