mirror of
https://github.com/elicpeter/nyx.git
synced 2026-06-24 20:28:06 +02:00
Phase 1 (#33)
* chore: Exclude CLAUDE.md from Cargo.toml * feat: add callgraph module and integrate into main analysis flow * feat: enhance CLI with new severity filtering and analysis modes * feat: update CHANGELOG with recent enhancements and fixes to severity filtering and output handling * feat: implement state-model dataflow analysis for resource lifecycle and auth state * feat: enhance diagnostic output formatting and add evidence structure * feat: implement attack surface ranking for diagnostics with scoring and sorting * feat: add comprehensive documentation for installation, usage, and rules reference * feat: add multiple language support for command execution and evaluation endpoints * feat: implement inline suppression for findings using `nyx:ignore` comments * feat: add confidence levels to AST patterns and update output structure * feat: implement low-noise prioritization system with category filtering, rollup grouping, and configurable budgets * feat: bump version to 0.4.0 and update changelog with new features and improvements * feat: add dead code allowances to various functions in mod.rs and real_world_tests.rs
This commit is contained in:
parent
19b578c5c4
commit
1bbe4b1cfb
456 changed files with 25628 additions and 1228 deletions
|
|
@ -80,8 +80,8 @@ fn taint_only_mode_excludes_ast() {
|
|||
let diags = scan_fixture_dir(&dir, AnalysisMode::Taint);
|
||||
|
||||
// Taint mode should not produce AST-only pattern findings
|
||||
assert_no_findings(&diags, "unwrap_call");
|
||||
assert_no_findings(&diags, "expect_call");
|
||||
assert_no_findings(&diags, "rs.quality.unwrap");
|
||||
assert_no_findings(&diags, "rs.quality.expect");
|
||||
}
|
||||
|
||||
#[test]
|
||||
|
|
@ -160,13 +160,9 @@ fn binary_json_output() {
|
|||
);
|
||||
|
||||
let stdout = String::from_utf8_lossy(&cmd.stdout);
|
||||
// Find the JSON array line in stdout (config notes and "Finished" surround it)
|
||||
// Find the JSON array in stdout (config notes and "Finished" surround it)
|
||||
let json_start = stdout.find('[').expect("Expected JSON array in stdout");
|
||||
let json_end = stdout[json_start..]
|
||||
.find(']')
|
||||
.expect("Expected closing bracket in JSON")
|
||||
+ json_start
|
||||
+ 1;
|
||||
let json_end = stdout.rfind(']').expect("Expected closing bracket in JSON") + 1;
|
||||
let json_str = &stdout[json_start..json_end];
|
||||
let parsed: Vec<serde_json::Value> =
|
||||
serde_json::from_str(json_str).expect("stdout should contain valid JSON array");
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue