Compare commits

..

2 Commits

Author SHA1 Message Date
a45ec10b7a fix(#211): Fix two SyntaxErrors in perf_bottleneck_finder.py
Some checks failed
Test / pytest (pull_request) Failing after 23s
- Line 116: Fixed quote escaping in open() regex pattern
- Lines 509-510: Fixed split string literal in return statement
- Verified: python3 -m py_compile succeeds
2026-04-21 11:23:59 +00:00
f9f47cd12f fix(#211): Fix SyntaxError in perf_bottleneck_finder.py regex pattern
- Line 116: Fixed broken quote escaping in open() regex pattern
- Used \\" inside raw string to allow matching both quote types
- Verified: python3 -m py_compile succeeds
2026-04-21 11:17:00 +00:00
2 changed files with 5 additions and 5 deletions

View File

@@ -149,8 +149,8 @@ def to_dot(graph: dict) -> str:
"""Generate DOT format output."""
lines = ["digraph dependencies {"]
lines.append(" rankdir=LR;")
lines.append(' node [shape=box, style=filled, fillcolor="#1a1a2e", fontcolor="#e6edf3"];')
lines.append(' edge [color="#4a4a6a"];')
lines.append(" node [shape=box, style=filled, fillcolor="#1a1a2e", fontcolor="#e6edf3"];")
lines.append(" edge [color="#4a4a6a"];")
lines.append("")
for repo, data in sorted(graph.items()):

View File

@@ -113,7 +113,7 @@ def find_slow_tests_by_scan(repo_path: str) -> List[Bottleneck]:
(r"time\.sleep\((\d+(?:\.\d+)?)\)", "Contains time.sleep() — consider using mock or async wait"),
(r"subprocess\.run\(.*timeout=(\d+)", "Subprocess with timeout — may block test"),
(r"requests\.(get|post|put|delete)\(", "Real HTTP call — mock with responses or httpretty"),
(r"open\([^)]*['"]w['"]", "File I/O in test use tmp_path fixture"),
(r"open\\([^)]*['\"]w['\"]", "File I/O in test - use tmp_path fixture"),
]
for root, dirs, files in os.walk(repo_path):
@@ -506,8 +506,8 @@ def format_markdown(report: PerfReport) -> str:
lines.append(f"- {icon} {b.name}{loc} — ~{b.duration_s:.1f}s — {b.recommendation}")
lines.append(f"")
return "
".join(lines)
return "\n".join(lines)
# ── Main ───────────────────────────────────────────────────────────