Replaces LICENSE (GPLv3 -> AGPLv3) and prepends `SPDX-License-Identifier: AGPL-3.0-or-later` to every source file across decnet/, decnet_web/, tests/, scripts/, and tools/. Rationale: closes the GPLv3 ASP loophole so any party operating a modified DECNET as a network service must offer their modified source. Personal copyright (Samuel Paschuan) + inbound=outbound contributions make a future unilateral relicense infeasible. - LICENSE: full AGPL-3.0 text (gnu.org/licenses/agpl-3.0.txt) - COPYRIGHT: project copyright notice - tools/add_spdx_headers.py: idempotent header injector (shebang- and PEP 263-aware) Touches 1565 source files (.py, .ts, .tsx, .js, .jsx, .css, .sh). No behavior change; comments only.
65 lines
2.4 KiB
Python
65 lines
2.4 KiB
Python
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
"""Step 6: ``cognitive.command_branch_diversity``."""
|
|
from __future__ import annotations
|
|
|
|
from decnet.profiler.behave_shell import extract_session
|
|
from decnet.profiler.behave_shell._parse import AsciinemaEvent
|
|
|
|
|
|
def _of(observations: list, primitive: str):
|
|
obs = [o for o in observations if o.primitive == primitive]
|
|
assert len(obs) == 1, f"expected exactly one {primitive}, got {len(obs)}"
|
|
return obs[0]
|
|
|
|
|
|
def _commands(first_tokens: list[str]) -> list[AsciinemaEvent]:
|
|
"""One command per token, well-spaced."""
|
|
events: list[AsciinemaEvent] = []
|
|
t = 0.0
|
|
for tok in first_tokens:
|
|
events.append((t, "i", f"{tok} arg\r"))
|
|
t += 1.0
|
|
return events
|
|
|
|
|
|
def test_under_floor_emits_unknown_high_confidence() -> None:
|
|
out = list(extract_session(_commands(["ls", "ps", "id"]), sid="bd-low"))
|
|
obs = _of(out, "cognitive.command_branch_diversity")
|
|
assert obs.value == "unknown"
|
|
assert obs.confidence == 1.0
|
|
|
|
|
|
def test_unique_first_tokens_emit_linear_playbook() -> None:
|
|
# 8 distinct tools — ratio 1.0 → linear_playbook
|
|
tokens = ["uname", "id", "whoami", "pwd", "ls", "ps", "netstat", "ss"]
|
|
out = list(extract_session(_commands(tokens), sid="bd-linear"))
|
|
obs = _of(out, "cognitive.command_branch_diversity")
|
|
assert obs.value == "linear_playbook"
|
|
assert obs.confidence == 0.80
|
|
|
|
|
|
def test_repeated_first_tokens_emit_adaptive_branching() -> None:
|
|
# 8 commands, only 3 distinct — ratio 0.375 < 0.60
|
|
tokens = ["curl", "curl", "curl", "ls", "curl", "ls", "curl", "ps"]
|
|
out = list(extract_session(_commands(tokens), sid="bd-adaptive"))
|
|
obs = _of(out, "cognitive.command_branch_diversity")
|
|
assert obs.value == "adaptive_branching"
|
|
|
|
|
|
def test_just_below_linear_threshold_emits_adaptive() -> None:
|
|
# 7 commands, 4 unique → ratio ≈ 0.57 — below the 0.70 linear floor.
|
|
tokens = ["a", "b", "c", "d", "a", "b", "c"]
|
|
out = list(extract_session(_commands(tokens), sid="bd-just-adaptive"))
|
|
obs = _of(out, "cognitive.command_branch_diversity")
|
|
assert obs.value == "adaptive_branching"
|
|
|
|
|
|
def test_pii_no_command_bodies_in_observation() -> None:
|
|
out = list(extract_session(_commands(
|
|
["secret_arg_payload"] * 6,
|
|
), sid="bd-pii"))
|
|
obs = _of(out, "cognitive.command_branch_diversity")
|
|
# Whatever the verdict, the raw token must not be in the dump
|
|
serialised = obs.model_dump_json()
|
|
assert "secret_arg_payload" not in serialised
|