Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
119 lines
3.8 KiB
Nix
119 lines
3.8 KiB
Nix
{
|
|
lib,
|
|
stdenv,
|
|
buildGoModule,
|
|
dependabot-cli,
|
|
dockerTools,
|
|
fetchFromGitHub,
|
|
installShellFiles,
|
|
makeWrapper,
|
|
symlinkJoin,
|
|
testers,
|
|
}:
|
|
let
|
|
pname = "dependabot-cli";
|
|
version = "1.74.0";
|
|
|
|
# `tag` is what `dependabot` uses to find the relevant docker images.
|
|
tag = "nixpkgs-dependabot-cli-${version}";
|
|
|
|
# Get these hashes from
|
|
# nix run nixpkgs#nix-prefetch-docker -- --image-name ghcr.io/github/dependabot-update-job-proxy/dependabot-update-job-proxy --image-tag latest --final-image-name dependabot-update-job-proxy --final-image-tag ${tag}
|
|
updateJobProxy.imageDigest = "sha256:05539969894efd6f5d04c9c633f330cc61a3024106b19361d6684850258e4f0f";
|
|
updateJobProxy.hash = "sha256-qhHkL1HmCz0o3JIBAevWnTkidtoH92wE2GyzYTFhVyY=";
|
|
|
|
# Get these hashes from
|
|
# nix run nixpkgs#nix-prefetch-docker -- --image-name ghcr.io/dependabot/dependabot-updater-github-actions --image-tag latest --final-image-name dependabot-updater-github-actions --final-image-tag ${tag}
|
|
updaterGitHubActions.imageDigest = "sha256:7424e2a837d3bee8c49ddabf8d0152e9d5e87eac6cf67edb684f5e9f7895cff3";
|
|
updaterGitHubActions.hash = "sha256-75qJjwYEkpKP1Gs87odBsiLXTZhQ0KvaOpBB+YFZkJY=";
|
|
in
|
|
buildGoModule {
|
|
inherit pname version;
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "dependabot";
|
|
repo = "cli";
|
|
rev = "v${version}";
|
|
hash = "sha256-h1qnyH9M37kWFeET31KFKNn+RnnE7FRcaKADDDtxSdw=";
|
|
};
|
|
|
|
vendorHash = "sha256-Tq+mHd/5LkBkqEXvZ98SRTdA6IsCdUPril+AmPQZfdI=";
|
|
|
|
ldflags = [
|
|
"-s"
|
|
"-w"
|
|
"-X github.com/dependabot/cli/cmd/dependabot/internal/cmd.version=v${version}"
|
|
];
|
|
|
|
nativeBuildInputs = [
|
|
makeWrapper
|
|
installShellFiles
|
|
];
|
|
|
|
postInstall = lib.optionalString (stdenv.buildPlatform.canExecute stdenv.hostPlatform) ''
|
|
installShellCompletion --cmd dependabot \
|
|
--bash <($out/bin/dependabot completion bash) \
|
|
--fish <($out/bin/dependabot completion fish) \
|
|
--zsh <($out/bin/dependabot completion zsh)
|
|
'';
|
|
|
|
checkFlags = [
|
|
"-skip=TestDependabot"
|
|
];
|
|
|
|
doInstallCheck = true;
|
|
installCheckPhase = ''
|
|
$out/bin/dependabot --help
|
|
'';
|
|
|
|
passthru.updateScript = ./update.sh;
|
|
|
|
passthru.withDockerImages = symlinkJoin {
|
|
name = "dependabot-cli-with-docker-images";
|
|
paths = [ dependabot-cli ];
|
|
buildInputs = [ makeWrapper ];
|
|
postBuild =
|
|
let
|
|
updateJobProxyImage = dockerTools.pullImage {
|
|
imageName = "ghcr.io/github/dependabot-update-job-proxy/dependabot-update-job-proxy";
|
|
finalImageName = "dependabot-update-job-proxy";
|
|
finalImageTag = tag;
|
|
inherit (updateJobProxy) imageDigest hash;
|
|
};
|
|
|
|
updaterGitHubActionsImage = dockerTools.pullImage {
|
|
imageName = "ghcr.io/dependabot/dependabot-updater-github-actions";
|
|
finalImageName = "dependabot-updater-github-actions";
|
|
finalImageTag = tag;
|
|
inherit (updaterGitHubActions) imageDigest hash;
|
|
};
|
|
in
|
|
''
|
|
# Create a wrapper that pins the docker images that `dependabot` uses.
|
|
wrapProgram $out/bin/dependabot \
|
|
--run "docker load --input ${updateJobProxyImage} >&2" \
|
|
--add-flags "--proxy-image=dependabot-update-job-proxy:${tag}" \
|
|
--run "docker load --input ${updaterGitHubActionsImage} >&2" \
|
|
--add-flags "--updater-image=dependabot-updater-github-actions:${tag}"
|
|
'';
|
|
};
|
|
|
|
passthru.tests.version = testers.testVersion {
|
|
package = dependabot-cli;
|
|
command = "dependabot --version";
|
|
version = "v${version}";
|
|
};
|
|
|
|
meta = {
|
|
changelog = "https://github.com/dependabot/cli/releases/tag/v${version}";
|
|
description = "Tool for testing and debugging Dependabot update jobs";
|
|
mainProgram = "dependabot";
|
|
homepage = "https://github.com/dependabot/cli";
|
|
license = lib.licenses.mit;
|
|
maintainers = with lib.maintainers; [
|
|
infinisil
|
|
philiptaron
|
|
];
|
|
};
|
|
}
|