mirror of
https://github.com/bytedance/deer-flow.git
synced 2026-05-30 12:28:10 +00:00
* Fix custom skill install permissions * Fix skill upload test portability * Keep custom skill writes sandbox readable * Clear sandbox write bits on skill permissions * Limit custom skill write permission updates
64 lines
1.9 KiB
Python
64 lines
1.9 KiB
Python
import stat
|
|
|
|
from deerflow.skills.permissions import make_skill_tree_sandbox_readable, make_skill_written_path_sandbox_readable
|
|
|
|
|
|
def _mode(path):
|
|
return stat.S_IMODE(path.stat().st_mode)
|
|
|
|
|
|
def test_skill_tree_readability_includes_hidden_paths_and_removes_sandbox_write(tmp_path):
|
|
root = tmp_path / "demo-skill"
|
|
hidden_dir = root / ".hidden"
|
|
scripts_dir = root / "scripts"
|
|
hidden_dir.mkdir(parents=True)
|
|
scripts_dir.mkdir()
|
|
env_file = root / ".env"
|
|
hidden_file = hidden_dir / ".secret"
|
|
script_file = scripts_dir / "run.sh"
|
|
env_file.write_text("secret", encoding="utf-8")
|
|
hidden_file.write_text("secret", encoding="utf-8")
|
|
script_file.write_text("#!/bin/sh\n", encoding="utf-8")
|
|
|
|
root.chmod(0o777)
|
|
hidden_dir.chmod(0o777)
|
|
scripts_dir.chmod(0o777)
|
|
env_file.chmod(0o666)
|
|
hidden_file.chmod(0o600)
|
|
script_file.chmod(0o777)
|
|
|
|
make_skill_tree_sandbox_readable(root)
|
|
|
|
assert _mode(root) == 0o755
|
|
assert _mode(hidden_dir) == 0o755
|
|
assert _mode(scripts_dir) == 0o755
|
|
assert _mode(env_file) == 0o644
|
|
assert _mode(hidden_file) == 0o644
|
|
assert _mode(script_file) == 0o755
|
|
|
|
|
|
def test_written_path_readability_is_limited_to_written_path(tmp_path):
|
|
root = tmp_path / "demo-skill"
|
|
ref_dir = root / "references"
|
|
sibling_dir = root / "templates"
|
|
ref_dir.mkdir(parents=True)
|
|
sibling_dir.mkdir()
|
|
target = ref_dir / "guide.md"
|
|
sibling = sibling_dir / "note.md"
|
|
target.write_text("guide", encoding="utf-8")
|
|
sibling.write_text("note", encoding="utf-8")
|
|
|
|
root.chmod(0o700)
|
|
ref_dir.chmod(0o700)
|
|
target.chmod(0o600)
|
|
sibling_dir.chmod(0o700)
|
|
sibling.chmod(0o600)
|
|
|
|
make_skill_written_path_sandbox_readable(root, target)
|
|
|
|
assert _mode(root) == 0o755
|
|
assert _mode(ref_dir) == 0o755
|
|
assert _mode(target) == 0o644
|
|
assert _mode(sibling_dir) == 0o700
|
|
assert _mode(sibling) == 0o600
|