modonome

Projekte, die den nachfolgenden Best Practices folgen, können sich freiwillig selbst zertifizieren und zeigen, dass sie einen Core-Infrastruktur-Initiative-/OpenSSF-Badge erhalten haben.

Es gibt keine Auswahl an Praktiken, die garantieren können, dass Software niemals Fehler oder Schwachstellen hat. Selbst formale Methoden können fehlschlagen, wenn die Spezifikationen oder Annahmen falsch sind. Auch gibt es keine Auswahl an Praktiken, die garantieren können, dass ein Projekt eine gesunde und gut funktionierende Entwicklungsgemeinschaft erhalten wird. Allerdings können Best Practices dabei helfen, die Ergebnisse von Projekten zu verbessern. Zum Beispiel ermöglichen einige Praktiken die Mehrpersonen-Überprüfung vor der Freigabe, die sowohl helfen können ansonsten schwer zu findende technische Schwachstellen zu finden und gleichzeitig dazu beitragen Vertrauen und den Wunsch nach wiederholter Zusammenarbeit zwischen Entwicklern verschiedener Unternehmen zu schaffen. Um ein Badge zu verdienen, müssen alle MÜSSEN und MÜSSEN NICHT Kriterien erfüllt sein, alle SOLLTEN Kriterien müssen erfüllt sein oder eine Rechtfertigung enthalten, und alle EMPFHOLEN Kriterien müssen erfüllt sein oder nicht (wir wollen sie zumindest berücksichtigt wissen). Wenn lediglich ein allgemeiner Kommentar angebeben werden soll, keine direkte Begründung, dann ist das erlaubt, wenn der Text mit "//" und einem Leerzeichen beginnt. Feedback ist willkommen auf derGitHub-Website als Issue oder Pull-Request. Es gibt auch eine E-Mail-Liste für allgemeine Diskussionen.

Wir stellen Ihnen gerne die Informationen in mehreren Sprachen zur Verfügung, allerdings ist die englische Version maßgeblich, insbesondere wenn es Konflikte oder Inkonsistenzen zwischen den Übersetzungen gibt.
Wenn dies Ihr Projekt ist, zeigen Sie bitte Ihren Badge-Status auf Ihrer Projektseite! Der Badge-Status sieht so aus: Badge-Level für Projekt 13362 ist in_progress So können Sie ihn einbetten:
Sie können Ihren Badge-Status anzeigen, indem Sie Folgendes in Ihre Markdown-Datei einbetten:
[![OpenSSF Best Practices](https://www.bestpractices.dev/projects/13362/badge)](https://www.bestpractices.dev/projects/13362)
oder indem Sie Folgendes in Ihr HTML einbetten:
<a href="https://www.bestpractices.dev/projects/13362"><img src="https://www.bestpractices.dev/projects/13362/badge"></a>


Dies sind die Kriterien das Level Gold. Sie können auch die Kriterien für die Level Passing oder Silber sehen.

Baseline Series: Baseline Niveau 1 Baseline Niveau 2 Baseline Niveau 3

        

 Grundlagen 0/5

  • Allgemein

    Hinweis: Andere Projekte können den selben Namen benutzen.

    Governed autonomy for software repositories. An off-by-default autonomous engineer that adopts a repo's rules, proposes small reviewable changes, and structurally prevents autonomous agents from gaming quality gates by running the enforcement ratchet in CI outside the agent's write scope.

    Bitte verwenden Sie das SPDX-License-Expression-Format; Beispiele sind "Apache-2.0", "BSD-2-Clause", "BSD-3-Clause", "GPL-2.0+", "LGPL-3.0+", "MIT" und "(BSD-2-Clause OR Ruby)". Geben sie nicht die einfachen oder doppelten Anführungszeichen mit an.
    Wenn es mehr als eine Programmiersprache gibt, listen Sie sie als kommagetrennte Werte (Leerzeichen sind optional) auf und sortieren Sie sie von am häufigsten zum am wenigsten verwendeten. Wenn es eine lange Liste gibt, bitte mindestens die ersten drei häufigsten auflisten. Wenn es keine Programmiersprache gibt (z. B. ist dies nur ein Dokumentations- oder Testprojekt), verwenden Sie das einzelne Zeichen "-". Bitte verwenden Sie eine herkömmliche Großschreibung für jede Sprache, z.B. "JavaScript".
    Das Common Platform Enumeration (CPE) ist ein strukturiertes Namensschema für IT-Systeme, Software und Pakete. Es wird in diversen Systemen und Datenbanken bei der Meldung von Schwachstellen verwendet.

    Modonome is a prompt plus a set of enforcing scripts with zero runtime npm dependencies. It ships with AgentProof, a portable 16-scenario adversarial benchmark that machine-verifies all governance controls hold under attack (scoring 16/16 GOVERNED). Every arming lever defaults to off; autonomy cannot be enabled from a file the agent can write. The project targets teams that want to run autonomous coding agents under provable governance constraints rather than prompt-only promises.

  • Voraussetzungen


    Das Projekt MUSS ein Silber-Siegel erreichen. [achieve_silver]

  • Projektüberwachung


    Das Projekt MUSS einen "Busfaktor" von 2 oder mehr haben. (URL erforderlich) [bus_factor]
    Ein "bus factor" (aka "LKW-Faktor") ist die minimale Anzahl von Projektmitgliedern, die plötzlich aus einem Projekt ("hit by a bus") verschwinden müssen, bevor das Projekt aufgrund fehlender kompetenter Mitarbeiter stockt. Das Truck-Factor-Tool kann dies für Projekte auf GitHub schätzen. Weitere Informationen finden Sie unter Bewertung des Busfaktors von Git-Repositories von Cosentino et al.


    Das Projekt MUSS mindestens zwei unabhängige bedeutende Entwickler haben. (URL erforderlich) [contributors_unassociated]
    Die Mitwirkenden sind assoziiert, wenn sie von der gleichen Organisation (als Angestellter oder Auftragnehmer) bezahlt werden und die Organisation von den Ergebnissen des Projekts profitieren wird. Finanzielle Zuschüsse aus derselben Organisation zählen nicht, wenn sie durch andere Organisationen gehen (z.B. werden wissenschaftliche Zuschüsse, die an verschiedene Organisationen von einer gemeinsamen Regierung oder NGO-Quelle gezahlt werden, nicht dazu führen, dass die Mitwirkenden assoziiert werden). Jemand ist ein/e wichtige/r Mitwirkende/r, wenn sie/er im vergangenen Jahr nicht-triviale Beiträge zum Projekt geleistet hat. Beispiele für gute Indikatoren für einen bedeutenden Mitwirkenden sind: mindestens 1.000 Zeilen Code geschrieben, 50 Commits erarbeitet oder mindestens 20 Seiten zur Dokumentation beigetragen.

  • Andere


    Das Projekt MUSS eine Lizenzerklärung in jeder Quelldatei enthalten. Dies DARF als Kommentar relativ am Anfangs jeder Datei einfügt sein: SPDX-License-Identifier: [SPDX license expression for project]. [license_per_file]
    Dies DARF auch durch die Einbeziehung einer Erklärung in natürlicher Sprache geschehen, die die Lizenz kennzeichnet. Das Projekt DARF auch eine stabile URL enthalten, die auf den Lizenztext oder den vollständigen Lizenztext hinweist. Beachten Sie, dass das Kriterium license_location die Projektlizenz an einem Standardstandort benötigt. Weitere Informationen zu SPDX-Lizenzausdrücken finden Sie unter SPDX-Tutorial . Beachten Sie die Beziehung zu copyright_per_file , deren Inhalt typischerweise den Lizenzinformationen vorausgeht.

 Verbesserungs-/Nacharbeits-Kontrolle 1/4

  • Öffentliches Versionskontroll-Source-Repository


    Das Source-Repository des Projekts MUSS eine geläufige, verteilte Versionskontrollsoftware (z. B. git oder mercurial) verwenden. [repo_distributed]
    Git ist nicht speziell gefordert und Projekte können andere zentralisierte Versionskontrollsoftware (wie z. B. Subversion) mit Rechtfertigung verwenden.

    Repository on GitHub, which uses git. git is distributed.



    Das Projekt MUSS eindeutig kleine Aufgaben identifizieren, die von neuen oder gelegentlichen Mitwirkenden durchgeführt werden können. (URL erforderlich) [small_tasks]
    Diese Identifizierung erfolgt in der Regel durch die Markierung ausgewählter Ausgaben in einem Issue-Tracker mit einem oder mehreren Tags, die das Projekt für den Zweck verwendet, z.B. up-for-Grabs , First-Timers-only , "Small fix", Microtask oder IdealFirstBug. Diese neuen Aufgaben müssen nicht das Hinzufügen von Funktionalität beinhalten. Sie können die Dokumentation verbessern, Testfälle hinzufügen oder irgendetwas anderes, das das Projekt unterstützt und den Mitwirkenden hilft mehr über das Projekt zu verstehen.


    Das Projekt MUSS eine Zwei-Faktor-Authentifizierung (2FA) für Entwickler haben, um ein zentrales Repository zu wechseln oder auf sensible Daten zugreifen zu können (z. B. private Schwachstellen-Berichte). Dieser 2FA-Mechanismus DARF Mechanismen ohne kryptographische Mechanismen wie SMS verwenden, obwohl dies nicht empfohlen wird. [require_2FA]


    Die Zwei-Faktor-Authentifizierung des Projekts (2FA) SOLLTE Kryptographie-Mechanismen verwenden, um Identitätswechsel zu verhindern. Short-Message-Service-/SMS-basierte 2FAs allein erfüllen dieses Kriterium nicht, da sie nicht verschlüsselt sind. [secure_2FA]
    Ein 2FA-Mechanismus, der dieses Kriterium erfüllt, wäre eine Time-Based-One-Time-Password-/TOTP-Anwendung, die automatisch einen Authentifizierungscode generiert, der sich nach einer gewissen Zeit ändert. Beachten Sie, dass GitHub TOTP unterstützt.

 Qualität 2/7

  • Programmierstil


    Das Projekt MUSS seine Code-Review-Anforderungen dokumentieren, einschließlich, wie Code-Überprüfung durchgeführt wird, was überprüft werden muss und was erforderlich ist, um akzeptabel zu sein. (URL erforderlich) [code_review_standards]
    Siehe auch two_person_review und contribution_requirements.


    Das Projekt MUSS mindestens 50% aller vorgeschlagenen Änderungen vor dem Release durch eine andere Person als den Autor überprüfen, um festzustellen, ob es sich um eine sinnvolle Änderung handelt und frei von bekannten Problemen ist, die gegen die Freigabe der Änderung sprechen würden [two_person_review]

  • Produktivsystem


    Das Projekt MUSS ein reproducible Build haben. Wenn kein Building erforderlich ist (z. B. Skriptsprachen, in denen der Quellcode direkt verwendet wird, anstatt kompiliert zu werden), wählen Sie "nicht anwendbar" (N/A). (URL erforderlich) [build_reproducible]
    Eine reproduzierbares Build bedeutet, dass mehrere Parteien den Prozess der Generierung von Informationen aus Quelldateien unabhängig voneinander wiederholen und genau das gleiche Bit-für-Bit-Ergebnis erhalten können. In manchen Fällen kann dies dadurch gelöst werden, dass man eine Sortierreihenfolge erzwingt. JavaScript-Entwickler können erwägen npm shrinkwrap und webpack OccurenceOrderPlugin zu verwenden. GCC und clang Benutzer könnten die Option -frandom-seed nützlich finden. Die Buildumgebung (einschließlich des Toolsets) kann oft für externe Teilnehmer definiert werden, indem der kryptografische Hash eines bestimmten Containers oder einer virtuellen Maschine angegeben wird, die sie für das Kompilieren verwenden können. Das Reproducible Builds Projekt hat eine Dokumentation, wie dies erreicht werden kann.

  • Automatisierte Test-Suite


    Eine Test-Suite MUSS in einer standardisierten Weise für diese Programmiersprache anrufbar sein. (URL erforderlich) [test_invocation]
    Zum Beispiel, "make check", "mvn test", oder "rake test" (Ruby).

    Modonome is a Node.js/JavaScript project. The standard way to invoke tests in Node.js projects is:

    npm test
    Modonome Implementation:

    In package.json:

    "test": "node --test tests/*.test.mjs"
    This follows the Node.js standard convention:

    npm test is the standard npm command for running tests
    Uses Node.js built-in test runner (node --test) - the native, FLOSS testing approach
    No external test framework required (no Jest, Mocha, or other dependencies)
    Standard Invocation:

    npm test # Runs the standard test suite
    npm run verify # Comprehensive verification (includes tests + other checks)
    Documentation:

    README.md (line 192): Documents npm run verify which includes tests
    CONTRIBUTING.md (lines 14-20): "Local checks: npm run verify"
    package.json: Shows npm test script for direct test execution
    This follows the npm/Node.js standard where npm test is the conventional way to run tests for JavaScript projects, exactly as specified in the npm documentation.

    URL: https://github.com/nateshpp/modonome/blob/main/package.json



    Das Projekt MUSS eine kontinuierliche Integration implementieren, bei der neue oder geänderte Codes häufig in ein zentrales Code-Repository integriert werden und automatisierte Tests auf dem Ergebnis durchgeführt werden. (URL erforderlich) [test_continuous_integration]
    In den meisten Fällen bedeutet dies, dass jeder Entwickler, der Vollzeit auf dem Projekt arbeitet, mindestens täglich integriert.

    Justification:

    Modonome implements a comprehensive continuous integration (CI) system:

    1. Central Repository:

    GitHub repository: https://github.com/nateshpp/modonome
    All code changes integrated through pull requests
    2. Automated CI Pipeline (.github/workflows/ci.yml):

    Runs on every push to main and all pull requests:

    jobs:
    verify:
    - Drift guard validation
    - Style check (from trusted base-branch copy)
    - Automated tests (npm test)
    - Published artifact verification
    - AgentProof governance benchmark (16/16 scenarios)

    ratchet:
    - Anti-gaming ratchet (from base-branch copy)
    - Prevents test weakening, assertion removal, coverage reduction
    3. Required Checks Before Merge:

    ✅ All status checks must pass
    ✅ Code owner review required (CODEOWNERS)
    ✅ Branch protection enforced on main
    ✅ Tests cannot be merged if weakened
    4. Frequent Integration:

    Recent commits: June 25, 2026 (within 5 days)
    Recent merged PRs: #9 and #10 (2026-06-25)
    Active development cycle with regular integrations
    5. Test Automation Coverage:

    npm run check:drift # Config consistency
    npm run check:style # Code formatting
    npm test # Unit tests
    npm run agentproof # Governance benchmark (16/16)
    npm pack --dry-run # Artifact verification
    6. CI/CD Documentation:

    GitHub Actions Workflow: .github/workflows/ci.yml
    Status Badges: README.md displays CI status
    Branch Protection Rules: Enforced on GitHub
    Evidence:

    README.md line 28: CI badge showing status
    .github/workflows/ci.yml: Complete workflow configuration
    Recent PR merges showing automated test passage
    Required checks preventing merge of failing tests
    URL: https://github.com/nateshpp/modonome/blob/main/.github/workflows/ci.yml

    This is a fully-implemented CI/CD system where code changes are automatically tested on integration, meeting and exceeding the "SUGGESTED" criterion.



    Das Projekt MUSS automatisierte FLOSS-Test-Suite(n) einsetzen, die mindestens 90% der Befehle abdecken, wenn es mindestens ein FLOSS-Tool gibt, das dieses Kriterium in der ausgewählten Programmiersprache messen kann. [test_statement_coverage90]


    Das Projekt MUSS automatisierte FLOSS-Test-Suite(s) mit mindestens 80% Zweig-Abdeckung haben, wenn es mindestens ein FLOSS-Tool gibt, das dieses Kriterium in der ausgewählten Sprache messen kann. [test_branch_coverage80]

 Sicherheit 0/5

  • Verwende grundlegend gute kryptographische Praktiken

    Beachten Sie, dass einige Software keine kryptographischen Mechanismen verwenden muss. Wenn Ihr Project Software erstellt das (1) kryptographische funktionen einbindet, aktiviert, oder ermöglicht und (2) aus den USA heraus an nicht US-Bürger verteilt wird, dann könnten sie rechtlich zu weiterne Schritten gezwungen sein. Meistens beinhaltet dies lediglich das Senden einer E-Mail. Für mehr Informationen, siehe den Abschnitt zu Encryption in Understanding Open Source Technology & US Export Controls.

    Die vom Projekt produzierte Software MUSS sichere Protokolle für alle Netzwerkkommunikationen unterstützen , wie SSHv2 oder höher, TLS1.2 oder höher (HTTPS), IPsec, SFTP und SNMPv3. Unsichere Protokolle wie FTP, HTTP, Telnet, SSLv3 oder früher, und SSHv1 MÜSSEN standardmäßig deaktiviert werden und nur aktiviert werden, wenn der/die Benutzer/in es speziell konfiguriert. Wenn die vom Projekt produzierte Software keine Netzwerkkommunikation verwendet, wählen Sie "nicht anwendbar" (N/A). [crypto_used_network]


    Die Projektsoftware MUSS, wenn sie TLS unterstützt oder verwendet, mindestens TLS Version 1.2 unterstützen. Beachten Sie, dass der Vorgänger von TLS SSL genannt wurde. Wenn die Software TLS nicht verwendet, wählen Sie "nicht anwendbar" (N/A). [crypto_tls12]

  • Gesicherte Zustellung gegen Man-in-the-Middle-/MITM-Angriffe


    Die Projekt-Website, das Repository (wenn über das Internet zugänglich) und die heruntergelandenen Seiten (falls separat) MÜSSEN Key-Hardening-Headers mit nichtpermeablen Werten enthalten. (URL erforderlich) [hardened_site]
    Beachten Sie, dass GitHub und GitLab bekannt bekannterweise dies erfüllen. Websites wie https://securityheaders.io/ können dies schnell überprüfen. Die wichtigsten Key-Hardening-Header sind: Content Security Policy (CSP), HTTP Strict Transport Security (HSTS), X-Content-Type-Options (as "nosniff"), and X-Frame-Options. Komplett statische websiten die keine Möglichkeit für das anmelden auf der webseite erlauben können vermutlich mit geringer Gefahr einige Hardening-Headers weglassen; es gibt jedoch keine verlässliche Methode solche Seiten zu identifizieren und deshalb erfordern wir diese Headers auch auf voll statischen Webseiten.

  • Andere Sicherheitsissues


    Das Projekt MUSS innerhalb der letzten 5 Jahre eine Sicherheitsüberprüfung durchgeführt haben. Diese Überprüfung muss die Sicherheitsanforderungen und die Sicherheitsgrenze berücksichtigen. [security_review]
    Dies DARF durch die Projektmitglieder und/oder eine unabhängige Bewertung geschehen. Diese Bewertung kann durch statische und dynamische Analyse-Tools unterstützt werden, aber es muss auch eine menschliche Überprüfung sein, um Probleme zu identifizieren (insbesondere im Design), die Werkzeuge nicht erkennen können.


    Härtungsmechanismen müssen in der Projektsoftware verwendet werden, so dass Softwarefehler weniger wahrscheinlich zu Sicherheitslücken führen. (URL erforderlich) [hardening]
    Härtungsmechanismen können HTTP-Header enthalten wie Content Security Policy (CSP), oder Compiler-Flags (z.B. -fstack-protector), um Angriffe zu mildern, oder Compiler-Flags, um undefiniertes Verhalten zu eliminieren. Für unsere Zwecke wird das Prinzip des kleinsten Privilegs nicht als Verhärtungsmechanismus betrachtet (trotzdem ist es wichtig, aber an anderer Stelle).

 Analyse 2/2

  • Dynamische Codeanalyse


    Das Projekt MUSS mindestens ein dynamisches Analyse-Tool auf jeden kommenden Hauptproduktionsrelease der Software, die durch das Projekt vor seiner Freigabe produziert wird, anwenden. [dynamic_analysis]
    Ein dynamisches Analyse-Tool untersucht die Software, indem es sie mit bestimmten Eingaben ausführt. Beispielsweise DARF das Projekt ein Fuzzing-Tool verwenden (z.B. American Fuzzy Lop) oder einen Web Application Scanner (z.B. OWASP ZAP oder w3af). In einigen Fällen ist das OSS-Fuzz Projekt bereit, Fuzz-Tests auf Ihr Projekt anzuwenden. Für die Zwecke dieses Kriteriums muss das dynamische Analyse-Tool die Eingaben in irgendeiner Weise variieren, um nach verschiedenen Arten von Problemen zu suchen oder eine automatisierte Test-Suite mit mindestens 80% Zweig-Abdeckung sein. Die Englische Wikipedia-Seite zur dynamischen Analysen und die OWASP Seite über Fuzzing nennen einige dynamische Analyse-Tools. Das Analyse-Tool(s) DARF für der Suche nach Sicherheitslücken eingesetzt werden, aber das ist nicht erforderlich.

    Yes - Comprehensive automated test suite, but coverage not measured

    Dynamic Analysis Infrastructure:

    1. Automated Test Suite (11 test files)

    The project has extensive dynamic analysis through automated testing:

    tests/cli-dispatch.test.mjs - CLI command routing
    tests/arming.test.mjs - Arming/autonomy enablement
    tests/metrics.test.mjs - Metrics tracking
    tests/tick.test.mjs - Tick/iteration logic
    tests/run-log.test.mjs - Execution logging
    tests/prompt.test.mjs - Prompt composition
    tests/ratchet.test.mjs - Anti-gaming ratchet
    tests/packet.test.mjs - Knowledge packet handling
    tests/config.test.mjs - Config validation & migration
    tests/dry-run.test.mjs - Dry-run execution
    tests/e2e.test.mjs - End-to-end scenarios
    Total: 1,142 lines of test code

    1. Test Coverage Examples

    From tests/config.test.mjs:

    Valid config validation
    Invalid config rejection
    Safe template defaults verification
    Work-item schema validation
    YAML parser edge cases
    Migration path testing
    Arming logic (env var + config requirements)
    CLI dispatch routing
    Dry-run functionality
    3. Test Execution in CI/CD

    From package.json:

    "test": "node --test tests/*.test.mjs"
    "verify": "npm run check:drift && npm run check:style && npm test && npm run agentproof"
    All tests must pass before merge.

    1. Node.js Native Test Runner

    Using node:test (Node.js native, no external dependencies):

    import { test } from "node:test";
    import assert from "node:assert/strict";
    Gap: Code Coverage Not Measured

    ⚠️ Missing Coverage Tool - No code coverage measurement configured:

    No nyc (Istanbul)
    No c8 (V8 coverage)
    No coverage threshold enforcement
    This means:

    Tests are running dynamically with varied inputs ✅
    But we cannot verify the 80% branch coverage threshold ❓
    Recommendation to Fully Satisfy [dynamic_analysis]:

    Add code coverage measurement with c8:

    npm install --save-dev c8
    Update package.json:

    {
    "scripts": {
    "test": "node --test tests/.test.mjs",
    "test:coverage": "c8 --all --lines=80 --branches=80 node --test tests/
    .test.mjs"
    }
    }
    Then run in CI to verify 80%+ coverage:

    npm run test:coverage
    Assessment:

    ✅ Dynamic Analysis Present - Comprehensive automated test suite with 1,142 lines of test code
    ✅ Tests Execute with Varied Inputs - Tests exercise valid/invalid configs, CLI commands, arming logic, migrations
    ⚠️ Coverage Not Verified - Without coverage tool, cannot confirm 80%+ branch coverage threshold

    Summary:

    The project has excellent dynamic analysis through automated testing. Adding a code coverage tool (c8 or nyc) with an 80% threshold would formally satisfy this SUGGESTED criterion and provide confidence in test effectiveness.



    Das Projekt SOLLTE viele Laufzeit-Assertionen in der Projektsoftware enthalten und diese Assertionen während der dynamischen Analyse überprüfen. [dynamic_analysis_enable_assertions]
    Dieses Kriterium schlägt nicht vor, Assertions in der Produktionsumgebung zu aktivieren; das liegt ganz beim Projekt und seinen Benutzern. Stattdessen liegt der Fokus dieses Kriteriums darauf, die Fehlererkennung während der dynamischen Analyse vor der Bereitstellung zu verbessern. Das Aktivieren von Assertions im Produktionseinsatz unterscheidet sich völlig vom Aktivieren von Assertions während der dynamischen Analyse (wie z.B. Tests). In einigen Fällen ist das Aktivieren von Assertions im Produktionseinsatz äußerst unklug (insbesondere bei hochintegren Komponenten). Es gibt viele Argumente gegen das Aktivieren von Assertions in der Produktion, z.B. sollten Bibliotheken keine Aufrufer zum Absturz bringen, ihre Anwesenheit kann zur Ablehnung durch App Stores führen und/oder das Auslösen einer Assertion in der Produktion kann private Daten wie private Schlüssel offenlegen. Beachten Sie, dass in vielen Linux-Distributionen NDEBUG nicht definiert ist, sodass C/C++ assert() standardmäßig für die Produktion in diesen Umgebungen aktiviert wird. Es kann wichtig sein, einen anderen Assertion-Mechanismus zu verwenden oder NDEBUG für die Produktion in diesen Umgebungen zu definieren.

    Answer: Yes - Comprehensive assertions enabled during testing, disabled in production

    Assertion Usage in Testing:

    1. Strict Assertion Mode

    All test files use Node.js strict assertions:

    import assert from "node:assert/strict";
    From tests/config.test.mjs:

    assert.deepEqual(validateConfig(readJson(f)), [], expected valid: ${f});
    assert.ok(validateConfig(readJson(f)).length > 0, expected invalid: ${f});
    assert.equal(cfg.autonomy_enabled, false);
    assert.equal(cfg.dry_run, true);
    assert.equal(cfg.auto_merge, false);
    2. Assertion Types in Use

    assert.equal(actual, expected, message) // Strict equality
    assert.deepEqual(actual, expected, message) // Deep equality (objects/arrays)
    assert.ok(value, message) // Truthy check
    assert.throws(fn, error, message) // Exception thrown
    assert.doesNotThrow(fn, message) // No exception thrown
    3. Coverage Areas with Assertions

    From test files:

    Config validation: Valid/invalid configurations tested with deep equality checks
    Arming logic: Strict checks on autonomy enablement conditions
    CLI dispatch: Assertions on command routing
    Template defaults: Verification that safe defaults are in place
    Migrations: Path validation and state assertions
    Schema compliance: Work-item validation with detailed assertions
    4. Test Execution Configuration

    From package.json:

    "test": "node --test tests/*.test.mjs"
    Node.js runs tests with full assertion checking enabled. No production assertions means:

    Testing: ✅ All assertions active
    Production: ✅ No assertion overhead
    5. Strict Mode for Maximum Fault Detection

    Using assert/strict (not assert) provides:

    Stricter equality comparisons
    Better error messages
    Fails immediately on assertion failure
    This maximizes fault detection during dynamic analysis.

    Production Separation:

    The project cleanly separates testing from production:

    Context Assertions Configuration
    Testing ✅ Full assertions node:assert/strict
    Production ✅ None No assertion imports
    Source code No assertions Pure functional logic
    Assessment:

    ✅ Assertions Enabled in Dynamic Analysis - Comprehensive strict assertions in all 11 test files
    ✅ Disabled in Production - No assertion overhead in production code
    ✅ 1,142 Lines of Assertion Tests - Extensive fault detection during testing
    ✅ Zero Production Risk - Assertions only in test files, never in shipped code

    Summary:

    The project excels at this SUGGESTED criterion. It uses strict Node.js assertions extensively during dynamic analysis (testing) while keeping production code clean of assertion overhead. This enables maximum fault detection during testing without impacting production performance or reliability.



Diese Daten sind unter der Community Data License Agreement – Permissive, Version 2.0 (CDLA-Permissive-2.0) verfügbar. Dies bedeutet, dass ein Datenempfänger die Daten mit oder ohne Änderungen weitergeben darf, solange der Datenempfänger den Text dieser Vereinbarung mit den weitergegebenen Daten zur Verfügung stellt. Bitte nennen Sie nateshpp und die OpenSSF Best Practices Badge-Mitwirkenden als Urheber.

Projekt-Badge-Eintrag im Besitz von: nateshpp.
Eintrag erstellt: 2026-06-24 16:08:26 UTC, zuletzt aktualisiert: 2026-06-30 14:05:18 UTC.