From ae7c1f0fb4faf8c7a435d7537567b67e4932baf2 Mon Sep 17 00:00:00 2001 From: Victor Engmark Date: Thu, 10 Oct 2024 13:03:51 +1300 Subject: [PATCH 1/2] pre-commit: Format using nixfmt-rfc-style --- pkgs/by-name/pr/pre-commit/package.nix | 61 ++++++++++++++------------ 1 file changed, 32 insertions(+), 29 deletions(-) diff --git a/pkgs/by-name/pr/pre-commit/package.nix b/pkgs/by-name/pr/pre-commit/package.nix index d11b373aada0..517f6fc3ef85 100644 --- a/pkgs/by-name/pr/pre-commit/package.nix +++ b/pkgs/by-name/pr/pre-commit/package.nix @@ -1,18 +1,19 @@ -{ lib -, fetchFromGitHub -, python3Packages -, libiconv -, cargo -, coursier -, dotnet-sdk -, git -, glibcLocales -, go -, nodejs -, perl -, cabal-install -, testers -, pre-commit +{ + lib, + fetchFromGitHub, + python3Packages, + libiconv, + cargo, + coursier, + dotnet-sdk, + git, + glibcLocales, + go, + nodejs, + perl, + cabal-install, + testers, + pre-commit, }: with python3Packages; @@ -81,24 +82,26 @@ buildPythonApplication rec { "--forked" ]; - preCheck = lib.optionalString (!(stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64)) '' - # Disable outline atomics for rust tests on aarch64-linux. - export RUSTFLAGS="-Ctarget-feature=-outline-atomics" - '' + '' - export GIT_AUTHOR_NAME=test GIT_COMMITTER_NAME=test \ - GIT_AUTHOR_EMAIL=test@example.com GIT_COMMITTER_EMAIL=test@example.com \ - VIRTUALENV_NO_DOWNLOAD=1 PRE_COMMIT_NO_CONCURRENCY=1 LANG=en_US.UTF-8 + preCheck = + lib.optionalString (!(stdenv.hostPlatform.isLinux && stdenv.hostPlatform.isAarch64)) '' + # Disable outline atomics for rust tests on aarch64-linux. + export RUSTFLAGS="-Ctarget-feature=-outline-atomics" + '' + + '' + export GIT_AUTHOR_NAME=test GIT_COMMITTER_NAME=test \ + GIT_AUTHOR_EMAIL=test@example.com GIT_COMMITTER_EMAIL=test@example.com \ + VIRTUALENV_NO_DOWNLOAD=1 PRE_COMMIT_NO_CONCURRENCY=1 LANG=en_US.UTF-8 - # Resolve `.NET location: Not found` errors for dotnet tests - export DOTNET_ROOT="${dotnet-sdk.unwrapped}/share/dotnet" + # Resolve `.NET location: Not found` errors for dotnet tests + export DOTNET_ROOT="${dotnet-sdk.unwrapped}/share/dotnet" - export HOME=$(mktemp -d) + export HOME=$(mktemp -d) - git init -b master + git init -b master - python -m venv --system-site-packages venv - source "$PWD/venv/bin/activate" - ''; + python -m venv --system-site-packages venv + source "$PWD/venv/bin/activate" + ''; postCheck = '' deactivate From 291e11d98f56bc4838de6d4563f7b67b14bc313e Mon Sep 17 00:00:00 2001 From: Victor Engmark Date: Fri, 22 Nov 2024 15:40:02 +1300 Subject: [PATCH 2/2] pre-commit: fix import bug for built-in hooks And add regression test. Closes #270805. Co-Authored-By: Matt Rixman --- pkgs/by-name/pr/pre-commit/package.nix | 10 ++---- pkgs/by-name/pr/pre-commit/tests.nix | 45 ++++++++++++++++++++++++++ 2 files changed, 47 insertions(+), 8 deletions(-) create mode 100644 pkgs/by-name/pr/pre-commit/tests.nix diff --git a/pkgs/by-name/pr/pre-commit/package.nix b/pkgs/by-name/pr/pre-commit/package.nix index 517f6fc3ef85..c5c62a54499f 100644 --- a/pkgs/by-name/pr/pre-commit/package.nix +++ b/pkgs/by-name/pr/pre-commit/package.nix @@ -107,12 +107,6 @@ buildPythonApplication rec { deactivate ''; - # Propagating dependencies leaks them through $PYTHONPATH which causes issues - # when used in nix-shell. - postFixup = '' - rm $out/nix-support/propagated-build-inputs - ''; - disabledTests = [ # ERROR: The install method you used for conda--probably either `pip install conda` # or `easy_install conda`--is not compatible with using conda as an application. @@ -182,8 +176,8 @@ buildPythonApplication rec { "pre_commit" ]; - passthru.tests.version = testers.testVersion { - package = pre-commit; + passthru.tests = callPackage ./tests.nix { + inherit git pre-commit; }; meta = with lib; { diff --git a/pkgs/by-name/pr/pre-commit/tests.nix b/pkgs/by-name/pr/pre-commit/tests.nix new file mode 100644 index 000000000000..a1b40bc2d8cc --- /dev/null +++ b/pkgs/by-name/pr/pre-commit/tests.nix @@ -0,0 +1,45 @@ +{ + git, + pre-commit, + runCommand, + testers, +}: +{ + check-meta-hooks = + runCommand "check-meta-hooks" + { + nativeBuildInputs = [ + git + pre-commit + ]; + } + '' + cd "$(mktemp --directory)" + export HOME="$PWD" + cat << 'EOF' > .pre-commit-config.yaml + repos: + - repo: local + hooks: + - id: echo + name: echo + entry: echo + files: \.yaml$ + language: system + - repo: meta + hooks: + - id: check-hooks-apply + - id: check-useless-excludes + - id: identity + EOF + git config --global user.email "you@example.com" + git config --global user.name "Your Name" + git init --initial-branch=main + git add . + pre-commit run --all-files + touch $out + ''; + + version = testers.testVersion { + package = pre-commit; + }; +}