From 162a65f029e480b82c79bcb766568ba2e0092e2b Mon Sep 17 00:00:00 2001 From: Robert Helgesson Date: Sat, 27 Apr 2019 00:21:18 +0200 Subject: [PATCH] Fix type of various `sessionVariables` options Unfortunately, using `attrsOf` is not possible since it results in too eager evaluation. In particular, the home.sessionVariables = { FOO = "Hello"; BAR = "${config.home.sessionVariables.FOO} World!"; }; example will cause an infinite recursion. This commit restores the option type of - `home.sessionVariables`, - `pam.sessionVariables`, - `programs.bash.sessionVariables`, and - `programs.zsh.sessionVariables` to `attrs`. It also adds test cases for the above options to avoid regressions. Fixes #659 (cherry picked from commit b6e613c7711fcab0adbc582f1db0b83c11840fba) --- modules/home-environment.nix | 18 ++++++------ modules/misc/pam.nix | 2 +- modules/programs/bash.nix | 2 +- modules/programs/zsh.nix | 2 +- tests/default.nix | 6 +++- tests/modules/home-environment/default.nix | 3 ++ .../session-variables-expected.txt | 6 ++++ .../home-environment/session-variables.nix | 19 +++++++++++++ tests/modules/misc/pam/default.nix | 3 ++ .../misc/pam/session-variables-expected.txt | 2 ++ tests/modules/misc/pam/session-variables.nix | 19 +++++++++++++ tests/modules/programs/bash/default.nix | 3 ++ .../bash/session-variables-expected.txt | 8 ++++++ .../programs/bash/session-variables.nix | 28 +++++++++++++++++++ tests/modules/programs/zsh/default.nix | 3 ++ .../programs/zsh/session-variables.nix | 22 +++++++++++++++ 16 files changed, 133 insertions(+), 13 deletions(-) create mode 100644 tests/modules/home-environment/default.nix create mode 100644 tests/modules/home-environment/session-variables-expected.txt create mode 100644 tests/modules/home-environment/session-variables.nix create mode 100644 tests/modules/misc/pam/default.nix create mode 100644 tests/modules/misc/pam/session-variables-expected.txt create mode 100644 tests/modules/misc/pam/session-variables.nix create mode 100644 tests/modules/programs/bash/default.nix create mode 100644 tests/modules/programs/bash/session-variables-expected.txt create mode 100644 tests/modules/programs/bash/session-variables.nix create mode 100644 tests/modules/programs/zsh/default.nix create mode 100644 tests/modules/programs/zsh/session-variables.nix diff --git a/modules/home-environment.nix b/modules/home-environment.nix index c577c3072..7f51cd8a3 100644 --- a/modules/home-environment.nix +++ b/modules/home-environment.nix @@ -149,7 +149,7 @@ in home.sessionVariables = mkOption { default = {}; - type = with types; attrsOf (either int str); + type = types.attrs; example = { EDITOR = "emacs"; GS_OPTIONS = "-sPAPERSIZE=a4"; }; description = '' Environment variables to always set at login. @@ -167,19 +167,19 @@ in variable may have a runtime dependency on another session variable. In particular code like - home.sessionVariables = { - FOO = "Hello"; - BAR = "$FOO World!"; - }; + home.sessionVariables = { + FOO = "Hello"; + BAR = "$FOO World!"; + }; may not work as expected. If you need to reference another session variable, then do so inside Nix instead. The above example then becomes - home.sessionVariables = { - FOO = "Hello"; - BAR = "''${config.home.sessionVariables.FOO} World!"; - }; + home.sessionVariables = { + FOO = "Hello"; + BAR = "''${config.home.sessionVariables.FOO} World!"; + }; ''; }; diff --git a/modules/misc/pam.nix b/modules/misc/pam.nix index 9cebc0a8b..6ace2bfda 100644 --- a/modules/misc/pam.nix +++ b/modules/misc/pam.nix @@ -14,7 +14,7 @@ in options = { pam.sessionVariables = mkOption { default = {}; - type = with types; attrsOf (either int str); + type = types.attrs; example = { EDITOR = "vim"; }; description = '' Environment variables that will be set for the PAM session. diff --git a/modules/programs/bash.nix b/modules/programs/bash.nix index 92ce18d25..98f149066 100644 --- a/modules/programs/bash.nix +++ b/modules/programs/bash.nix @@ -72,7 +72,7 @@ in sessionVariables = mkOption { default = {}; - type = with types; attrsOf (either int str); + type = types.attrs; example = { MAILCHECK = 30; }; description = '' Environment variables that will be set for the Bash session. diff --git a/modules/programs/zsh.nix b/modules/programs/zsh.nix index ad59ad749..3e0e4062d 100644 --- a/modules/programs/zsh.nix +++ b/modules/programs/zsh.nix @@ -202,7 +202,7 @@ in sessionVariables = mkOption { default = {}; - type = with types; attrsOf (either int str); + type = types.attrs; example = { MAILCHECK = 30; }; description = "Environment variables that will be set for zsh session."; }; diff --git a/tests/default.nix b/tests/default.nix index 2a0e53388..39353e482 100644 --- a/tests/default.nix +++ b/tests/default.nix @@ -31,8 +31,12 @@ import nmt { { i3-keybindings = ./modules/services/window-managers/i3-keybindings.nix; } + // import ./modules/misc/pam // import ./modules/systemd ) + // import ./modules/home-environment + // import ./modules/programs/bash // import ./modules/programs/ssh - // import ./modules/programs/tmux; + // import ./modules/programs/tmux + // import ./modules/programs/zsh; } diff --git a/tests/modules/home-environment/default.nix b/tests/modules/home-environment/default.nix new file mode 100644 index 000000000..2a1201a2f --- /dev/null +++ b/tests/modules/home-environment/default.nix @@ -0,0 +1,3 @@ +{ + home-session-variables = ./session-variables.nix; +} diff --git a/tests/modules/home-environment/session-variables-expected.txt b/tests/modules/home-environment/session-variables-expected.txt new file mode 100644 index 000000000..5c3868c39 --- /dev/null +++ b/tests/modules/home-environment/session-variables-expected.txt @@ -0,0 +1,6 @@ +# Only source this once. +if [ -n "$__HM_SESS_VARS_SOURCED" ]; then return; fi +export __HM_SESS_VARS_SOURCED=1 + +export V1="v1" +export V2="v2-v1" diff --git a/tests/modules/home-environment/session-variables.nix b/tests/modules/home-environment/session-variables.nix new file mode 100644 index 000000000..9f326ebc1 --- /dev/null +++ b/tests/modules/home-environment/session-variables.nix @@ -0,0 +1,19 @@ +{ config, lib, ... }: + +with lib; + +{ + config = { + home.sessionVariables = { + V1 = "v1"; + V2 = "v2-${config.home.sessionVariables.V1}"; + }; + + nmt.script = '' + assertFileExists home-path/etc/profile.d/hm-session-vars.sh + assertFileContent \ + home-path/etc/profile.d/hm-session-vars.sh \ + ${./session-variables-expected.txt} + ''; + }; +} diff --git a/tests/modules/misc/pam/default.nix b/tests/modules/misc/pam/default.nix new file mode 100644 index 000000000..8a64f831c --- /dev/null +++ b/tests/modules/misc/pam/default.nix @@ -0,0 +1,3 @@ +{ + pam-session-variables = ./session-variables.nix; +} diff --git a/tests/modules/misc/pam/session-variables-expected.txt b/tests/modules/misc/pam/session-variables-expected.txt new file mode 100644 index 000000000..b84a12b76 --- /dev/null +++ b/tests/modules/misc/pam/session-variables-expected.txt @@ -0,0 +1,2 @@ +V1 OVERRIDE="v1" +V2 OVERRIDE="v2-v1" diff --git a/tests/modules/misc/pam/session-variables.nix b/tests/modules/misc/pam/session-variables.nix new file mode 100644 index 000000000..4fbec4163 --- /dev/null +++ b/tests/modules/misc/pam/session-variables.nix @@ -0,0 +1,19 @@ +{ config, lib, ... }: + +with lib; + +{ + config = { + pam.sessionVariables = { + V1 = "v1"; + V2 = "v2-${config.pam.sessionVariables.V1}"; + }; + + nmt.script = '' + assertFileExists home-files/.pam_environment + assertFileContent \ + home-files/.pam_environment \ + ${./session-variables-expected.txt} + ''; + }; +} diff --git a/tests/modules/programs/bash/default.nix b/tests/modules/programs/bash/default.nix new file mode 100644 index 000000000..0d361adf7 --- /dev/null +++ b/tests/modules/programs/bash/default.nix @@ -0,0 +1,3 @@ +{ + bash-session-variables = ./session-variables.nix; +} diff --git a/tests/modules/programs/bash/session-variables-expected.txt b/tests/modules/programs/bash/session-variables-expected.txt new file mode 100644 index 000000000..c586477ec --- /dev/null +++ b/tests/modules/programs/bash/session-variables-expected.txt @@ -0,0 +1,8 @@ +# -*- mode: sh -*- + +. "@homeDirectory@/.nix-profile/etc/profile.d/hm-session-vars.sh" + +export V1="v1" +export V2="v2-v1" + + diff --git a/tests/modules/programs/bash/session-variables.nix b/tests/modules/programs/bash/session-variables.nix new file mode 100644 index 000000000..a7a69a2a1 --- /dev/null +++ b/tests/modules/programs/bash/session-variables.nix @@ -0,0 +1,28 @@ +{ config, lib, pkgs, ... }: + +with lib; + +{ + config = { + programs.bash = { + enable = true; + + sessionVariables = { + V1 = "v1"; + V2 = "v2-${config.programs.bash.sessionVariables.V1}"; + }; + }; + + nmt.script = '' + assertFileExists home-files/.profile + assertFileContent \ + home-files/.profile \ + ${ + pkgs.substituteAll { + src = ./session-variables-expected.txt; + inherit (config.home) homeDirectory; + } + } + ''; + }; +} diff --git a/tests/modules/programs/zsh/default.nix b/tests/modules/programs/zsh/default.nix new file mode 100644 index 000000000..da5dd5b55 --- /dev/null +++ b/tests/modules/programs/zsh/default.nix @@ -0,0 +1,3 @@ +{ + zsh-session-variables = ./session-variables.nix; +} diff --git a/tests/modules/programs/zsh/session-variables.nix b/tests/modules/programs/zsh/session-variables.nix new file mode 100644 index 000000000..a87d39820 --- /dev/null +++ b/tests/modules/programs/zsh/session-variables.nix @@ -0,0 +1,22 @@ +{ config, lib, ... }: + +with lib; + +{ + config = { + programs.zsh = { + enable = true; + + sessionVariables = { + V1 = "v1"; + V2 = "v2-${config.programs.zsh.sessionVariables.V1}"; + }; + }; + + nmt.script = '' + assertFileExists home-files/.zshrc + assertFileRegex home-files/.zshrc 'export V1="v1"' + assertFileRegex home-files/.zshrc 'export V2="v2-v1"' + ''; + }; +}