codex: unify skills option and tests
This commit is contained in:
parent
34a9ab0fae
commit
f1b5f20210
7 changed files with 57 additions and 44 deletions
|
|
@ -64,14 +64,23 @@ in
|
|||
};
|
||||
|
||||
skills = lib.mkOption {
|
||||
type = lib.types.attrsOf (lib.types.either lib.types.lines lib.types.path);
|
||||
type = lib.types.either (lib.types.attrsOf (lib.types.either lib.types.lines lib.types.path)) lib.types.path;
|
||||
default = { };
|
||||
description = ''
|
||||
Custom skills for Codex.
|
||||
The attribute name becomes the skill directory name, and the value is either:
|
||||
|
||||
This option can either be:
|
||||
- An attribute set defining skills
|
||||
- A path to a directory containing multiple skill folders
|
||||
|
||||
If an attribute set is used, the attribute name becomes the skill directory name,
|
||||
and the value is either:
|
||||
- Inline content as a string (creates {file}`skills/<name>/SKILL.md`)
|
||||
- A path to a file (creates {file}`skills/<name>/SKILL.md`)
|
||||
- A path to a directory (creates {file}`skills/<name>/` with all files)
|
||||
|
||||
If a path is used, it is expected to contain one folder per skill name, each
|
||||
containing a {file}`SKILL.md`. The directory is symlinked to {file}`skills/`.
|
||||
'';
|
||||
example = lib.literalExpression ''
|
||||
{
|
||||
|
|
@ -98,16 +107,6 @@ in
|
|||
}
|
||||
'';
|
||||
};
|
||||
|
||||
skillsDir = lib.mkOption {
|
||||
type = lib.types.nullOr lib.types.path;
|
||||
default = null;
|
||||
description = ''
|
||||
Path to a directory containing skill folders for Codex.
|
||||
Skill folders from this directory will be symlinked to {file}`skills/`.
|
||||
'';
|
||||
example = lib.literalExpression "./skills";
|
||||
};
|
||||
};
|
||||
|
||||
config =
|
||||
|
|
@ -120,8 +119,8 @@ in
|
|||
mkIf cfg.enable {
|
||||
assertions = [
|
||||
{
|
||||
assertion = !(cfg.skills != { } && cfg.skillsDir != null);
|
||||
message = "Cannot specify both `programs.codex.skills` and `programs.codex.skillsDir`";
|
||||
assertion = !lib.isPath cfg.skills || lib.pathIsDirectory cfg.skills;
|
||||
message = "`programs.codex.skills` must be a directory when set to a path";
|
||||
}
|
||||
];
|
||||
|
||||
|
|
@ -134,8 +133,8 @@ in
|
|||
"${configDir}/AGENTS.md" = lib.mkIf (cfg.custom-instructions != "") {
|
||||
text = cfg.custom-instructions;
|
||||
};
|
||||
"${configDir}/skills" = lib.mkIf (cfg.skillsDir != null) {
|
||||
source = cfg.skillsDir;
|
||||
"${configDir}/skills" = lib.mkIf (lib.isPath cfg.skills) {
|
||||
source = cfg.skills;
|
||||
recursive = true;
|
||||
};
|
||||
}
|
||||
|
|
@ -150,7 +149,7 @@ in
|
|||
lib.nameValuePair "${configDir}/skills/${name}/SKILL.md" (
|
||||
if lib.isPath content then { source = content; } else { text = content; }
|
||||
)
|
||||
) cfg.skills);
|
||||
) (if builtins.isAttrs cfg.skills then cfg.skills else { }));
|
||||
sessionVariables = mkIf useXdgDirectories {
|
||||
CODEX_HOME = "${config.xdg.configHome}/codex";
|
||||
};
|
||||
|
|
|
|||
|
|
@ -8,5 +8,5 @@
|
|||
codex-empty-custom-instructions = ./empty-custom-instructions.nix;
|
||||
codex-skills-inline = ./skills-inline.nix;
|
||||
codex-skills-dir = ./skills-dir.nix;
|
||||
codex-skills-conflict = ./skills-conflict.nix;
|
||||
codex-skills-path-not-directory = ./skills-path-not-directory.nix;
|
||||
}
|
||||
|
|
|
|||
8
tests/modules/programs/codex/skill-file.md
Normal file
8
tests/modules/programs/codex/skill-file.md
Normal file
|
|
@ -0,0 +1,8 @@
|
|||
---
|
||||
name: file-skill
|
||||
description: File skill for tests.
|
||||
---
|
||||
|
||||
# File Skill
|
||||
|
||||
Test fixture content.
|
||||
|
|
@ -1,13 +0,0 @@
|
|||
{
|
||||
programs.codex = {
|
||||
enable = true;
|
||||
skills = {
|
||||
inline-skill = "Test";
|
||||
};
|
||||
skillsDir = ./skills-dir;
|
||||
};
|
||||
|
||||
test.asserts.assertions.expected = [
|
||||
"Cannot specify both `programs.codex.skills` and `programs.codex.skillsDir`"
|
||||
];
|
||||
}
|
||||
|
|
@ -1,11 +1,12 @@
|
|||
{
|
||||
programs.codex = {
|
||||
enable = true;
|
||||
skillsDir = ./skills-dir;
|
||||
skills = ./skills-dir;
|
||||
};
|
||||
|
||||
nmt.script = ''
|
||||
assertFileExists home-files/.codex/skills/skill-one/SKILL.md
|
||||
assertFileRegex home-files/.codex/skills/skill-one/SKILL.md "Skill One"
|
||||
assertFileContent home-files/.codex/skills/skill-one/SKILL.md \
|
||||
${./skills-dir/skill-one/SKILL.md}
|
||||
'';
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,22 +1,30 @@
|
|||
let
|
||||
inlineSkill = ''
|
||||
---
|
||||
name: inline-skill
|
||||
description: Inline skill for tests.
|
||||
---
|
||||
|
||||
# Inline Skill
|
||||
|
||||
Test fixture content.
|
||||
'';
|
||||
in
|
||||
{
|
||||
programs.codex = {
|
||||
enable = true;
|
||||
skills = {
|
||||
inline-skill = ''
|
||||
---
|
||||
name: inline-skill
|
||||
description: Inline skill for tests.
|
||||
---
|
||||
|
||||
# Inline Skill
|
||||
|
||||
Test fixture content.
|
||||
'';
|
||||
inline-skill = inlineSkill;
|
||||
file-skill = ./skill-file.md;
|
||||
};
|
||||
};
|
||||
|
||||
nmt.script = ''
|
||||
assertFileExists home-files/.codex/skills/inline-skill/SKILL.md
|
||||
assertFileRegex home-files/.codex/skills/inline-skill/SKILL.md "Inline Skill"
|
||||
assertFileContent home-files/.codex/skills/inline-skill/SKILL.md \
|
||||
${builtins.toFile "expected-inline-skill.md" inlineSkill}
|
||||
assertFileExists home-files/.codex/skills/file-skill/SKILL.md
|
||||
assertFileContent home-files/.codex/skills/file-skill/SKILL.md \
|
||||
${./skill-file.md}
|
||||
'';
|
||||
}
|
||||
|
|
|
|||
10
tests/modules/programs/codex/skills-path-not-directory.nix
Normal file
10
tests/modules/programs/codex/skills-path-not-directory.nix
Normal file
|
|
@ -0,0 +1,10 @@
|
|||
{
|
||||
programs.codex = {
|
||||
enable = true;
|
||||
skills = ./skill-file.md;
|
||||
};
|
||||
|
||||
test.asserts.assertions.expected = [
|
||||
"`programs.codex.skills` must be a directory when set to a path"
|
||||
];
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue