From a72ce7c34c123283d1eacc368759668012e91c15 Mon Sep 17 00:00:00 2001 From: Thiago Kenji Okada Date: Tue, 24 Oct 2023 18:31:22 +0100 Subject: [PATCH] Pin nixpkgs (#88) * Pin nixpkgs according to nix-index-database This PR should fix #87 by ensuring that what database the nix-index-database is pointing up is the nixpkgs version we will end up using in the default.nix files. For now this only changes the non-Flake version. The Flake ones will come in another PR. * Implement nixpkgs pining in Flake versions * Fix checks * Bump UUID to regenerate all nix-alien files Since there is so many changes in nix-alien right now, this commit will bump the UUID used as a base for hashing the names, so we can ensure everyone will use the new changes. * Simplify substituteInPlace calls --- checks.nix | 26 ++++++++++++++++++-------- default.nix | 1 + flake.lock | 22 ++++++++++++++++++---- flake.nix | 9 +++------ nix-alien.nix | 23 +++++++++-------------- nix_alien/fhs_env.template.nix | 9 ++++++++- nix_alien/fhs_env_flake.template.nix | 4 ++-- nix_alien/helpers.py | 2 +- nix_alien/nix_ld.template.nix | 9 ++++++++- nix_alien/nix_ld_flake.template.nix | 5 ++--- shell.nix | 10 ++++++++-- tests/test_fhs_env.py | 26 ++++++++++++++++++++------ tests/test_helpers.py | 18 +++++++++--------- tests/test_nix_ld.py | 27 ++++++++++++++++++++------- 14 files changed, 127 insertions(+), 64 deletions(-) diff --git a/checks.nix b/checks.nix index e4fb4a7..e140957 100644 --- a/checks.nix +++ b/checks.nix @@ -1,16 +1,26 @@ { pkgs ? (import ./compat.nix).pkgs +, self ? (import ./compat.nix).flake }: -let - rev = "0.1.0+ci"; -in { - nix-alien-ci = pkgs.callPackage ./nix-alien.nix { - inherit rev; - ci = true; - }; + inherit (self.outputs.packages.${pkgs.system}) nix-alien nix-index-update; - nix-index-update-ci = pkgs.callPackage ./nix-index-update.nix { }; + check-py-files = pkgs.runCommand "check-py-files" + { + src = ./.; + nativeBuildInputs = with pkgs; [ + python3.pkgs.black + python3.pkgs.mypy + ruff + ]; + } '' + touch $out + export PYLINTHOME="$(mktemp -d)" + export RUFF_CACHE_DIR="$(mktemp -d)" + black --check $src/nix_alien + mypy --ignore-missing-imports $src/nix_alien + ruff check $src/nix_alien + ''; check-nix-files = pkgs.runCommand "check-nix-files" { diff --git a/default.nix b/default.nix index 030d4bd..8222952 100644 --- a/default.nix +++ b/default.nix @@ -11,6 +11,7 @@ in nix-alien = pkgs.callPackage ./nix-alien.nix { inherit rev; nix-index = self.inputs.nix-index-database.packages.${pkgs.system}.nix-index-with-db; + nixpkgs-src = self.inputs.nix-index-database.inputs.nixpkgs.sourceInfo; }; # For backwards compat, may be removed in the future diff --git a/flake.lock b/flake.lock index 89133f7..f457e9b 100644 --- a/flake.lock +++ b/flake.lock @@ -36,9 +36,7 @@ }, "nix-index-database": { "inputs": { - "nixpkgs": [ - "nixpkgs" - ] + "nixpkgs": "nixpkgs" }, "locked": { "lastModified": 1697340827, @@ -55,6 +53,22 @@ } }, "nixpkgs": { + "locked": { + "lastModified": 1697723726, + "narHash": "sha256-SaTWPkI8a5xSHX/rrKzUe+/uVNy6zCGMXgoeMb7T9rg=", + "owner": "nixos", + "repo": "nixpkgs", + "rev": "7c9cc5a6e5d38010801741ac830a3f8fd667a7a0", + "type": "github" + }, + "original": { + "owner": "nixos", + "ref": "nixos-unstable", + "repo": "nixpkgs", + "type": "github" + } + }, + "nixpkgs_2": { "locked": { "lastModified": 1697009197, "narHash": "sha256-viVRhBTFT8fPJTb1N3brQIpFZnttmwo3JVKNuWRVc3s=", @@ -75,7 +89,7 @@ "flake-compat": "flake-compat", "flake-utils": "flake-utils", "nix-index-database": "nix-index-database", - "nixpkgs": "nixpkgs" + "nixpkgs": "nixpkgs_2" } }, "systems": { diff --git a/flake.nix b/flake.nix index 70b94c3..6475006 100644 --- a/flake.nix +++ b/flake.nix @@ -8,10 +8,7 @@ }; flake-utils.url = "github:numtide/flake-utils"; nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable"; - nix-index-database = { - url = "github:Mic92/nix-index-database"; - inputs.nixpkgs.follows = "nixpkgs"; - }; + nix-index-database.url = "github:Mic92/nix-index-database"; }; outputs = { self, nixpkgs, flake-utils, ... }: @@ -32,7 +29,7 @@ default = self.outputs.packages.${system}.nix-alien; }; - checks = import ./checks.nix { inherit pkgs; }; + checks = import ./checks.nix { inherit pkgs self; }; apps = let @@ -46,6 +43,6 @@ nix-index-update = mkApp { drv = self.outputs.packages.${system}.nix-index-update; }; }; - devShells.default = import ./shell.nix { inherit pkgs; }; + devShells.default = import ./shell.nix { inherit pkgs self; }; })); } diff --git a/nix-alien.nix b/nix-alien.nix index efdd5b1..7aff5ae 100644 --- a/nix-alien.nix +++ b/nix-alien.nix @@ -1,14 +1,16 @@ { lib , fzf , nix-index +, nixpkgs-src ? { + lastModifiedDate = "19700101000000"; + rev = "nixpkgs-unstable"; + narHash = "sha256-AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA="; + } , python3 -, ruff , rev ? null , dev ? false -, ci ? false }: -assert dev -> !ci; let version = if (rev != null) then rev else "dev"; deps = (lib.importTOML ./pyproject.toml).project.dependencies; @@ -29,25 +31,18 @@ python3.pkgs.buildPythonApplication { preBuild = lib.optionalString (rev != null) '' echo "__version__ = \"${rev}\"" > nix_alien/_version.py + substituteInPlace {nix_alien,tests}/*.{py,nix} \ + --subst-var-by nixpkgsLastModifiedDate ${nixpkgs-src.lastModifiedDate} \ + --subst-var-by nixpkgsRev ${nixpkgs-src.rev} \ + --subst-var-by nixpkgsHash ${nixpkgs-src.narHash} ''; doCheck = !dev; nativeCheckInputs = with python3.pkgs; [ pytestCheckHook - ] ++ lib.optionals ci [ - black - mypy - ruff ]; - preCheck = lib.optionalString ci '' - export PYLINTHOME="$(mktemp -d)" - black --check ./nix_alien - mypy --ignore-missing-imports ./nix_alien - ruff check ./nix_alien - ''; - meta = with lib; { description = "Run unpatched binaries on Nix/NixOS"; homepage = "https://github.com/thiagokokada/nix-alien"; diff --git a/nix_alien/fhs_env.template.nix b/nix_alien/fhs_env.template.nix index 17f4537..3388fbb 100644 --- a/nix_alien/fhs_env.template.nix +++ b/nix_alien/fhs_env.template.nix @@ -1,4 +1,11 @@ -{ pkgs ? import { } }: +{ pkgs ? import + (builtins.fetchTarball { + name = "nixpkgs-unstable-@nixpkgsLastModifiedDate@"; + url = "https://github.com/NixOS/nixpkgs/archive/@nixpkgsRev@.tar.gz"; + sha256 = "@nixpkgsHash@"; + }) + { } +}: let inherit (pkgs) buildFHSUserEnv; diff --git a/nix_alien/fhs_env_flake.template.nix b/nix_alien/fhs_env_flake.template.nix index a0eb7a1..7b13bb5 100644 --- a/nix_alien/fhs_env_flake.template.nix +++ b/nix_alien/fhs_env_flake.template.nix @@ -1,7 +1,7 @@ { description = "${__name__}-fhs"; - inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable"; + inputs.nixpkgs.url = "github:NixOS/nixpkgs/@nixpkgsRev@"; outputs = { self, nixpkgs }: let @@ -23,7 +23,7 @@ defaultApp.${system} = { type = "app"; - program = "${defaultPackage.${system}}/bin/${__name__}-fhs"; + program = "${self.outputs.defaultPackage.${system}}/bin/${__name__}-fhs"; }; }; } diff --git a/nix_alien/helpers.py b/nix_alien/helpers.py index c6fb850..c6428e7 100644 --- a/nix_alien/helpers.py +++ b/nix_alien/helpers.py @@ -7,7 +7,7 @@ from string import Template from typing import Callable, Optional -UUID_NAMESPACE = uuid.UUID("f318d4a6-dd46-47ce-995d-e95c17cadcc0") +UUID_NAMESPACE = uuid.UUID("eebf3397-2041-4370-bf33-937b33d5c959") def edit_file(file: Path) -> subprocess.CompletedProcess: diff --git a/nix_alien/nix_ld.template.nix b/nix_alien/nix_ld.template.nix index c6aad28..04e41e7 100644 --- a/nix_alien/nix_ld.template.nix +++ b/nix_alien/nix_ld.template.nix @@ -1,4 +1,11 @@ -{ pkgs ? import { } }: +{ pkgs ? import + (builtins.fetchTarball { + name = "nixpkgs-unstable-@nixpkgsLastModifiedDate@"; + url = "https://github.com/NixOS/nixpkgs/archive/@nixpkgsRev@.tar.gz"; + sha256 = "@nixpkgsHash@"; + }) + { } +}: let inherit (pkgs) lib stdenv; diff --git a/nix_alien/nix_ld_flake.template.nix b/nix_alien/nix_ld_flake.template.nix index 9cf4304..76b15fc 100644 --- a/nix_alien/nix_ld_flake.template.nix +++ b/nix_alien/nix_ld_flake.template.nix @@ -1,7 +1,7 @@ { description = "${__name__}-nix-ld"; - inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable"; + inputs.nixpkgs.url = "github:NixOS/nixpkgs/@nixpkgsRev@"; outputs = { self, nixpkgs }: let @@ -15,11 +15,10 @@ NIX_LD_LIBRARY_PATH = with pkgs; lib.makeLibraryPath [ ${__packages__} ]; - NIX_LD = lib.fileContents "${stdenv.cc}/nix-support/dynamic-linker"; in pkgs.writeShellScriptBin "${__name__}" '' export NIX_LD_LIBRARY_PATH='${NIX_LD_LIBRARY_PATH}'${"\${NIX_LD_LIBRARY_PATH:+':'}$NIX_LD_LIBRARY_PATH"} - export NIX_LD='${NIX_LD}' + export NIX_LD="$(cat ${stdenv.cc}/nix-support/dynamic-linker)" ${__program__} "$@" ''; diff --git a/shell.nix b/shell.nix index 9fca9ab..ef5a1c8 100644 --- a/shell.nix +++ b/shell.nix @@ -1,8 +1,14 @@ -{ pkgs ? (import ./compat.nix).pkgs }: +{ pkgs ? (import ./compat.nix).pkgs +, self ? (import ./compat.nix).flake +}: let inherit (pkgs) python3 callPackage; - nix-alien = python3.pkgs.toPythonModule (callPackage ./nix-alien.nix { dev = true; }); + nix-alien = python3.pkgs.toPythonModule (callPackage ./nix-alien.nix { + dev = true; + nix-index = self.inputs.nix-index-database.packages.${pkgs.system}.nix-index-with-db; + nixpkgs-src = self.inputs.nix-index-database.inputs.nixpkgs.sourceInfo; + }); python-with-packages = python3.withPackages (ps: with ps; [ black mypy diff --git a/tests/test_fhs_env.py b/tests/test_fhs_env.py index 501d7a2..e39f097 100644 --- a/tests/test_fhs_env.py +++ b/tests/test_fhs_env.py @@ -14,7 +14,14 @@ def test_create_fhs_env_drv(mock_find_libs, pytestconfig): assert ( fhs_env.create_fhs_env_drv("xyz", additional_packages=["libGL"]) == """\ -{ pkgs ? import { } }: +{ pkgs ? import + (builtins.fetchTarball { + name = "nixpkgs-unstable-@nixpkgsLastModifiedDate@"; + url = "https://github.com/NixOS/nixpkgs/archive/@nixpkgsRev@.tar.gz"; + sha256 = "@nixpkgsHash@"; + }) + { } +}: let inherit (pkgs) buildFHSUserEnv; @@ -45,7 +52,14 @@ def test_create_fhs_env_drv_with_spaces(mock_find_libs, pytestconfig): assert ( fhs_env.create_fhs_env_drv("x y z", additional_packages=["libGL"]) == """\ -{ pkgs ? import { } }: +{ pkgs ? import + (builtins.fetchTarball { + name = "nixpkgs-unstable-@nixpkgsLastModifiedDate@"; + url = "https://github.com/NixOS/nixpkgs/archive/@nixpkgsRev@.tar.gz"; + sha256 = "@nixpkgsHash@"; + }) + { } +}: let inherit (pkgs) buildFHSUserEnv; @@ -81,7 +95,7 @@ def test_create_fhs_env_drv_flake(mock_machine, mock_find_libs, pytestconfig): { description = "xyz-fhs"; - inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable"; + inputs.nixpkgs.url = "github:NixOS/nixpkgs/@nixpkgsRev@"; outputs = { self, nixpkgs }: let @@ -106,7 +120,7 @@ def test_create_fhs_env_drv_flake(mock_machine, mock_find_libs, pytestconfig): defaultApp.${system} = { type = "app"; - program = "${defaultPackage.${system}}/bin/xyz-fhs"; + program = "${self.outputs.defaultPackage.${system}}/bin/xyz-fhs"; }; }; } @@ -222,7 +236,7 @@ def test_main_with_print(monkeypatch, capsys): assert ( out == """\ -/home/nameless-shelter/.cache/nix-alien/b5ae45f6-276c-53a3-93ab-4a44f35976a4/fhs-env/default.nix +/home/nameless-shelter/.cache/nix-alien/d51a223b-43f0-56c6-b5c8-2404823026ac/fhs-env/default.nix """ ) @@ -232,6 +246,6 @@ def test_main_with_print(monkeypatch, capsys): assert ( out == """\ -/home/nameless-shelter/.cache/nix-alien/b5ae45f6-276c-53a3-93ab-4a44f35976a4/fhs-env/flake.nix +/home/nameless-shelter/.cache/nix-alien/d51a223b-43f0-56c6-b5c8-2404823026ac/fhs-env/flake.nix """ ) diff --git a/tests/test_helpers.py b/tests/test_helpers.py index 89043a4..6726859 100644 --- a/tests/test_helpers.py +++ b/tests/test_helpers.py @@ -12,31 +12,31 @@ def test_edit_file(monkeypatch): def test_get_hash_for_program(monkeypatch): monkeypatch.setenv("HOME", "/home/nameless-shelter") assert helpers.get_hash_for_program("/home/nameless-shelter/abc") == UUID( - "d0efaea7-176f-56e6-99a0-ea49599a163b" + "0acc4435-07de-59bf-a1c3-a42f55aaca35" ) assert helpers.get_hash_for_program("~/abc") == UUID( - "d0efaea7-176f-56e6-99a0-ea49599a163b" + "0acc4435-07de-59bf-a1c3-a42f55aaca35" ) assert helpers.get_hash_for_program("/abc") == UUID( - "f52177f5-def5-5d9e-91fc-ef1283fc54b1" + "cf2f97e0-6eec-5407-aea0-bbecc488d451" ) assert helpers.get_hash_for_program("/./abc") == UUID( - "f52177f5-def5-5d9e-91fc-ef1283fc54b1" + "cf2f97e0-6eec-5407-aea0-bbecc488d451" ) assert helpers.get_hash_for_program("/xyz/../abc") == UUID( - "f52177f5-def5-5d9e-91fc-ef1283fc54b1" + "cf2f97e0-6eec-5407-aea0-bbecc488d451" ) def test_get_cache_path(monkeypatch): monkeypatch.setenv("HOME", "/home/nameless-shelter") assert helpers.get_cache_path("/abc") == Path( - "/home/nameless-shelter/.cache/nix-alien/f52177f5-def5-5d9e-91fc-ef1283fc54b1" + "/home/nameless-shelter/.cache/nix-alien/cf2f97e0-6eec-5407-aea0-bbecc488d451" ) monkeypatch.setenv("XDG_CACHE_HOME", "/") assert helpers.get_cache_path("/abc") == Path( - "/nix-alien/f52177f5-def5-5d9e-91fc-ef1283fc54b1" + "/nix-alien/cf2f97e0-6eec-5407-aea0-bbecc488d451" ) @@ -48,7 +48,7 @@ def test_get_dest_path(monkeypatch): directory="bar", filename="foo.nix", ) == Path( - "/home/nameless-shelter/.cache/nix-alien/f52177f5-def5-5d9e-91fc-ef1283fc54b1/bar/foo.nix" + "/home/nameless-shelter/.cache/nix-alien/cf2f97e0-6eec-5407-aea0-bbecc488d451/bar/foo.nix" ) monkeypatch.setenv("XDG_CACHE_HOME", "/") @@ -57,7 +57,7 @@ def test_get_dest_path(monkeypatch): program="/abc", directory="bar", filename="foo.nix", - ) == Path("/nix-alien/f52177f5-def5-5d9e-91fc-ef1283fc54b1/bar/foo.nix") + ) == Path("/nix-alien/cf2f97e0-6eec-5407-aea0-bbecc488d451/bar/foo.nix") assert helpers.get_dest_path( destination="/quux", diff --git a/tests/test_nix_ld.py b/tests/test_nix_ld.py index 9e4169d..dca0d71 100644 --- a/tests/test_nix_ld.py +++ b/tests/test_nix_ld.py @@ -14,7 +14,14 @@ def test_create_nix_ld_drv(mock_find_libs, pytestconfig): assert ( nix_ld.create_nix_ld_drv("xyz", additional_packages=["libGL"]) == """\ -{ pkgs ? import { } }: +{ pkgs ? import + (builtins.fetchTarball { + name = "nixpkgs-unstable-@nixpkgsLastModifiedDate@"; + url = "https://github.com/NixOS/nixpkgs/archive/@nixpkgsRev@.tar.gz"; + sha256 = "@nixpkgsHash@"; + }) + { } +}: let inherit (pkgs) lib stdenv; @@ -47,7 +54,14 @@ def test_create_nix_ld_drv_with_spaces(mock_find_libs, pytestconfig): assert ( nix_ld.create_nix_ld_drv("x y z", additional_packages=["libGL"]) == """\ -{ pkgs ? import { } }: +{ pkgs ? import + (builtins.fetchTarball { + name = "nixpkgs-unstable-@nixpkgsLastModifiedDate@"; + url = "https://github.com/NixOS/nixpkgs/archive/@nixpkgsRev@.tar.gz"; + sha256 = "@nixpkgsHash@"; + }) + { } +}: let inherit (pkgs) lib stdenv; @@ -85,7 +99,7 @@ def test_create_nix_ld_drv_flake(mock_machine, mock_find_libs, pytestconfig): { description = "xyz-nix-ld"; - inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable"; + inputs.nixpkgs.url = "github:NixOS/nixpkgs/@nixpkgsRev@"; outputs = { self, nixpkgs }: let @@ -102,11 +116,10 @@ def test_create_nix_ld_drv_flake(mock_machine, mock_find_libs, pytestconfig): quux.out libGL ]; - NIX_LD = lib.fileContents "${stdenv.cc}/nix-support/dynamic-linker"; in pkgs.writeShellScriptBin "xyz" '' export NIX_LD_LIBRARY_PATH='${NIX_LD_LIBRARY_PATH}'${"\\${NIX_LD_LIBRARY_PATH:+':'}$NIX_LD_LIBRARY_PATH"} - export NIX_LD='${NIX_LD}' + export NIX_LD="$(cat ${stdenv.cc}/nix-support/dynamic-linker)" %s/xyz "$@" ''; @@ -228,7 +241,7 @@ def test_main_with_print(monkeypatch, capsys): assert ( out == """\ -/home/nameless-shelter/.cache/nix-alien/b5ae45f6-276c-53a3-93ab-4a44f35976a4/nix-ld/default.nix +/home/nameless-shelter/.cache/nix-alien/d51a223b-43f0-56c6-b5c8-2404823026ac/nix-ld/default.nix """ ) @@ -238,6 +251,6 @@ def test_main_with_print(monkeypatch, capsys): assert ( out == """\ -/home/nameless-shelter/.cache/nix-alien/b5ae45f6-276c-53a3-93ab-4a44f35976a4/nix-ld/flake.nix +/home/nameless-shelter/.cache/nix-alien/d51a223b-43f0-56c6-b5c8-2404823026ac/nix-ld/flake.nix """ )