add more tests to be able to import shb with default config
This commit is contained in:
parent
9a758fb86e
commit
af71513dcf
5 changed files with 113 additions and 14 deletions
|
@ -42,11 +42,14 @@
|
|||
let
|
||||
importFiles = files:
|
||||
map (m: import m {
|
||||
inherit pkgs;
|
||||
inherit (pkgs) lib;
|
||||
}) files;
|
||||
|
||||
mergeTests = pkgs.lib.lists.foldl pkgs.lib.trivial.mergeAttrs {};
|
||||
in mergeTests (importFiles [
|
||||
./test/modules/arr.nix
|
||||
./test/modules/davfs.nix
|
||||
./test/modules/postgresql.nix
|
||||
]);
|
||||
};
|
||||
|
|
|
@ -24,6 +24,7 @@ let
|
|||
settingsFormat = pkgs.formats.json {};
|
||||
moreOptions = {
|
||||
settings = lib.mkOption {
|
||||
default = {};
|
||||
type = lib.types.submodule {
|
||||
freeformType = apps.jackett.settingsFormat.type;
|
||||
options = {
|
||||
|
@ -66,6 +67,7 @@ let
|
|||
|
||||
appOption = name: c: lib.nameValuePair name (lib.mkOption {
|
||||
description = "Configuration for ${name}";
|
||||
default = {};
|
||||
type = lib.types.submodule {
|
||||
options = {
|
||||
enable = lib.mkEnableOption "selfhostblocks.${name}";
|
||||
|
@ -95,7 +97,8 @@ let
|
|||
};
|
||||
|
||||
oidcEndpoint = lib.mkOption {
|
||||
type = lib.types.str;
|
||||
type = lib.types.nullOr lib.types.str;
|
||||
default = null;
|
||||
description = "OIDC endpoint for SSO";
|
||||
example = "https://authelia.example.com";
|
||||
};
|
||||
|
@ -125,7 +128,7 @@ in
|
|||
enable = true;
|
||||
dataDir = "/var/lib/radarr";
|
||||
};
|
||||
users.users.radarr = {
|
||||
users.users.radarr = lib.mkIf cfg.radarr.enable {
|
||||
extraGroups = [ "media" ];
|
||||
};
|
||||
|
||||
|
@ -134,7 +137,7 @@ in
|
|||
enable = true;
|
||||
dataDir = "/var/lib/sonarr";
|
||||
};
|
||||
users.users.sonarr = {
|
||||
users.users.sonarr = lib.mkIf cfg.sonarr.enable {
|
||||
extraGroups = [ "media" ];
|
||||
};
|
||||
|
||||
|
@ -142,13 +145,16 @@ in
|
|||
enable = true;
|
||||
listenPort = cfg.bazarr.port;
|
||||
};
|
||||
users.users.bazarr = lib.mkIf cfg.bazarr.enable {
|
||||
extraGroups = [ "media" ];
|
||||
};
|
||||
|
||||
# Listens on port 8787
|
||||
services.readarr = lib.mkIf cfg.readarr.enable {
|
||||
enable = true;
|
||||
dataDir = "/var/lib/readarr";
|
||||
};
|
||||
users.users.readarr = {
|
||||
users.users.readarr = lib.mkIf cfg.readarr.enable {
|
||||
extraGroups = [ "media" ];
|
||||
};
|
||||
|
||||
|
@ -157,7 +163,7 @@ in
|
|||
enable = true;
|
||||
dataDir = "/var/lib/lidarr";
|
||||
};
|
||||
users.users.lidarr = {
|
||||
users.users.lidarr = lib.mkIf cfg.lidarr.enable {
|
||||
extraGroups = [ "media" ];
|
||||
};
|
||||
|
||||
|
@ -166,12 +172,12 @@ in
|
|||
enable = true;
|
||||
dataDir = "/var/lib/jackett";
|
||||
};
|
||||
shb.arr.jackett.settings = {
|
||||
shb.arr.jackett.settings = lib.mkIf cfg.jackett.enable {
|
||||
Port = config.shb.arr.jackett.port;
|
||||
AllowExternal = "false";
|
||||
UpdateDisabled = "true";
|
||||
};
|
||||
users.users.jackett = {
|
||||
users.users.jackett = lib.mkIf cfg.jackett.enable {
|
||||
extraGroups = [ "media" ];
|
||||
};
|
||||
systemd.services.jackett.preStart =
|
||||
|
@ -184,14 +190,16 @@ in
|
|||
OmdbApiKey = "%OMDBAPIKEY%";
|
||||
};
|
||||
templatedSettings = (removeAttrs s [ "APIKeyFile" "OmdbApiKeyFile" ]) // templatedfileSettings;
|
||||
in
|
||||
template (apps.jackett.settingsFormat.generate "jackett.json" templatedSettings) "${config.services.jackett.dataDir}/ServerConfig.json" (
|
||||
|
||||
t = template (apps.jackett.settingsFormat.generate "jackett.json" templatedSettings) "${config.services.jackett.dataDir}/ServerConfig.json" (
|
||||
lib.optionalAttrs (!(isNull s.APIKeyFile)) {
|
||||
"%APIKEY%" = "$(cat ${s.APIKeyFile})";
|
||||
} // lib.optionalAttrs (!(isNull s.OmdbApiKeyFile)) {
|
||||
"%OMDBAPIKEY%" = "$(cat ${s.OmdbApiKeyFile})";
|
||||
}
|
||||
);
|
||||
in
|
||||
lib.mkIf cfg.jackett.enable t;
|
||||
|
||||
shb.nginx.autheliaProtect =
|
||||
let
|
||||
|
@ -199,7 +207,7 @@ in
|
|||
let
|
||||
c = cfg.${name};
|
||||
in
|
||||
{
|
||||
lib.mkIf (c.oidcEndpoint != null) {
|
||||
inherit (c) subdomain domain oidcEndpoint;
|
||||
upstream = "http://127.0.0.1:${toString c.port}";
|
||||
autheliaRules = [
|
||||
|
@ -235,7 +243,7 @@ in
|
|||
in
|
||||
lib.mkMerge (lib.mapAttrsToList backupConfig apps);
|
||||
}
|
||||
] ++ map (name: {
|
||||
] ++ map (name: lib.mkIf cfg.${name}.enable {
|
||||
systemd.tmpfiles.rules = lib.mkIf (lib.hasAttr "dataDir" config.services.${name}) [
|
||||
"d '${config.services.${name}.dataDir}' 0750 ${config.services.${name}.user} ${config.services.${name}.group} - -"
|
||||
];
|
||||
|
|
52
test/modules/arr.nix
Normal file
52
test/modules/arr.nix
Normal file
|
@ -0,0 +1,52 @@
|
|||
{ pkgs, lib, ... }:
|
||||
let
|
||||
anyOpt = default: lib.mkOption {
|
||||
type = lib.types.anything;
|
||||
inherit default;
|
||||
};
|
||||
|
||||
testConfig = m:
|
||||
let
|
||||
cfg = (lib.evalModules {
|
||||
specialArgs = { inherit pkgs; };
|
||||
modules = [
|
||||
{
|
||||
options = {
|
||||
systemd = anyOpt {};
|
||||
shb.backup = anyOpt {};
|
||||
shb.nginx = anyOpt {};
|
||||
users = anyOpt {};
|
||||
services.bazarr = anyOpt {};
|
||||
services.jackett = anyOpt {};
|
||||
services.lidarr = anyOpt {};
|
||||
services.radarr = anyOpt {};
|
||||
services.readarr = anyOpt {};
|
||||
services.sonarr = anyOpt {};
|
||||
};
|
||||
}
|
||||
../../modules/arr.nix
|
||||
m
|
||||
];
|
||||
}).config;
|
||||
in {
|
||||
inherit (cfg) systemd services users;
|
||||
shb = { inherit (cfg.shb) backup nginx; };
|
||||
};
|
||||
in
|
||||
{
|
||||
testArrNoOptions = {
|
||||
expected = {
|
||||
systemd.services.jackett = {};
|
||||
shb.backup = {};
|
||||
shb.nginx.autheliaProtect = [];
|
||||
users.users = {};
|
||||
services.bazarr = {};
|
||||
services.jackett = {};
|
||||
services.lidarr = {};
|
||||
services.radarr = {};
|
||||
services.readarr = {};
|
||||
services.sonarr = {};
|
||||
};
|
||||
expr = testConfig {};
|
||||
};
|
||||
}
|
35
test/modules/davfs.nix
Normal file
35
test/modules/davfs.nix
Normal file
|
@ -0,0 +1,35 @@
|
|||
{ pkgs, lib, ... }:
|
||||
let
|
||||
anyOpt = default: lib.mkOption {
|
||||
type = lib.types.anything;
|
||||
inherit default;
|
||||
};
|
||||
|
||||
testConfig = m:
|
||||
let
|
||||
cfg = (lib.evalModules {
|
||||
specialArgs = { inherit pkgs; };
|
||||
modules = [
|
||||
{
|
||||
options = {
|
||||
systemd = anyOpt {};
|
||||
services = anyOpt {};
|
||||
};
|
||||
}
|
||||
../../modules/davfs.nix
|
||||
m
|
||||
];
|
||||
}).config;
|
||||
in {
|
||||
inherit (cfg) systemd services;
|
||||
};
|
||||
in
|
||||
{
|
||||
testDavfsNoOptions = {
|
||||
expected = {
|
||||
services.davfs2.enable = false;
|
||||
systemd.mounts = [];
|
||||
};
|
||||
expr = testConfig {};
|
||||
};
|
||||
}
|
|
@ -1,4 +1,4 @@
|
|||
{ lib }:
|
||||
{ lib, ... }:
|
||||
let
|
||||
anyOpt = default: lib.mkOption {
|
||||
type = lib.types.anything;
|
||||
|
@ -274,6 +274,7 @@ in
|
|||
port = 1234;
|
||||
authentication = ''
|
||||
#type database DBuser origin-address auth-method
|
||||
local all all peer
|
||||
# ipv4
|
||||
host all all 127.0.0.1/32 trust
|
||||
# ipv6
|
||||
|
|
Loading…
Reference in a new issue