memorylink 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.cursorrules +0 -0
- package/.github/workflows/buddy-check.yml +105 -0
- package/.github/workflows/memorylink-preflight.yml +63 -0
- package/.github/workflows/release-on-tag.yml +58 -0
- package/.github/workflows/stress-tests.yml +79 -0
- package/.memorylinkignore +24 -0
- package/5000_SCENARIOS_TEST_RESULTS.md +174 -0
- package/ADVANCED_SCENARIOS_TEST_RESULTS.md +377 -0
- package/AGGRESSIVE_RANDOM_TEST_RESULTS.md +134 -0
- package/AI_CONSENSUS_ANALYSIS.md +138 -0
- package/AI_CONSENSUS_ANALYSIS_FINAL.md +345 -0
- package/AI_CONSENSUS_ANALYSIS_v2.md +188 -0
- package/AI_CONSENSUS_ANALYSIS_v3.md +246 -0
- package/AI_CONSENSUS_ANALYSIS_v4.md +309 -0
- package/AI_CONSENSUS_ANALYSIS_v5.md +311 -0
- package/AI_CONSENSUS_ANALYSIS_v6.md +432 -0
- package/AI_PANEL_CLARIFICATION_REQUEST.md +37 -0
- package/AI_RESPONSES_BLACKBOX.md +338 -0
- package/AI_RESPONSES_CHATGPT.md +379 -0
- package/AI_RESPONSES_CLAUDE.md +464 -0
- package/AI_RESPONSES_CONSOLIDATED.md +560 -0
- package/AI_RESPONSES_DEEPSEEK.md +341 -0
- package/AI_RESPONSES_GEMINI.md +262 -0
- package/AI_RESPONSES_GROK.md +335 -0
- package/AI_RESPONSES_MANUS.md +246 -0
- package/AI_RESPONSES_PERPLEXITY.md +295 -0
- package/AI_RESPONSES_QWEN.md +335 -0
- package/AI_REVIEW_REQUEST.md +333 -0
- package/AI_STRATEGIC_CONSENSUS_COMPARISON.md +507 -0
- package/AI_VALIDATION_AND_GAP_ANALYSIS.md +410 -0
- package/ALL_10_AI_RESPONSES_FINAL.md +435 -0
- package/ALL_3_AI_RESPONSES_FINAL.md +305 -0
- package/ALL_4_AI_RESPONSES_FINAL.md +335 -0
- package/ALL_5_AI_RESPONSES_FINAL.md +349 -0
- package/ALL_6_AI_RESPONSES_FINAL.md +354 -0
- package/ALL_7_AI_RESPONSES_FINAL.md +369 -0
- package/ALL_8_AI_RESPONSES_FINAL.md +381 -0
- package/ALL_9_AI_RESPONSES_FINAL.md +398 -0
- package/ALL_AI_RESPONSES_TRACKER.md +152 -0
- package/ALL_AI_RESPONSES_VALIDATED.md +261 -0
- package/ALL_FEATURES_COMPLETE.md +198 -0
- package/BREAK_IT_TEST_RESULTS.md +273 -0
- package/BUDDY_CHECK_STRESS_TEST_PLAN.md +1089 -0
- package/CHANGELOG.md +135 -0
- package/CHATGPT_GAP_ANALYSIS.md +286 -0
- package/CHATGPT_V2_ANALYSIS.md +109 -0
- package/CHECK_MISSING_FEATURES.md +192 -0
- package/CI_CD_INTEGRATION.md +421 -0
- package/COMPETITIVE_LAUNCH_STRATEGY.md +257 -0
- package/COMPLETE_COMPETITIVE_ANALYSIS_ALL_AIS.md +339 -0
- package/COMPLETE_DEVELOPMENT_PLAN_ALL_AIS.md +622 -0
- package/COMPREHENSIVE_FEATURE_ANALYSIS_100_PERCENT.md +423 -0
- package/COMPREHENSIVE_TEST_SUMMARY.md +314 -0
- package/CONTINUOUS_TESTING_COMPLETE.md +268 -0
- package/CONTINUOUS_TESTING_GUIDE.md +328 -0
- package/CONTINUOUS_TEST_FINAL_RESULTS.md +148 -0
- package/CONTINUOUS_TEST_INSTRUCTIONS.md +173 -0
- package/CONTINUOUS_TEST_RESULTS.md +194 -0
- package/CONTINUOUS_TEST_STATUS.md +68 -0
- package/CURSOR_AI_BUDDY_CHECK_GUIDE.md +439 -0
- package/CURSOR_AI_INTEGRATION_GUIDE.md +775 -0
- package/CURSOR_AI_V1.4_NEXT_STEPS.md +314 -0
- package/CURSOR_BREAK_IT_TEST.md +389 -0
- package/CURSOR_DOCUMENTATION_RULES.md +259 -0
- package/CURSOR_HOSTILE_TEST_DOCUMENT.md +343 -0
- package/CURSOR_PROMPTS_FOR_TESTING.md +252 -0
- package/DEPLOYMENT_GUIDE.md +493 -0
- package/DEVELOPMENT_AND_OVERNIGHT_TESTING.md +304 -0
- package/DEVELOPMENT_PROGRESS.md +185 -0
- package/DOCS_CLEANUP_SUMMARY.md +192 -0
- package/DOC_CONFIDENTIALITY_RULES.md +259 -0
- package/E2E_TEST_REPORT_v1.3.0.md +196 -0
- package/E2E_TEST_RESULTS.md +250 -0
- package/E2E_TEST_SCENARIOS.md +357 -0
- package/END_TO_END_TEST_REPORT.md +217 -0
- package/ENHANCEMENT_RECOMMENDATIONS.md +368 -0
- package/EPIPE_FIX_SUMMARY.md +177 -0
- package/FEEDBACK_TEMPLATE.md +173 -0
- package/FINAL_100_PERCENT_CONFIRMATION.md +319 -0
- package/FINAL_8_AI_CONSENSUS_SUMMARY.md +355 -0
- package/FINAL_CONFIRMATION.md +143 -0
- package/FINAL_E2E_TEST_REPORT.md +248 -0
- package/FINAL_E2E_TEST_RESULTS.md +212 -0
- package/FINAL_LAUNCH_CLARIFICATION_SUMMARY.md +101 -0
- package/FINAL_LAUNCH_PLAN_BASED_ON_AI_CONSENSUS.md +410 -0
- package/FINAL_LAUNCH_SUMMARY.md +176 -0
- package/FINAL_PRODUCT_TEST.md +316 -0
- package/FINAL_PROJECT_STATUS.md +407 -0
- package/FINAL_STATUS_REPORT.md +244 -0
- package/FINAL_STRATEGIC_PLAN_9_AIS.md +576 -0
- package/FINAL_TEST_EXECUTION_REPORT.md +252 -0
- package/FINAL_VALIDATION_DOCUMENT.md +238 -0
- package/FINAL_VALIDATION_SUMMARY.md +230 -0
- package/FIX_SPECIAL_CHARS.sh +13 -0
- package/FRESH_SCENARIOS_TEST_RESULTS.md +358 -0
- package/GAP_EVALUATION_TEMPLATE.md +146 -0
- package/GITHUB_SETUP_GUIDE.md +193 -0
- package/HOSTILE_TEST_RESULTS.md +221 -0
- package/HOW_MEMORYLINK_HELPS_AI.md +401 -0
- package/IMPLEMENTATION_PLANS_DETAILED.md +516 -0
- package/LAUNCH_CHECKLIST.md +247 -0
- package/LAUNCH_DOCS_FRAMEWORK.md +378 -0
- package/LAUNCH_READINESS.md +148 -0
- package/LAUNCH_SEQUENCE.md +137 -0
- package/LICENSE +67 -0
- package/MARKET_ANALYSIS_AND_STRATEGY.md +280 -0
- package/MASTER_AI_VERIFICATION_DOCUMENT.md +1085 -0
- package/MASTER_VALIDATION_DOCUMENT.md +818 -0
- package/MINORITY_OPINION_ANALYSIS.md +464 -0
- package/NEW_RANDOM_TEST_RESULTS.md +127 -0
- package/NEW_SCENARIOS_TEST_RESULTS.md +272 -0
- package/NEXT_ACTIONS_COMPLETE.md +137 -0
- package/NEXT_PLAN_BASED_ON_AI_ANALYSES.md +413 -0
- package/NEXT_PLAN_BASED_ON_ALL_AI_RESPONSES.md +558 -0
- package/NEXT_STEPS.md +120 -0
- package/NEXT_STEPS_ACTION_PLAN.md +369 -0
- package/NPM_2FA_FIX.md +113 -0
- package/NPM_PUBLISH_TROUBLESHOOTING.md +230 -0
- package/PERPLEXITY_AI_VALIDATION_REQUEST.md +318 -0
- package/PERPLEXITY_AI_VALIDATION_RESPONSE.md +172 -0
- package/PERPLEXITY_BREAK_IT_VALIDATION.md +262 -0
- package/PERPLEXITY_DOCS_VALIDATION.md +237 -0
- package/PERPLEXITY_FEEDBACK_ACTION_PLAN.md +271 -0
- package/PERPLEXITY_FINAL_E2E_VALIDATION.md +210 -0
- package/PERPLEXITY_FINAL_SUMMARY.md +211 -0
- package/PERPLEXITY_PHASE2_VALIDATION.md +270 -0
- package/PERPLEXITY_PHASE2_VALIDATION_RESPONSE.md +136 -0
- package/PERPLEXITY_PRIORITY2_VALIDATION.md +321 -0
- package/PERPLEXITY_TELEMETRY_EXPLANATION.md +174 -0
- package/PERPLEXITY_TELEMETRY_VALIDATION.md +118 -0
- package/PERPLEXITY_TELEMETRY_VALIDATION_RESPONSE.md +154 -0
- package/PERPLEXITY_USER_GUIDE_VALIDATION.md +236 -0
- package/PERPLEXITY_VALIDATION_REQUEST.md +427 -0
- package/PERPLEXITY_VALIDATION_REQUEST_v1.5.1.md +190 -0
- package/PHASE_2_COMPLETE.md +149 -0
- package/PRE_LAUNCH_SECURITY_AUDIT.md +155 -0
- package/PRE_LAUNCH_TEST_CYCLE.md +326 -0
- package/PRE_LAUNCH_TEST_RESULTS.md +148 -0
- package/PROJECT_STRUCTURE_PLAN.md +104 -0
- package/PUBLIC_DOCS.md +90 -0
- package/PUBLISH_CHECKLIST.md +134 -0
- package/PUSH_INSTRUCTIONS.md +120 -0
- package/QUICK_START_TEST_CYCLE.md +76 -0
- package/README.md +557 -0
- package/README_TEST_INSTRUCTIONS.md +65 -0
- package/README_v1.5.1.md +137 -0
- package/REALISTIC_ASSESSMENT.md +186 -0
- package/REAL_WORLD_VALIDATION_COMPLETE.md +98 -0
- package/RED_TEAM_TESTING_GUIDE.md +302 -0
- package/RELEASE_NOTES_v1.0.0.md +125 -0
- package/RELEASE_NOTES_v1.5.1.md +105 -0
- package/REQUEST_COUNTERS.md +22 -0
- package/ROADMAP_v1.6.md +335 -0
- package/ROUND3_RANDOM_TEST_RESULTS.md +135 -0
- package/SECURITY_MODEL.md +577 -0
- package/SESSION_SUMMARY_CURRENT_STATE.md +206 -0
- package/SESSION_SUMMARY_REVIEW.md +203 -0
- package/SINGLE_RUN_ALL_SCENARIOS_TEST.sh +129 -0
- package/STRATEGIC_QUESTIONS_FOR_AI_VALIDATION.md +277 -0
- package/STRESS_TEST_CHECK_RESULTS.md +154 -0
- package/STRESS_TEST_EXECUTION_GUIDE.md +284 -0
- package/STRESS_TEST_IMPLEMENTATION_SUMMARY.md +221 -0
- package/TELEMETRY.md +370 -0
- package/TELEMETRY_COMPLETE_SUMMARY.md +231 -0
- package/TELEMETRY_CONTROL_POLICY.md +135 -0
- package/TELEMETRY_DESIGN_SUMMARY.md +210 -0
- package/TELEMETRY_FINAL_STATUS.md +178 -0
- package/TELEMETRY_NEXT_STEPS.md +258 -0
- package/TELEMETRY_TESTING_NOTES.md +217 -0
- package/TELEMETRY_WORK_COMPLETE.md +237 -0
- package/TEST_PLAN_v1.0.1.md +194 -0
- package/TEST_RESULTS_SUMMARY.md +128 -0
- package/TREE_SITTER_EXPLANATION.md +303 -0
- package/TROUBLESHOOTING.md +62 -0
- package/ULTIMATE_SCENARIOS_TEST_RESULTS.md +366 -0
- package/USER_FEEDBACK_TEMPLATE.md +104 -0
- package/USER_GUIDE.md +809 -0
- package/V1.1_DEVELOPMENT_COMPLETE.md +299 -0
- package/V1.1_SCENARIOS_ADDED.md +161 -0
- package/V1.2_CODE_STRUCTURE_IMPLEMENTATION.md +243 -0
- package/V1.3_COMPETITIVE_LAUNCH_COMPLETE.md +253 -0
- package/V1.3_COMPETITIVE_LAUNCH_IMPLEMENTATION_PLAN.md +385 -0
- package/V1.3_TEAM_PATTERNS_IMPLEMENTATION.md +183 -0
- package/V1.4_BUILD_PLAN_IMPLEMENTATION.md +698 -0
- package/V1.4_COMPLETE_SUMMARY_FOR_AI_REVIEW.md +516 -0
- package/V1.4_COMPLETE_VALIDATION_DOCUMENT.md +601 -0
- package/V1.4_DEVELOPMENT_PROGRESS.md +117 -0
- package/V1.4_FINAL_STATUS.md +147 -0
- package/V1.4_INTEGRATION_COMPLETE.md +207 -0
- package/V1.4_INTEGRATION_TEST_RESULTS.md +181 -0
- package/V1.4_OBSERVABILITY_AND_OVERRIDE_COMPLETE.md +180 -0
- package/V1.4_PHASE_3_COMPLETE.md +135 -0
- package/V1.4_RUNTIME_TESTING_GUIDE.md +364 -0
- package/V1.4_VERIFICATION_REPORT.md +199 -0
- package/V1.5.1_COMPLETE_SUMMARY.md +234 -0
- package/V1.5.1_RELEASE_NOTES.md +206 -0
- package/V1.5.1_RELEASE_READY.md +198 -0
- package/V1.5_COMPLETE_SUMMARY.md +264 -0
- package/V1.5_COMPLETE_VERIFICATION.md +183 -0
- package/V1.5_DESIGN_NOTES.md +272 -0
- package/V1.5_FINAL_STATUS.md +224 -0
- package/V1.5_IMPLEMENTATION_SUMMARY.md +113 -0
- package/V1.5_IMPROVEMENTS_COMPLETE.md +205 -0
- package/V1.5_PHASE1_COMPLETE.md +183 -0
- package/V1.5_PHASE1_PROGRESS.md +102 -0
- package/V1.5_PHASE2_COMPLETE.md +133 -0
- package/V1.5_PHASE2_PLAN.md +185 -0
- package/V1.5_PRIORITIZATION.md +313 -0
- package/V1.5_PRIORITY2_COMPLETE.md +150 -0
- package/V1.5_TESTING_COMPLETE.md +69 -0
- package/V1.5_TEST_RESULTS.md +178 -0
- package/V1.5_VALIDATION_RESULTS.md +209 -0
- package/V1.6_GAP_TRACKING.md +118 -0
- package/VALIDATION_SUMMARY_FOR_PERPLEXITY.md +83 -0
- package/VERIFICATION_REPORT.md +220 -0
- package/VERSION_UPDATE_VERIFICATION.md +76 -0
- package/config/tsconfig.json +21 -0
- package/dist/cli.d.ts +9 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +1114 -0
- package/dist/cli.js.map +1 -0
- package/dist/commands/archive.d.ts +20 -0
- package/dist/commands/archive.d.ts.map +1 -0
- package/dist/commands/archive.js +231 -0
- package/dist/commands/archive.js.map +1 -0
- package/dist/commands/auto-context.d.ts +22 -0
- package/dist/commands/auto-context.d.ts.map +1 -0
- package/dist/commands/auto-context.js +172 -0
- package/dist/commands/auto-context.js.map +1 -0
- package/dist/commands/auto-log.d.ts +30 -0
- package/dist/commands/auto-log.d.ts.map +1 -0
- package/dist/commands/auto-log.js +500 -0
- package/dist/commands/auto-log.js.map +1 -0
- package/dist/commands/change.d.ts +13 -0
- package/dist/commands/change.d.ts.map +1 -0
- package/dist/commands/change.js +254 -0
- package/dist/commands/change.js.map +1 -0
- package/dist/commands/checkpoint.d.ts +26 -0
- package/dist/commands/checkpoint.d.ts.map +1 -0
- package/dist/commands/checkpoint.js +326 -0
- package/dist/commands/checkpoint.js.map +1 -0
- package/dist/commands/configure.d.ts +21 -0
- package/dist/commands/configure.d.ts.map +1 -0
- package/dist/commands/configure.js +283 -0
- package/dist/commands/configure.js.map +1 -0
- package/dist/commands/consolidate.d.ts +19 -0
- package/dist/commands/consolidate.d.ts.map +1 -0
- package/dist/commands/consolidate.js +236 -0
- package/dist/commands/consolidate.js.map +1 -0
- package/dist/commands/context.d.ts +10 -0
- package/dist/commands/context.d.ts.map +1 -0
- package/dist/commands/context.js +571 -0
- package/dist/commands/context.js.map +1 -0
- package/dist/commands/detect.d.ts +13 -0
- package/dist/commands/detect.d.ts.map +1 -0
- package/dist/commands/detect.js +187 -0
- package/dist/commands/detect.js.map +1 -0
- package/dist/commands/doctor.d.ts +19 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +1272 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/export.d.ts +3 -0
- package/dist/commands/export.d.ts.map +1 -0
- package/dist/commands/export.js +95 -0
- package/dist/commands/export.js.map +1 -0
- package/dist/commands/graph.d.ts +25 -0
- package/dist/commands/graph.d.ts.map +1 -0
- package/dist/commands/graph.js +208 -0
- package/dist/commands/graph.js.map +1 -0
- package/dist/commands/hooks.d.ts +9 -0
- package/dist/commands/hooks.d.ts.map +1 -0
- package/dist/commands/hooks.js +240 -0
- package/dist/commands/hooks.js.map +1 -0
- package/dist/commands/impact.d.ts +18 -0
- package/dist/commands/impact.d.ts.map +1 -0
- package/dist/commands/impact.js +163 -0
- package/dist/commands/impact.js.map +1 -0
- package/dist/commands/index-vector.d.ts +13 -0
- package/dist/commands/index-vector.d.ts.map +1 -0
- package/dist/commands/index-vector.js +103 -0
- package/dist/commands/index-vector.js.map +1 -0
- package/dist/commands/index.d.ts +37 -0
- package/dist/commands/index.d.ts.map +1 -0
- package/dist/commands/index.js +105 -0
- package/dist/commands/index.js.map +1 -0
- package/dist/commands/init.d.ts +8 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +200 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/inject.d.ts +22 -0
- package/dist/commands/inject.d.ts.map +1 -0
- package/dist/commands/inject.js +394 -0
- package/dist/commands/inject.js.map +1 -0
- package/dist/commands/learn.d.ts +13 -0
- package/dist/commands/learn.d.ts.map +1 -0
- package/dist/commands/learn.js +282 -0
- package/dist/commands/learn.js.map +1 -0
- package/dist/commands/lock.d.ts +35 -0
- package/dist/commands/lock.d.ts.map +1 -0
- package/dist/commands/lock.js +308 -0
- package/dist/commands/lock.js.map +1 -0
- package/dist/commands/memory.d.ts +15 -0
- package/dist/commands/memory.d.ts.map +1 -0
- package/dist/commands/memory.js +366 -0
- package/dist/commands/memory.js.map +1 -0
- package/dist/commands/migrate.d.ts +22 -0
- package/dist/commands/migrate.d.ts.map +1 -0
- package/dist/commands/migrate.js +458 -0
- package/dist/commands/migrate.js.map +1 -0
- package/dist/commands/patterns.d.ts +18 -0
- package/dist/commands/patterns.d.ts.map +1 -0
- package/dist/commands/patterns.js +120 -0
- package/dist/commands/patterns.js.map +1 -0
- package/dist/commands/protect.d.ts +12 -0
- package/dist/commands/protect.d.ts.map +1 -0
- package/dist/commands/protect.js +181 -0
- package/dist/commands/protect.js.map +1 -0
- package/dist/commands/quickstart.d.ts +11 -0
- package/dist/commands/quickstart.d.ts.map +1 -0
- package/dist/commands/quickstart.js +256 -0
- package/dist/commands/quickstart.js.map +1 -0
- package/dist/commands/repair.d.ts +13 -0
- package/dist/commands/repair.d.ts.map +1 -0
- package/dist/commands/repair.js +157 -0
- package/dist/commands/repair.js.map +1 -0
- package/dist/commands/resolve.d.ts +19 -0
- package/dist/commands/resolve.d.ts.map +1 -0
- package/dist/commands/resolve.js +355 -0
- package/dist/commands/resolve.js.map +1 -0
- package/dist/commands/roadmap.d.ts +5 -0
- package/dist/commands/roadmap.d.ts.map +1 -0
- package/dist/commands/roadmap.js +23 -0
- package/dist/commands/roadmap.js.map +1 -0
- package/dist/commands/scopes.d.ts +10 -0
- package/dist/commands/scopes.d.ts.map +1 -0
- package/dist/commands/scopes.js +80 -0
- package/dist/commands/scopes.js.map +1 -0
- package/dist/commands/search.d.ts +9 -0
- package/dist/commands/search.d.ts.map +1 -0
- package/dist/commands/search.js +313 -0
- package/dist/commands/search.js.map +1 -0
- package/dist/commands/setup.d.ts +13 -0
- package/dist/commands/setup.d.ts.map +1 -0
- package/dist/commands/setup.js +405 -0
- package/dist/commands/setup.js.map +1 -0
- package/dist/commands/snippet.d.ts +23 -0
- package/dist/commands/snippet.d.ts.map +1 -0
- package/dist/commands/snippet.js +235 -0
- package/dist/commands/snippet.js.map +1 -0
- package/dist/commands/stats.d.ts +15 -0
- package/dist/commands/stats.d.ts.map +1 -0
- package/dist/commands/stats.js +502 -0
- package/dist/commands/stats.js.map +1 -0
- package/dist/commands/status.d.ts +8 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +134 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/commands/suggest-tags.d.ts +9 -0
- package/dist/commands/suggest-tags.d.ts.map +1 -0
- package/dist/commands/suggest-tags.js +95 -0
- package/dist/commands/suggest-tags.js.map +1 -0
- package/dist/commands/sync-rules.d.ts +14 -0
- package/dist/commands/sync-rules.d.ts.map +1 -0
- package/dist/commands/sync-rules.js +211 -0
- package/dist/commands/sync-rules.js.map +1 -0
- package/dist/commands/sync.d.ts +24 -0
- package/dist/commands/sync.d.ts.map +1 -0
- package/dist/commands/sync.js +330 -0
- package/dist/commands/sync.js.map +1 -0
- package/dist/commands/telemetry-test.d.ts +24 -0
- package/dist/commands/telemetry-test.d.ts.map +1 -0
- package/dist/commands/telemetry-test.js +84 -0
- package/dist/commands/telemetry-test.js.map +1 -0
- package/dist/commands/template.d.ts +16 -0
- package/dist/commands/template.d.ts.map +1 -0
- package/dist/commands/template.js +122 -0
- package/dist/commands/template.js.map +1 -0
- package/dist/commands/validate.d.ts +11 -0
- package/dist/commands/validate.d.ts.map +1 -0
- package/dist/commands/validate.js +144 -0
- package/dist/commands/validate.js.map +1 -0
- package/dist/commands/watch-preferences.d.ts +17 -0
- package/dist/commands/watch-preferences.d.ts.map +1 -0
- package/dist/commands/watch-preferences.js +172 -0
- package/dist/commands/watch-preferences.js.map +1 -0
- package/dist/commands/watch.d.ts +11 -0
- package/dist/commands/watch.d.ts.map +1 -0
- package/dist/commands/watch.js +223 -0
- package/dist/commands/watch.js.map +1 -0
- package/dist/config/thresholds.d.ts +8 -0
- package/dist/config/thresholds.d.ts.map +1 -0
- package/dist/config/thresholds.js +10 -0
- package/dist/config/thresholds.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +31 -0
- package/dist/index.js.map +1 -0
- package/dist/memorylink.d.ts +91 -0
- package/dist/memorylink.d.ts.map +1 -0
- package/dist/memorylink.js +208 -0
- package/dist/memorylink.js.map +1 -0
- package/dist/search/local-embeddings.d.ts +21 -0
- package/dist/search/local-embeddings.d.ts.map +1 -0
- package/dist/search/local-embeddings.js +87 -0
- package/dist/search/local-embeddings.js.map +1 -0
- package/dist/search/vector-search.d.ts +58 -0
- package/dist/search/vector-search.d.ts.map +1 -0
- package/dist/search/vector-search.js +535 -0
- package/dist/search/vector-search.js.map +1 -0
- package/dist/server/mcp-server.d.ts +18 -0
- package/dist/server/mcp-server.d.ts.map +1 -0
- package/dist/server/mcp-server.js +293 -0
- package/dist/server/mcp-server.js.map +1 -0
- package/dist/telemetry.d.ts +92 -0
- package/dist/telemetry.d.ts.map +1 -0
- package/dist/telemetry.js +339 -0
- package/dist/telemetry.js.map +1 -0
- package/dist/telemetry.test.d.ts +13 -0
- package/dist/telemetry.test.d.ts.map +1 -0
- package/dist/telemetry.test.js +324 -0
- package/dist/telemetry.test.js.map +1 -0
- package/dist/test-runner/TestRunner.d.ts +68 -0
- package/dist/test-runner/TestRunner.d.ts.map +1 -0
- package/dist/test-runner/TestRunner.js +384 -0
- package/dist/test-runner/TestRunner.js.map +1 -0
- package/dist/test-runner/performance-test.d.ts +36 -0
- package/dist/test-runner/performance-test.d.ts.map +1 -0
- package/dist/test-runner/performance-test.js +163 -0
- package/dist/test-runner/performance-test.js.map +1 -0
- package/dist/test-runner/run-tests.d.ts +7 -0
- package/dist/test-runner/run-tests.d.ts.map +1 -0
- package/dist/test-runner/run-tests.js +167 -0
- package/dist/test-runner/run-tests.js.map +1 -0
- package/dist/types.d.ts +400 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +81 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/batch-commits.d.ts +48 -0
- package/dist/utils/batch-commits.d.ts.map +1 -0
- package/dist/utils/batch-commits.js +164 -0
- package/dist/utils/batch-commits.js.map +1 -0
- package/dist/utils/code-structure.d.ts +62 -0
- package/dist/utils/code-structure.d.ts.map +1 -0
- package/dist/utils/code-structure.js +582 -0
- package/dist/utils/code-structure.js.map +1 -0
- package/dist/utils/commit-patterns.d.ts +24 -0
- package/dist/utils/commit-patterns.d.ts.map +1 -0
- package/dist/utils/commit-patterns.js +78 -0
- package/dist/utils/commit-patterns.js.map +1 -0
- package/dist/utils/observability.d.ts +47 -0
- package/dist/utils/observability.d.ts.map +1 -0
- package/dist/utils/observability.js +137 -0
- package/dist/utils/observability.js.map +1 -0
- package/dist/utils/quality.d.ts +32 -0
- package/dist/utils/quality.d.ts.map +1 -0
- package/dist/utils/quality.js +207 -0
- package/dist/utils/quality.js.map +1 -0
- package/dist/utils/semantic-search.d.ts +29 -0
- package/dist/utils/semantic-search.d.ts.map +1 -0
- package/dist/utils/semantic-search.js +167 -0
- package/dist/utils/semantic-search.js.map +1 -0
- package/dist/utils/streaming.d.ts +24 -0
- package/dist/utils/streaming.d.ts.map +1 -0
- package/dist/utils/streaming.js +121 -0
- package/dist/utils/streaming.js.map +1 -0
- package/dist/utils/tag-suggestions.d.ts +18 -0
- package/dist/utils/tag-suggestions.d.ts.map +1 -0
- package/dist/utils/tag-suggestions.js +103 -0
- package/dist/utils/tag-suggestions.js.map +1 -0
- package/dist/utils/team-patterns.d.ts +48 -0
- package/dist/utils/team-patterns.d.ts.map +1 -0
- package/dist/utils/team-patterns.js +413 -0
- package/dist/utils/team-patterns.js.map +1 -0
- package/dist/utils/templates.d.ts +36 -0
- package/dist/utils/templates.d.ts.map +1 -0
- package/dist/utils/templates.js +200 -0
- package/dist/utils/templates.js.map +1 -0
- package/dist/utils/tree-sitter-parser.d.ts +20 -0
- package/dist/utils/tree-sitter-parser.d.ts.map +1 -0
- package/dist/utils/tree-sitter-parser.js +259 -0
- package/dist/utils/tree-sitter-parser.js.map +1 -0
- package/dist/utils/v1.6-patterns.d.ts +117 -0
- package/dist/utils/v1.6-patterns.d.ts.map +1 -0
- package/dist/utils/v1.6-patterns.js +201 -0
- package/dist/utils/v1.6-patterns.js.map +1 -0
- package/dist/utils.d.ts +176 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +822 -0
- package/dist/utils.js.map +1 -0
- package/docs/1000_SCENARIOS_TEST_RESULTS.md +138 -0
- package/docs/1000_UNIQUE_SCENARIOS_TEST.md +171 -0
- package/docs/100_PERCENT_PASS_RATE_VERIFICATION.md +111 -0
- package/docs/5000_SCENARIOS_ISSUE_ANALYSIS.md +96 -0
- package/docs/5000_SCENARIOS_TEST_PLAN.md +281 -0
- package/docs/AGENT_CONTRACT.md +240 -0
- package/docs/AI_RESPONSE_ANALYZER.md +157 -0
- package/docs/AI_RESPONSE_TRACKER.md +923 -0
- package/docs/AI_TESTING_PROMPT.md +307 -0
- package/docs/AI_VALIDATION_PROMPTS.md +366 -0
- package/docs/ALL_AI_ANALYSES_CONSOLIDATED.md +354 -0
- package/docs/ALL_AI_CONSOLIDATION_FINAL.md +372 -0
- package/docs/ALL_AI_TEST_CONSOLIDATION.md +290 -0
- package/docs/ALL_AI_VALIDATION_SYNTHESIS.md +241 -0
- package/docs/BEST_TESTING_SOLUTION.md +227 -0
- package/docs/BLACKBOX_AI_ANALYSIS.md +288 -0
- package/docs/BLACKBOX_AI_CLARIFICATION.md +55 -0
- package/docs/BLACKBOX_AI_STRATEGIC_VALIDATION.md +283 -0
- package/docs/BLACKBOX_AI_VALIDATION_RESPONSE.md +251 -0
- package/docs/BLACKBOX_AI_VALIDATION_RESPONSE_v2.md +402 -0
- package/docs/BLACKBOX_LAUNCH_VALIDATION.md +25 -0
- package/docs/BLACKBOX_SUPERMEMORY_VALIDATION_AND_PLAN.md +50 -0
- package/docs/CAPACITY_AND_ALTERNATIVES_ANALYSIS.md +289 -0
- package/docs/CHATGPT_AI_CLARIFICATION.md +65 -0
- package/docs/CHATGPT_FINAL_VALIDATION.md +348 -0
- package/docs/CHATGPT_IMPLEMENTATION_GUIDE.md +325 -0
- package/docs/CHATGPT_LAUNCH_VALIDATION.md +47 -0
- package/docs/CHATGPT_MEMORY_QUALITY_AND_VSCODE_CHECK.md +43 -0
- package/docs/CHATGPT_SCOPE_REALITY_CHECK.md +35 -0
- package/docs/CHATGPT_STRATEGIC_VALIDATION.md +329 -0
- package/docs/CHATGPT_VALIDATION_RESPONSE.md +332 -0
- package/docs/CHATGPT_VALIDATION_RESPONSE_v2.md +294 -0
- package/docs/CHATGPT_VALIDATION_RESULTS.md +143 -0
- package/docs/CLAUDE_AI_ANALYSIS.md +692 -0
- package/docs/CLAUDE_AI_CLARIFICATION.md +67 -0
- package/docs/CLAUDE_AI_STRATEGIC_VALIDATION.md +578 -0
- package/docs/CLAUDE_AI_VALIDATION_RESPONSE.md +374 -0
- package/docs/CLAUDE_AI_VALIDATION_RESPONSE_v2.md +463 -0
- package/docs/CLAUDE_FINAL_VALIDATION.md +679 -0
- package/docs/CLAUDE_LAUNCH_VALIDATION.md +27 -0
- package/docs/CLAUDE_SUPERMEMORY_LAUNCH_PRIORITIES.md +44 -0
- package/docs/CLAUDE_UNIVERSAL_VISION.md +18 -0
- package/docs/COMPLETE_AI_VALIDATION_SYNTHESIS.md +229 -0
- package/docs/COMPLETE_MEMORY_ANALYSIS_SUMMARY.md +323 -0
- package/docs/COMPLETE_STRATEGIC_LAUNCH_PLAN.md +241 -0
- package/docs/COPILOT_LANGCHAIN_MEMORY_COMPARISON_AND_PLAN.md +43 -0
- package/docs/CRITICAL_FIXES_ACTION_PLAN.md +251 -0
- package/docs/CRITICAL_MEMORY_USAGE_PROMPTS.md +290 -0
- package/docs/CURSOR_AI_MEMORY_ANALYSIS.md +479 -0
- package/docs/CURSOR_AI_MEMORY_WORKFLOW_ANALYSIS.md +267 -0
- package/docs/CURSOR_AI_TEST_RESULTS.md +298 -0
- package/docs/DEEPSEEK_AI_CLARIFICATION.md +52 -0
- package/docs/DEEPSEEK_AI_IMPLEMENTATION_GUIDE.md +398 -0
- package/docs/DEEPSEEK_AI_STRATEGIC_VALIDATION.md +348 -0
- package/docs/DEEPSEEK_AI_VALIDATION_RESPONSE.md +276 -0
- package/docs/DEEPSEEK_AI_VALIDATION_RESPONSE_v2.md +325 -0
- package/docs/DEEPSEEK_FINAL_VALIDATION.md +337 -0
- package/docs/DEEPSEEK_LAUNCH_VALIDATION.md +55 -0
- package/docs/DEEPSEEK_SCOPE_REALITY_CHECK.md +30 -0
- package/docs/DEEPSEEK_SUPERMEMORY_ADOPTION_AND_VSCODE_PIVOT.md +47 -0
- package/docs/DEEPSEEK_VALIDATION_RESULTS.md +165 -0
- package/docs/DEVELOPMENT_TESTING_PROTOCOL.md +378 -0
- package/docs/E2E_TEST_RESULTS.md +102 -0
- package/docs/END_TO_END_MEMORY_ISSUE_ANALYSIS.md +442 -0
- package/docs/FEATURE_1_GIT_SYNC_PLAN.md +228 -0
- package/docs/FEATURE_2_AUTO_LOGGING_PLAN.md +239 -0
- package/docs/FEATURE_3_CODE_SNIPPET_PLAN.md +249 -0
- package/docs/FEATURE_4_TAG_NORMALIZATION_PLAN.md +211 -0
- package/docs/FEATURE_5_WINDOWS_PATH_HANDLING_PLAN.md +199 -0
- package/docs/FEATURE_6_CONFLICT_DETECTION_PLAN.md +126 -0
- package/docs/FEATURE_IMPLEMENTATION_REPORT.md +203 -0
- package/docs/FINAL_COMPLETE_LAUNCH_DECISION.md +255 -0
- package/docs/FINAL_LAUNCH_DECISION.md +235 -0
- package/docs/FINAL_LAUNCH_DECISION_ALL_AIS.md +226 -0
- package/docs/FINAL_SCENARIO_VERIFICATION.md +363 -0
- package/docs/FIX_100_PERCENT_ANALYSIS.md +133 -0
- package/docs/FRAMEWORK_STRUCTURE.md +94 -0
- package/docs/GEMINI_AI_ANALYSIS.md +156 -0
- package/docs/GEMINI_AI_CLARIFICATION.md +47 -0
- package/docs/GEMINI_AI_STRATEGIC_VALIDATION.md +235 -0
- package/docs/GEMINI_AI_VALIDATION_RESPONSE.md +238 -0
- package/docs/GEMINI_AI_VALIDATION_RESPONSE_v2.md +168 -0
- package/docs/GEMINI_FINAL_VALIDATION.md +204 -0
- package/docs/GEMINI_LAUNCH_VALIDATION.md +30 -0
- package/docs/GEMINI_SCOPE_AND_UNIVERSALITY_DEBATE.md +25 -0
- package/docs/GEMINI_SUPERMEMORY_TREE_SITTER_MANDATE.md +43 -0
- package/docs/GEMINI_VALIDATION_RESULTS.md +183 -0
- package/docs/GROK_AI_ANALYSIS.md +278 -0
- package/docs/GROK_AI_CLARIFICATION.md +52 -0
- package/docs/GROK_AI_STRATEGIC_VALIDATION.md +306 -0
- package/docs/GROK_AI_VALIDATION_RESPONSE.md +252 -0
- package/docs/GROK_AI_VALIDATION_RESPONSE_v2.md +264 -0
- package/docs/GROK_FINAL_VALIDATION.md +251 -0
- package/docs/GROK_LAUNCH_VALIDATION.md +24 -0
- package/docs/GROK_SCOPE_REALITY_CHECK.md +28 -0
- package/docs/GROK_SUPERMEMORY_LAUNCH_ANALYSIS.md +44 -0
- package/docs/GROK_VALIDATION_RESULTS.md +180 -0
- package/docs/IMPLEMENTATION_PLAN_16_CRITICAL_FIXES.md +641 -0
- package/docs/LANGCHAIN_AND_LANGGRAPH_INTEGRATION_PLAN.md +51 -0
- package/docs/LAUNCH_DECISION_FINAL.md +243 -0
- package/docs/MANUS_AI_ANALYSIS.md +171 -0
- package/docs/MANUS_AI_CLARIFICATION.md +43 -0
- package/docs/MANUS_AI_VALIDATION_RESPONSE.md +335 -0
- package/docs/MANUS_AI_VALIDATION_RESPONSE_v2.md +226 -0
- package/docs/MANUS_FINAL_VALIDATION.md +257 -0
- package/docs/MANUS_VALIDATION_RESULTS.md +237 -0
- package/docs/MCP_SERVER_SETUP.md +167 -0
- package/docs/MEMORYLINK_7AI_FINAL_CONFIRMATION.md +210 -0
- package/docs/MEMORYLINK_CURSOR_AI_DEVELOPMENT_GUIDE.md +1092 -0
- package/docs/MEMORYLINK_DEVELOPMENT_PLAN_CURSOR_AI.md +629 -0
- package/docs/MEMORYLINK_FINAL_7AI_CLARIFICATION.md +184 -0
- package/docs/MEMORYLINK_MASTER_DOCUMENT_v4.md +1338 -0
- package/docs/MEMORYLINK_NAMING_ANALYSIS.md +427 -0
- package/docs/MEMORYLINK_REAL_WORLD_SCENARIOS.md +3517 -0
- package/docs/MEMORYLINK_STORAGE_COMPARISON.md +498 -0
- package/docs/MEMORYLINK_V1.0_FINAL_IMPLEMENTATION_PLAN.md +285 -0
- package/docs/MEMORYLINK_VALIDATION_COMPLETE_ANALYSIS.md +207 -0
- package/docs/MEMORYLINK_VS_MEMORY_APPS_ANALYSIS.md +667 -0
- package/docs/MEMORYLINK_v1.0_BUILD_DOCUMENT_FINAL.md +1928 -0
- package/docs/MEMORY_USAGE_FIX_IMPLEMENTATION.md +314 -0
- package/docs/MISTRAL_AI_ANALYSIS.md +189 -0
- package/docs/MISTRAL_AI_CLARIFICATION.md +57 -0
- package/docs/MISTRAL_AI_STRATEGIC_VALIDATION.md +334 -0
- package/docs/MISTRAL_AI_TESTING_REQUEST.md +261 -0
- package/docs/MISTRAL_AI_VALIDATION_RESPONSE.md +446 -0
- package/docs/MISTRAL_AI_VALIDATION_RESPONSE_v2.md +227 -0
- package/docs/MISTRAL_FINAL_VALIDATION.md +398 -0
- package/docs/MISTRAL_LAUNCH_VALIDATION.md +32 -0
- package/docs/MISTRAL_SCOPE_REALITY_CHECK.md +32 -0
- package/docs/MISTRAL_SUPERMEMORY_LAUNCH_ANALYSIS.md +43 -0
- package/docs/MISTRAL_VALIDATION_RESULTS.md +371 -0
- package/docs/NEXT_PLAN.md +300 -0
- package/docs/PERPLEXITY_AI_ANALYSIS.md +285 -0
- package/docs/PERPLEXITY_AI_CLARIFICATION.md +57 -0
- package/docs/PERPLEXITY_AI_STRATEGIC_VALIDATION.md +288 -0
- package/docs/PERPLEXITY_AI_VALIDATION_RESPONSE.md +350 -0
- package/docs/PERPLEXITY_AI_VALIDATION_RESPONSE_v2.md +260 -0
- package/docs/PERPLEXITY_FINAL_VALIDATION.md +320 -0
- package/docs/PERPLEXITY_LAUNCH_VALIDATION.md +42 -0
- package/docs/PERPLEXITY_MEMORY_QUALITY_AND_VSCODE_PLAN.md +56 -0
- package/docs/PERPLEXITY_SCOPE_REALITY_CHECK.md +31 -0
- package/docs/PERPLEXITY_VALIDATION_RESULTS.md +154 -0
- package/docs/PRE_LAUNCH_GAP_ANALYSIS.md +663 -0
- package/docs/PROJECT_STRUCTURE_PLAN.md +104 -0
- package/docs/QWEN_AI_ANALYSIS.md +176 -0
- package/docs/QWEN_AI_CLARIFICATION.md +60 -0
- package/docs/QWEN_AI_STRATEGIC_VALIDATION.md +241 -0
- package/docs/QWEN_AI_VALIDATION_RESPONSE.md +197 -0
- package/docs/QWEN_AI_VALIDATION_RESPONSE_v2.md +186 -0
- package/docs/QWEN_FINAL_VALIDATION.md +284 -0
- package/docs/QWEN_LAUNCH_VALIDATION.md +26 -0
- package/docs/QWEN_SCENARIOS_TEST_RESULTS.md +244 -0
- package/docs/QWEN_SCOPE_REALITY_CHECK.md +26 -0
- package/docs/QWEN_SUPERMEMORY_LAUNCH_AND_ENFORCEMENT_PLAN.md +56 -0
- package/docs/QWEN_VALIDATION_RESULTS.md +185 -0
- package/docs/README.md +479 -0
- package/docs/REAL_PRODUCT_LAUNCH_DECISION.md +185 -0
- package/docs/RECIPES.md +424 -0
- package/docs/RELEASE_NOTES_v1.0.0.md +193 -0
- package/docs/SCENARIO_INVENTORY_AND_VERIFICATION.md +284 -0
- package/docs/SINGLE_RUN_1018_SCENARIOS_RESULTS.md +142 -0
- package/docs/TESTING.md +256 -0
- package/docs/TESTING_STRATEGY.md +194 -0
- package/docs/TROUBLESHOOTING.md +188 -0
- package/docs/ULTIMATE_LAUNCH_DECISION.md +246 -0
- package/docs/WHAT_WE_BUILT.md +504 -0
- package/docs/v1.0_LAUNCH_CHECKLIST.md +104 -0
- package/examples/README.md +199 -0
- package/examples/chatgpt-context.js +161 -0
- package/examples/ci-integration.js +288 -0
- package/examples/sync-from-cursor.js +196 -0
- package/extensions/vscode/README.md +25 -0
- package/extensions/vscode/out/buddy-check.js +208 -0
- package/extensions/vscode/out/buddy-check.js.map +1 -0
- package/extensions/vscode/out/extension.js +413 -0
- package/extensions/vscode/out/extension.js.map +1 -0
- package/extensions/vscode/out/sidebar.js +409 -0
- package/extensions/vscode/out/sidebar.js.map +1 -0
- package/extensions/vscode/package.json +92 -0
- package/extensions/vscode/src/buddy-check.ts +220 -0
- package/extensions/vscode/src/extension.ts +425 -0
- package/extensions/vscode/src/shims-vscode.d.ts +2 -0
- package/extensions/vscode/src/sidebar.ts +431 -0
- package/extensions/vscode/tsconfig.json +14 -0
- package/k6-load-test.js +86 -0
- package/package.json +68 -0
- package/run-professional-tests.sh +72 -0
- package/scripts/monitor-continuous-test.sh +17 -0
- package/scripts/reorganize-project.sh +164 -0
- package/scripts/run-tests-parallel.sh +111 -0
- package/scripts/run-tests.sh +30 -0
- package/scripts/setup-framework.sh +139 -0
- package/scripts/setup-testing.sh +96 -0
- package/scripts/stress-test/README.md +86 -0
- package/scripts/stress-test/create-all-scenarios.sh +17 -0
- package/scripts/stress-test/create-remaining-scenarios.sh +3 -0
- package/scripts/stress-test/dev-test.sh +21 -0
- package/scripts/stress-test/monitor-continuous.sh +149 -0
- package/scripts/stress-test/overnight-test.sh +30 -0
- package/scripts/stress-test/quick-test.sh +21 -0
- package/scripts/stress-test/run-all-tests.sh +157 -0
- package/scripts/stress-test/run-continuous.sh +300 -0
- package/scripts/stress-test/run-stress-test.sh +153 -0
- package/scripts/stress-test/set1/1_1_mass_refactoring.sh +117 -0
- package/scripts/stress-test/set1/1_1_mass_refactoring_simple.sh +117 -0
- package/scripts/stress-test/set1/1_2_function_rename.sh +95 -0
- package/scripts/stress-test/set1/1_3_feature_flags.sh +93 -0
- package/scripts/stress-test/set1/1_4_feature_removal.sh +57 -0
- package/scripts/stress-test/set1/1_5_schema_changes.sh +42 -0
- package/scripts/stress-test/set1/1_6_dependency_update.sh +47 -0
- package/scripts/stress-test/set1/1_7_config_modification.sh +53 -0
- package/scripts/stress-test/set2/2_1_payment_logging.sh +49 -0
- package/scripts/stress-test/set2/2_2_test_data_generation.sh +43 -0
- package/scripts/stress-test/set2/2_3_documentation_leak.sh +45 -0
- package/scripts/stress-test/set2/2_4_api_key_rotation.sh +45 -0
- package/scripts/stress-test/set2/2_5_hardcoded_secrets.sh +45 -0
- package/scripts/stress-test/set2/2_6_debug_output.sh +49 -0
- package/scripts/stress-test/set3/3_1_billing_modification.sh +47 -0
- package/scripts/stress-test/set3/3_2_migration_deletion.sh +43 -0
- package/scripts/stress-test/set3/3_3_auth_middleware.sh +52 -0
- package/scripts/stress-test/set3/3_4_permission_bypass.sh +48 -0
- package/scripts/stress-test/set3/3_5_config_modification.sh +43 -0
- package/scripts/stress-test/set3/3_6_core_library.sh +51 -0
- package/scripts/stress-test/set3/3_7_test_infrastructure.sh +49 -0
- package/scripts/stress-test/set4/4_1_concurrent_features.sh +49 -0
- package/scripts/stress-test/set4/4_2_lock_acquisition.sh +32 -0
- package/scripts/stress-test/set4/4_3_migration_hotfix.sh +43 -0
- package/scripts/stress-test/set4/4_4_overlapping_scopes.sh +50 -0
- package/scripts/stress-test/set4/4_5_lock_timeout.sh +34 -0
- package/scripts/stress-test/set4/4_6_concurrent_stats.sh +33 -0
- package/scripts/stress-test/set5/5_1_wrong_decision.sh +41 -0
- package/scripts/stress-test/set5/5_2_outdated_docs.sh +40 -0
- package/scripts/stress-test/set5/5_3_conflicting_memories.sh +34 -0
- package/scripts/stress-test/set5/5_4_deleted_file_references.sh +38 -0
- package/scripts/stress-test/set5/5_5_old_pattern.sh +41 -0
- package/scripts/stress-test/set5/5_6_wrong_architecture.sh +42 -0
- package/scripts/stress-test/set5/5_7_high_trust_stale.sh +46 -0
- package/scripts/stress-test/set5/5_8_observability_stale.sh +36 -0
- package/scripts/stress-test/setup-test-repo-simple.sh +144 -0
- package/scripts/stress-test/setup-test-repo.sh +154 -0
- package/scripts/stress-test/start-continuous.sh +48 -0
- package/scripts/stress-test/stop-continuous.sh +42 -0
- package/scripts/stress-test/template-scenario.sh +115 -0
- package/scripts/test-advanced-scenarios.sh +411 -0
- package/scripts/test-continuous-30min.sh +307 -0
- package/scripts/test-continuous-enhanced.sh +250 -0
- package/scripts/test-e2e-comprehensive.sh +114 -0
- package/scripts/test-e2e-random.sh +359 -0
- package/scripts/test-fresh-scenarios.sh +412 -0
- package/scripts/test-new-scenarios.sh +374 -0
- package/scripts/test-quick-random.sh +97 -0
- package/scripts/test-runtime.sh +129 -0
- package/scripts/test-telemetry-local.sh +193 -0
- package/scripts/test-ultimate-scenarios.sh +428 -0
- package/scripts/test-v1.5-complete.sh +225 -0
- package/scripts/test-v1.5-phase1.sh +222 -0
- package/src/cli.ts +1259 -0
- package/src/commands/archive.ts +252 -0
- package/src/commands/auto-context.ts +159 -0
- package/src/commands/auto-log.ts +531 -0
- package/src/commands/change.ts +298 -0
- package/src/commands/checkpoint.ts +390 -0
- package/src/commands/configure.ts +297 -0
- package/src/commands/consolidate.ts +263 -0
- package/src/commands/context.ts +618 -0
- package/src/commands/detect.ts +181 -0
- package/src/commands/doctor.ts +1468 -0
- package/src/commands/export.ts +77 -0
- package/src/commands/graph.ts +214 -0
- package/src/commands/hooks.ts +245 -0
- package/src/commands/impact.ts +163 -0
- package/src/commands/index-vector.ts +126 -0
- package/src/commands/index.ts +57 -0
- package/src/commands/init.ts +194 -0
- package/src/commands/inject.ts +440 -0
- package/src/commands/learn.ts +328 -0
- package/src/commands/lock.ts +345 -0
- package/src/commands/memory.ts +415 -0
- package/src/commands/migrate.ts +540 -0
- package/src/commands/patterns.ts +158 -0
- package/src/commands/protect.ts +199 -0
- package/src/commands/quickstart.ts +259 -0
- package/src/commands/resolve.ts +373 -0
- package/src/commands/roadmap.ts +25 -0
- package/src/commands/scopes.ts +113 -0
- package/src/commands/search.ts +365 -0
- package/src/commands/setup.ts +430 -0
- package/src/commands/snippet.ts +271 -0
- package/src/commands/stats.ts +591 -0
- package/src/commands/status.ts +127 -0
- package/src/commands/suggest-tags.ts +122 -0
- package/src/commands/sync-rules.ts +218 -0
- package/src/commands/sync.ts +363 -0
- package/src/commands/telemetry-test.ts +97 -0
- package/src/commands/template.ts +166 -0
- package/src/commands/validate.ts +191 -0
- package/src/commands/watch-preferences.ts +162 -0
- package/src/commands/watch.ts +239 -0
- package/src/config/thresholds.ts +14 -0
- package/src/index.ts +12 -0
- package/src/memorylink.ts +308 -0
- package/src/search/local-embeddings.ts +94 -0
- package/src/search/vector-search.ts +608 -0
- package/src/server/mcp-server.ts +355 -0
- package/src/telemetry.ts +391 -0
- package/src/test-runner/TestRunner.ts +421 -0
- package/src/test-runner/performance-test.ts +161 -0
- package/src/test-runner/run-tests.ts +152 -0
- package/src/types.ts +533 -0
- package/src/utils/batch-commits.ts +162 -0
- package/src/utils/code-structure.ts +686 -0
- package/src/utils/commit-patterns.ts +87 -0
- package/src/utils/observability.ts +149 -0
- package/src/utils/quality.ts +230 -0
- package/src/utils/semantic-search.ts +222 -0
- package/src/utils/streaming.ts +109 -0
- package/src/utils/tag-suggestions.ts +117 -0
- package/src/utils/team-patterns.ts +499 -0
- package/src/utils/templates.ts +181 -0
- package/src/utils/tree-sitter-parser.ts +246 -0
- package/src/utils/v1.6-patterns.ts +227 -0
- package/src/utils.ts +885 -0
- package/test-all-features.sh +102 -0
- package/test-all-implemented-features.sh +209 -0
- package/test-all-new-features.sh +171 -0
- package/test-auto-log.txt +1 -0
- package/test-batch-commits.sh +47 -0
- package/test-conflict-resolution.sh +47 -0
- package/test-e2e.sh +22 -0
- package/test-end-to-end.sh +151 -0
- package/test-enhanced-autocapture.sh +164 -0
- package/test-inject.sh +44 -0
- package/test-mcp-server.sh +67 -0
- package/test-pagination.sh +37 -0
- package/test-python-go-structure.sh +164 -0
- package/test-quality-validation.sh +167 -0
- package/test-results-quick-smoke.json +13 -0
- package/test-results-targeted-perf.json +23 -0
- package/test-results.json +2272 -0
- package/test-scenarios/payment-logging.ts +17 -0
- package/test-scenarios/test-config.ts +13 -0
- package/test-semantic-search.sh +161 -0
- package/test-tag-intelligence.sh +49 -0
- package/test-vector-search.sh +64 -0
- package/test-vscode-extension.sh +144 -0
- package/test-watcher-file.txt +2 -0
- package/test-watcher-file2.txt +1 -0
- package/test-watcher.sh +103 -0
- package/test_qwen_scenarios.sh +285 -0
- package/tests/scenarios/4000_HARD_SCENARIOS.sh +4137 -0
- package/tests/scenarios/ADD_V1.1_SCENARIOS.sh +93 -0
- package/tests/scenarios/AGGRESSIVE_RANDOM_E2E_TEST.sh +474 -0
- package/tests/scenarios/COMPLETE_PRODUCT_VALIDATION.sh +227 -0
- package/tests/scenarios/COMPREHENSIVE_E2E_TEST.sh +426 -0
- package/tests/scenarios/CONTINUOUS_RANDOM_STRESS_TEST.sh +240 -0
- package/tests/scenarios/EXECUTE_10000_SCENARIOS.sh +61 -0
- package/tests/scenarios/EXECUTE_1000_UNIQUE_SCENARIOS.sh +190 -0
- package/tests/scenarios/EXECUTE_5000_SCENARIOS_SPLIT.sh +192 -0
- package/tests/scenarios/EXECUTE_5000_TOTAL_SCENARIOS.sh +162 -0
- package/tests/scenarios/EXECUTE_5040_SCENARIOS_WITH_V1.1.sh +251 -0
- package/tests/scenarios/EXECUTE_8_BATCHES_500.sh +51 -0
- package/tests/scenarios/EXECUTE_QUICK_SMOKE.sh +9 -0
- package/tests/scenarios/EXECUTE_SINGLE_BATCH.sh +117 -0
- package/tests/scenarios/EXECUTE_TARGETED_PERF.sh +19 -0
- package/tests/scenarios/GENERATE_1000_SCENARIOS.sh +235 -0
- package/tests/scenarios/GENERATE_4000_HARD_SCENARIOS.sh +266 -0
- package/tests/scenarios/GENERATE_4000_HARD_SCENARIOS_FIXED.sh +267 -0
- package/tests/scenarios/GENERATE_4000_HARD_SCENARIOS_FIXED_V2.sh +267 -0
- package/tests/scenarios/NEW_RANDOM_E2E_TEST.sh +422 -0
- package/tests/scenarios/QUICK_SMOKE_200.sh +38 -0
- package/tests/scenarios/QUICK_SMOKE_MINI.sh +3 -0
- package/tests/scenarios/RANDOM_REAL_WORLD_SCENARIOS.sh +372 -0
- package/tests/scenarios/ROUND3_RANDOM_E2E_TEST.sh +446 -0
- package/tests/scenarios/RUN_AGGRESSIVE_AND_SUMMARY.sh +51 -0
- package/tests/scenarios/RUN_ALL_1018_SCENARIOS.sh +161 -0
- package/tests/scenarios/TARGETED_PERF.sh +75 -0
- package/tests/scenarios/V1.1_FEATURES_SCENARIOS.sh +145 -0
- package/tests/unit/utils.test.ts +52 -0
- package/tests/v1.1-features-scenarios.sh +276 -0
- package/tsconfig.json +21 -0
- package/v1.6_FEATURE_REQUESTS.md +79 -0
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Add v1.1 Feature Scenarios to 4000_HARD_SCENARIOS.sh
|
|
3
|
+
# This script appends 40 new scenarios for v1.1 features (IDs 6001-6040)
|
|
4
|
+
|
|
5
|
+
SCENARIO_FILE="tests/scenarios/4000_HARD_SCENARIOS.sh"
|
|
6
|
+
V1_1_SCENARIOS="tests/scenarios/V1.1_FEATURES_SCENARIOS.sh"
|
|
7
|
+
|
|
8
|
+
if [ ! -f "$SCENARIO_FILE" ]; then
|
|
9
|
+
echo "❌ $SCENARIO_FILE not found"
|
|
10
|
+
exit 1
|
|
11
|
+
fi
|
|
12
|
+
|
|
13
|
+
echo "📝 Adding v1.1 feature scenarios to 4000_HARD_SCENARIOS.sh..."
|
|
14
|
+
echo ""
|
|
15
|
+
|
|
16
|
+
# Extract scenarios from V1.1 file and convert to 4000_HARD_SCENARIOS format
|
|
17
|
+
# We'll add them at the end with IDs starting from 6001
|
|
18
|
+
|
|
19
|
+
cat >> "$SCENARIO_FILE" << 'EOF'
|
|
20
|
+
|
|
21
|
+
# ============================================================================
|
|
22
|
+
# V1.1 NEW FEATURES SCENARIOS (IDs 6001-6040)
|
|
23
|
+
# ============================================================================
|
|
24
|
+
|
|
25
|
+
# Feature 1: File Watcher Auto-Capture
|
|
26
|
+
test_scenario 6001 "V1.1-1: Watch command with auto-log" "node dist/cli.js watch --help | grep -q 'watch'" "pass"
|
|
27
|
+
test_scenario 6002 "V1.1-2: Watch with --no-auto-log flag" "node dist/cli.js watch --help | grep -q 'no-auto-log'" "pass"
|
|
28
|
+
test_scenario 6003 "V1.1-3: Watch file exists" "[ -f dist/commands/watch.js ]" "pass"
|
|
29
|
+
|
|
30
|
+
# Feature 2: Pagination + Streaming
|
|
31
|
+
test_scenario 6004 "V1.1-4: Get-context with --page flag" "node dist/cli.js get-context --page 1 --per-page 5 > /dev/null 2>&1" "pass"
|
|
32
|
+
test_scenario 6005 "V1.1-5: Get-context with --per-page flag" "node dist/cli.js get-context --per-page 10 > /dev/null 2>&1" "pass"
|
|
33
|
+
test_scenario 6006 "V1.1-6: Get-context with --stream flag" "node dist/cli.js get-context --stream --limit 10 > /dev/null 2>&1" "pass"
|
|
34
|
+
test_scenario 6007 "V1.1-7: Streaming utility exists" "[ -f dist/utils/streaming.js ]" "pass"
|
|
35
|
+
|
|
36
|
+
# Feature 3: Auto-Context Injection
|
|
37
|
+
test_scenario 6008 "V1.1-8: Inject command works" "node dist/cli.js inject --help | grep -q 'inject'" "pass"
|
|
38
|
+
test_scenario 6009 "V1.1-9: Inject with --no-notify flag" "node dist/cli.js inject --help | grep -q 'no-notify'" "pass"
|
|
39
|
+
test_scenario 6010 "V1.1-10: Inject with --auto flag" "node dist/cli.js inject --help | grep -q 'auto'" "pass"
|
|
40
|
+
test_scenario 6011 "V1.1-11: Inject with tag filter" "node dist/cli.js inject --tag test > /dev/null 2>&1" "pass"
|
|
41
|
+
|
|
42
|
+
# Feature 4: MCP Server
|
|
43
|
+
test_scenario 6012 "V1.1-12: Server command exists" "node dist/cli.js server --help | grep -q 'server'" "pass"
|
|
44
|
+
test_scenario 6013 "V1.1-13: MCP server file exists" "[ -f dist/server/mcp-server.js ]" "pass"
|
|
45
|
+
test_scenario 6014 "V1.1-14: MCP SDK installed" "[ -d node_modules/@modelcontextprotocol/sdk ]" "pass"
|
|
46
|
+
test_scenario 6015 "V1.1-15: MCP server loads" "node -e \"require('./dist/server/mcp-server.js')\" > /dev/null 2>&1" "pass"
|
|
47
|
+
|
|
48
|
+
# Feature 5: Vector Search
|
|
49
|
+
test_scenario 6016 "V1.1-16: Index command exists" "node dist/cli.js index --help | grep -q 'index'" "pass"
|
|
50
|
+
test_scenario 6017 "V1.1-17: Index with --vector flag" "node dist/cli.js index --help | grep -q 'vector'" "pass"
|
|
51
|
+
test_scenario 6018 "V1.1-18: Search with --vector flag" "node dist/cli.js search --help | grep -q 'vector'" "pass"
|
|
52
|
+
test_scenario 6019 "V1.1-19: Vector search file exists" "[ -f dist/search/vector-search.js ]" "pass"
|
|
53
|
+
test_scenario 6020 "V1.1-20: OpenAI package installed" "[ -d node_modules/openai ]" "pass"
|
|
54
|
+
|
|
55
|
+
# Feature 6: Tag Intelligence
|
|
56
|
+
test_scenario 6021 "V1.1-21: Suggest-tags command exists" "node dist/cli.js suggest-tags --help | grep -q 'suggest'" "pass"
|
|
57
|
+
test_scenario 6022 "V1.1-22: Tag suggestions work" "node dist/cli.js suggest-tags 'test content' > /dev/null 2>&1" "pass"
|
|
58
|
+
test_scenario 6023 "V1.1-23: Tag normalization works" "node dist/cli.js memory 'Test' --tags 'TypeScript,React Hooks' > /dev/null 2>&1" "pass"
|
|
59
|
+
test_scenario 6024 "V1.1-24: Tag suggestions file exists" "[ -f dist/utils/tag-suggestions.js ]" "pass"
|
|
60
|
+
|
|
61
|
+
# Feature 7: Batch Commits
|
|
62
|
+
test_scenario 6025 "V1.1-25: Sync with --batch flag" "node dist/cli.js sync --help | grep -q 'batch'" "pass"
|
|
63
|
+
test_scenario 6026 "V1.1-26: Sync with --batch-size flag" "node dist/cli.js sync --help | grep -q 'batch-size'" "pass"
|
|
64
|
+
test_scenario 6027 "V1.1-27: Sync with --batch-timeout flag" "node dist/cli.js sync --help | grep -q 'batch-timeout'" "pass"
|
|
65
|
+
test_scenario 6028 "V1.1-28: Sync with --force-commit flag" "node dist/cli.js sync --help | grep -q 'force-commit'" "pass"
|
|
66
|
+
test_scenario 6029 "V1.1-29: Batch commits utility exists" "[ -f dist/utils/batch-commits.js ]" "pass"
|
|
67
|
+
|
|
68
|
+
# Feature 8: Conflict Resolution
|
|
69
|
+
test_scenario 6030 "V1.1-30: Resolve command exists" "node dist/cli.js resolve --help | grep -q 'resolve'" "pass"
|
|
70
|
+
test_scenario 6031 "V1.1-31: Resolve with --list flag" "node dist/cli.js resolve --help | grep -q 'list'" "pass"
|
|
71
|
+
test_scenario 6032 "V1.1-32: Resolve with --file flag" "node dist/cli.js resolve --help | grep -q 'file'" "pass"
|
|
72
|
+
test_scenario 6033 "V1.1-33: Resolve with --strategy flag" "node dist/cli.js resolve --help | grep -q 'strategy'" "pass"
|
|
73
|
+
test_scenario 6034 "V1.1-34: Resolve file exists" "[ -f dist/commands/resolve.js ]" "pass"
|
|
74
|
+
|
|
75
|
+
# Integration Scenarios
|
|
76
|
+
test_scenario 6035 "V1.1-35: Search with --semantic flag" "node dist/cli.js search 'test' --semantic --limit 5 > /dev/null 2>&1" "pass"
|
|
77
|
+
test_scenario 6036 "V1.1-36: Get-context with pagination" "node dist/cli.js get-context --page 1 --per-page 5 > /dev/null 2>&1" "pass"
|
|
78
|
+
test_scenario 6037 "V1.1-37: Memory with auto-suggestions" "node dist/cli.js memory 'Fixed JWT bug' > /dev/null 2>&1" "pass"
|
|
79
|
+
test_scenario 6038 "V1.1-38: Sync with batch check" "node dist/cli.js sync --batch --check > /dev/null 2>&1" "pass"
|
|
80
|
+
test_scenario 6039 "V1.1-39: Search with vector flag check" "node dist/cli.js search --help | grep -q 'vector'" "pass"
|
|
81
|
+
test_scenario 6040 "V1.1-40: All v1.1 features integrated" "node dist/cli.js --help | grep -q 'suggest-tags\|resolve\|index\|server'" "pass"
|
|
82
|
+
|
|
83
|
+
EOF
|
|
84
|
+
|
|
85
|
+
echo "✅ Added 40 v1.1 feature scenarios (IDs 6001-6040) to $SCENARIO_FILE"
|
|
86
|
+
echo ""
|
|
87
|
+
echo "📊 Updated scenario count:"
|
|
88
|
+
echo " - Original: 4000 scenarios (IDs 2001-6000)"
|
|
89
|
+
echo " - Added: 40 v1.1 scenarios (IDs 6001-6040)"
|
|
90
|
+
echo " - Total: 4040 scenarios"
|
|
91
|
+
echo ""
|
|
92
|
+
echo "💡 Note: Combined with existing 1000 scenarios = 5040 total scenarios"
|
|
93
|
+
|
|
@@ -0,0 +1,474 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Aggressive Random End-to-End Test
|
|
3
|
+
# Generates completely unpredictable scenarios to find any broken parts
|
|
4
|
+
|
|
5
|
+
set +e # Don't exit on error, we want to test everything
|
|
6
|
+
|
|
7
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
8
|
+
echo "🎲 AGGRESSIVE RANDOM END-TO-END TEST"
|
|
9
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
10
|
+
echo ""
|
|
11
|
+
|
|
12
|
+
# Colors
|
|
13
|
+
GREEN='\033[0;32m'
|
|
14
|
+
RED='\033[0;31m'
|
|
15
|
+
YELLOW='\033[1;33m'
|
|
16
|
+
BLUE='\033[0;34m'
|
|
17
|
+
CYAN='\033[0;36m'
|
|
18
|
+
NC='\033[0m'
|
|
19
|
+
|
|
20
|
+
PASSED=0
|
|
21
|
+
FAILED=0
|
|
22
|
+
TOTAL=0
|
|
23
|
+
BROKEN_FEATURES=()
|
|
24
|
+
|
|
25
|
+
# Test counter
|
|
26
|
+
test_num=0
|
|
27
|
+
|
|
28
|
+
# Generate random string
|
|
29
|
+
random_str() {
|
|
30
|
+
local len=${1:-$(($RANDOM % 50 + 10))}
|
|
31
|
+
cat /dev/urandom 2>/dev/null | LC_ALL=C tr -dc 'a-zA-Z0-9' 2>/dev/null | head -c $len || echo "test_$(date +%s)_$RANDOM"
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
# Generate random unicode
|
|
35
|
+
random_unicode() {
|
|
36
|
+
echo "测试_$(date +%s)_🌟_🚀_$(random_str 10)"
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
# Generate random number
|
|
40
|
+
random_num() {
|
|
41
|
+
echo $(($RANDOM % 100 + 1))
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
# Test function with detailed error reporting
|
|
45
|
+
test_random() {
|
|
46
|
+
local name="$1"
|
|
47
|
+
local cmd="$2"
|
|
48
|
+
local category="$3"
|
|
49
|
+
|
|
50
|
+
((test_num++))
|
|
51
|
+
((TOTAL++))
|
|
52
|
+
|
|
53
|
+
echo -e "${CYAN}[Test $test_num]${NC} ${BLUE}[$category]${NC} $name"
|
|
54
|
+
|
|
55
|
+
# Execute and capture
|
|
56
|
+
eval "$cmd" > /tmp/aggressive_test_$$.log 2>&1
|
|
57
|
+
local exit_code=$?
|
|
58
|
+
|
|
59
|
+
# Check for success indicators first
|
|
60
|
+
if grep -qiE "(added|success|✅|completed|found|Protected|Exported|Status|Quality|Memory|Learning|logged|Change logged|Memory added|Learning added|Protected|Unprotected|Exported|Status|Doctor|Quality score|templates|roadmap|Complexity|Functions|Lines|Dependencies)" /tmp/aggressive_test_$$.log 2>/dev/null; then
|
|
61
|
+
echo -e "${GREEN}✅ PASS${NC}"
|
|
62
|
+
((PASSED++))
|
|
63
|
+
return 0
|
|
64
|
+
fi
|
|
65
|
+
|
|
66
|
+
# Check for silent success (exit code 0 with no errors)
|
|
67
|
+
if [ $exit_code -eq 0 ]; then
|
|
68
|
+
# Check if there are actual errors
|
|
69
|
+
if ! grep -qiE "(error|✗|failed|not found|missing|syntax error|unexpected)" /tmp/aggressive_test_$$.log 2>/dev/null; then
|
|
70
|
+
# No errors and exit 0 = success (for silent commands like graph build)
|
|
71
|
+
echo -e "${GREEN}✅ PASS${NC}"
|
|
72
|
+
((PASSED++))
|
|
73
|
+
return 0
|
|
74
|
+
fi
|
|
75
|
+
fi
|
|
76
|
+
|
|
77
|
+
# Check for expected validation errors
|
|
78
|
+
if grep -qiE "(cannot be empty|not initialized|required|MemoryLink is not initialized|invalid|error)" /tmp/aggressive_test_$$.log 2>/dev/null; then
|
|
79
|
+
if grep -qiE "(cannot be empty|not initialized|required|invalid)" /tmp/aggressive_test_$$.log 2>/dev/null && \
|
|
80
|
+
! grep -qiE "(added|success|✅|completed)" /tmp/aggressive_test_$$.log 2>/dev/null; then
|
|
81
|
+
echo -e "${GREEN}✅ PASS${NC} (Expected validation)"
|
|
82
|
+
((PASSED++))
|
|
83
|
+
return 0
|
|
84
|
+
fi
|
|
85
|
+
fi
|
|
86
|
+
|
|
87
|
+
# Real failure
|
|
88
|
+
echo -e "${RED}❌ FAIL${NC}"
|
|
89
|
+
echo " Command: $cmd"
|
|
90
|
+
echo " Exit code: $exit_code"
|
|
91
|
+
echo " Output:"
|
|
92
|
+
head -5 /tmp/aggressive_test_$$.log | sed 's/^/ /'
|
|
93
|
+
BROKEN_FEATURES+=("$category: $name")
|
|
94
|
+
((FAILED++))
|
|
95
|
+
return 1
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
# Setup
|
|
99
|
+
cd "$(dirname "$0")/../.."
|
|
100
|
+
TEST_BASE="/tmp/memlink_aggressive_$$"
|
|
101
|
+
mkdir -p "$TEST_BASE"
|
|
102
|
+
|
|
103
|
+
echo "Generating completely random scenarios..."
|
|
104
|
+
echo ""
|
|
105
|
+
|
|
106
|
+
# Create test directory
|
|
107
|
+
TEST_DIR="$TEST_BASE/test_$(date +%s)"
|
|
108
|
+
mkdir -p "$TEST_DIR"
|
|
109
|
+
cd "$TEST_DIR"
|
|
110
|
+
|
|
111
|
+
# Initialize
|
|
112
|
+
echo "Initializing MemoryLink..."
|
|
113
|
+
npx tsx "$OLDPWD/src/cli.ts" init > /dev/null 2>&1 || true
|
|
114
|
+
|
|
115
|
+
echo ""
|
|
116
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
117
|
+
echo "🧪 RANDOM SCENARIO GENERATION"
|
|
118
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
119
|
+
echo ""
|
|
120
|
+
|
|
121
|
+
# ============================================
|
|
122
|
+
# RANDOM MEMORY SCENARIOS
|
|
123
|
+
# ============================================
|
|
124
|
+
echo -e "${YELLOW}📝 Random Memory Scenarios${NC}"
|
|
125
|
+
|
|
126
|
+
# Random memory with random tags
|
|
127
|
+
for i in {1..10}; do
|
|
128
|
+
MSG="Random memory $i: $(random_str $(($RANDOM % 200 + 20)))"
|
|
129
|
+
TAG_COUNT=$(($RANDOM % 10 + 1))
|
|
130
|
+
TAGS=""
|
|
131
|
+
for j in $(seq 1 $TAG_COUNT); do
|
|
132
|
+
TAGS="${TAGS}tag$(($RANDOM % 100))"
|
|
133
|
+
[ $j -lt $TAG_COUNT ] && TAGS="${TAGS},"
|
|
134
|
+
done
|
|
135
|
+
test_random "Memory $i with $TAG_COUNT tags" \
|
|
136
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" memory \"$MSG\" --tags \"$TAGS\"" \
|
|
137
|
+
"Memory"
|
|
138
|
+
done
|
|
139
|
+
|
|
140
|
+
# Random memory with unicode
|
|
141
|
+
for i in {1..3}; do
|
|
142
|
+
MSG="$(random_unicode): $(random_str 30)"
|
|
143
|
+
test_random "Unicode memory $i" \
|
|
144
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" memory \"$MSG\" --tags unicode,test" \
|
|
145
|
+
"Memory"
|
|
146
|
+
done
|
|
147
|
+
|
|
148
|
+
# Random memory with special characters (properly escaped)
|
|
149
|
+
SPECIAL_CHARS=("@#$%^&*()" "[]{}|\\" "test@example.com" "file://path/to/file")
|
|
150
|
+
for special in "${SPECIAL_CHARS[@]}"; do
|
|
151
|
+
MSG="Special chars test: $special $(random_str 20)"
|
|
152
|
+
# Use printf to properly escape
|
|
153
|
+
ESCAPED_MSG=$(printf '%q' "$MSG")
|
|
154
|
+
test_random "Memory with special: $special" \
|
|
155
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" memory $ESCAPED_MSG --tags special" \
|
|
156
|
+
"Memory"
|
|
157
|
+
done
|
|
158
|
+
|
|
159
|
+
# Test with quotes and backticks separately (harder cases)
|
|
160
|
+
test_random "Memory with quotes" \
|
|
161
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" memory 'Test with quotes: \"hello\" world' --tags special" \
|
|
162
|
+
"Memory"
|
|
163
|
+
test_random "Memory with backticks" \
|
|
164
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" memory 'Test with backticks: \`command\`' --tags special" \
|
|
165
|
+
"Memory"
|
|
166
|
+
|
|
167
|
+
# Random memory types
|
|
168
|
+
TYPES=("note" "decision" "doc_ref" "context" "rule")
|
|
169
|
+
for type in "${TYPES[@]}"; do
|
|
170
|
+
MSG="Type $type test: $(random_str 40)"
|
|
171
|
+
test_random "Memory type: $type" \
|
|
172
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" memory \"$MSG\" --type $type --tags type_test" \
|
|
173
|
+
"Memory"
|
|
174
|
+
done
|
|
175
|
+
|
|
176
|
+
# ============================================
|
|
177
|
+
# RANDOM LEARNING SCENARIOS
|
|
178
|
+
# ============================================
|
|
179
|
+
echo ""
|
|
180
|
+
echo -e "${YELLOW}🎓 Random Learning Scenarios${NC}"
|
|
181
|
+
|
|
182
|
+
for i in {1..10}; do
|
|
183
|
+
PROBLEM="Problem $i: $(random_str $(($RANDOM % 100 + 20)))"
|
|
184
|
+
SOLUTION="Solution $i: $(random_str $(($RANDOM % 150 + 30)))"
|
|
185
|
+
STATUS=$([ $(($RANDOM % 2)) -eq 0 ] && echo "SUCCESS" || echo "FAILED")
|
|
186
|
+
REASON=""
|
|
187
|
+
if [ $(($RANDOM % 2)) -eq 0 ]; then
|
|
188
|
+
REASON="--reason \"Reason $(random_str 30)\""
|
|
189
|
+
fi
|
|
190
|
+
test_random "Learning $i ($STATUS)" \
|
|
191
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" learn \"$PROBLEM\" \"$SOLUTION\" --status $STATUS $REASON --tags learning" \
|
|
192
|
+
"Learning"
|
|
193
|
+
done
|
|
194
|
+
|
|
195
|
+
# ============================================
|
|
196
|
+
# RANDOM SEARCH SCENARIOS
|
|
197
|
+
# ============================================
|
|
198
|
+
echo ""
|
|
199
|
+
echo -e "${YELLOW}🔍 Random Search Scenarios${NC}"
|
|
200
|
+
|
|
201
|
+
# Random search terms
|
|
202
|
+
SEARCH_TERMS=("test" "random" "$(random_str 10)" "tag$(($RANDOM % 10))" "memory" "learning" "decision" "special" "unicode")
|
|
203
|
+
for term in "${SEARCH_TERMS[@]}"; do
|
|
204
|
+
LIMIT=$(($RANDOM % 20 + 1))
|
|
205
|
+
test_random "Search: '$term' (limit: $LIMIT)" \
|
|
206
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" search \"$term\" --limit $LIMIT" \
|
|
207
|
+
"Search"
|
|
208
|
+
done
|
|
209
|
+
|
|
210
|
+
# Random search with filters
|
|
211
|
+
for i in {1..5}; do
|
|
212
|
+
TAG="tag$(($RANDOM % 10))"
|
|
213
|
+
TYPE=$([ $(($RANDOM % 2)) -eq 0 ] && echo "memory" || echo "learning")
|
|
214
|
+
LIMIT=$(($RANDOM % 15 + 1))
|
|
215
|
+
DAYS=$(($RANDOM % 30 + 1))
|
|
216
|
+
|
|
217
|
+
FILTERS="--tag $TAG --type $TYPE --limit $LIMIT --since ${DAYS}d"
|
|
218
|
+
test_random "Search with filters (tag:$TAG, type:$TYPE, limit:$LIMIT, since:${DAYS}d)" \
|
|
219
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" search \"test\" $FILTERS" \
|
|
220
|
+
"Search"
|
|
221
|
+
done
|
|
222
|
+
|
|
223
|
+
# ============================================
|
|
224
|
+
# RANDOM CONTEXT SCENARIOS
|
|
225
|
+
# ============================================
|
|
226
|
+
echo ""
|
|
227
|
+
echo -e "${YELLOW}📋 Random Context Scenarios${NC}"
|
|
228
|
+
|
|
229
|
+
for i in {1..10}; do
|
|
230
|
+
LIMIT=$(($RANDOM % 30 + 1))
|
|
231
|
+
OPTIONS="--limit $LIMIT"
|
|
232
|
+
|
|
233
|
+
if [ $(($RANDOM % 2)) -eq 0 ]; then
|
|
234
|
+
TAG="tag$(($RANDOM % 10))"
|
|
235
|
+
OPTIONS="$OPTIONS --tag $TAG"
|
|
236
|
+
fi
|
|
237
|
+
|
|
238
|
+
if [ $(($RANDOM % 2)) -eq 0 ]; then
|
|
239
|
+
DAYS=$(($RANDOM % 30 + 1))
|
|
240
|
+
OPTIONS="$OPTIONS --since ${DAYS}d"
|
|
241
|
+
fi
|
|
242
|
+
|
|
243
|
+
test_random "Get context $i ($OPTIONS)" \
|
|
244
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" get-context $OPTIONS" \
|
|
245
|
+
"Context"
|
|
246
|
+
done
|
|
247
|
+
|
|
248
|
+
# ============================================
|
|
249
|
+
# RANDOM FILE OPERATIONS
|
|
250
|
+
# ============================================
|
|
251
|
+
echo ""
|
|
252
|
+
echo -e "${YELLOW}📁 Random File Operations${NC}"
|
|
253
|
+
|
|
254
|
+
# Create random files
|
|
255
|
+
for i in {1..5}; do
|
|
256
|
+
FILE="test_$(random_str 8).txt"
|
|
257
|
+
echo "Random content $i: $(random_str 50)" > "$FILE"
|
|
258
|
+
|
|
259
|
+
# Protect
|
|
260
|
+
if [ $(($RANDOM % 2)) -eq 0 ]; then
|
|
261
|
+
REASON="Protection reason: $(random_str 30)"
|
|
262
|
+
test_random "Protect file: $FILE" \
|
|
263
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" protect \"$FILE\" --reason \"$REASON\"" \
|
|
264
|
+
"FileOps"
|
|
265
|
+
fi
|
|
266
|
+
|
|
267
|
+
# Log change
|
|
268
|
+
ACTIONS=("created" "edited" "deleted")
|
|
269
|
+
ACTION=${ACTIONS[$RANDOM % ${#ACTIONS[@]}]}
|
|
270
|
+
CHANGE_REASON="Change $i: $(random_str 40)"
|
|
271
|
+
test_random "Log change: $FILE ($ACTION)" \
|
|
272
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" change \"$FILE\" \"$CHANGE_REASON\" --action $ACTION" \
|
|
273
|
+
"FileOps"
|
|
274
|
+
done
|
|
275
|
+
|
|
276
|
+
# List protected
|
|
277
|
+
test_random "List protected files" \
|
|
278
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" protected" \
|
|
279
|
+
"FileOps"
|
|
280
|
+
|
|
281
|
+
# ============================================
|
|
282
|
+
# RANDOM CODE STRUCTURE
|
|
283
|
+
# ============================================
|
|
284
|
+
echo ""
|
|
285
|
+
echo -e "${YELLOW}🌳 Random Code Structure${NC}"
|
|
286
|
+
|
|
287
|
+
# Create random TypeScript files
|
|
288
|
+
for i in {1..3}; do
|
|
289
|
+
FILE="test_$(random_str 6).ts"
|
|
290
|
+
cat > "$FILE" << EOF
|
|
291
|
+
import { something } from './other_$(random_str 5)';
|
|
292
|
+
export function test_$(random_str 8)() { return true; }
|
|
293
|
+
export class TestClass_$(random_str 6) {}
|
|
294
|
+
EOF
|
|
295
|
+
done
|
|
296
|
+
|
|
297
|
+
# Build graph
|
|
298
|
+
test_random "Build code graph" \
|
|
299
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" graph build --silent" \
|
|
300
|
+
"CodeStructure"
|
|
301
|
+
|
|
302
|
+
# Query random files
|
|
303
|
+
for file in *.ts; do
|
|
304
|
+
if [ -f "$file" ]; then
|
|
305
|
+
test_random "Query graph: $file" \
|
|
306
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" graph-query \"$file\" 2>&1 | head -10" \
|
|
307
|
+
"CodeStructure"
|
|
308
|
+
fi
|
|
309
|
+
done
|
|
310
|
+
|
|
311
|
+
# ============================================
|
|
312
|
+
# RANDOM QUALITY & VALIDATION
|
|
313
|
+
# ============================================
|
|
314
|
+
echo ""
|
|
315
|
+
echo -e "${YELLOW}⭐ Random Quality & Validation${NC}"
|
|
316
|
+
|
|
317
|
+
test_random "Quality validation" \
|
|
318
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" validate" \
|
|
319
|
+
"Quality"
|
|
320
|
+
|
|
321
|
+
# ============================================
|
|
322
|
+
# RANDOM TEMPLATES
|
|
323
|
+
# ============================================
|
|
324
|
+
echo ""
|
|
325
|
+
echo -e "${YELLOW}📋 Random Templates${NC}"
|
|
326
|
+
|
|
327
|
+
test_random "List templates" \
|
|
328
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" template list" \
|
|
329
|
+
"Templates"
|
|
330
|
+
|
|
331
|
+
TEMPLATES=("bugfix" "feature" "refactor" "decision")
|
|
332
|
+
for template in "${TEMPLATES[@]}"; do
|
|
333
|
+
test_random "Show template: $template" \
|
|
334
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" template show $template 2>&1 | head -5" \
|
|
335
|
+
"Templates"
|
|
336
|
+
done
|
|
337
|
+
|
|
338
|
+
# ============================================
|
|
339
|
+
# RANDOM EXPORT
|
|
340
|
+
# ============================================
|
|
341
|
+
echo ""
|
|
342
|
+
echo -e "${YELLOW}💾 Random Export${NC}"
|
|
343
|
+
|
|
344
|
+
for i in {1..3}; do
|
|
345
|
+
FORMAT=$([ $(($RANDOM % 2)) -eq 0 ] && echo "json" || echo "jsonl")
|
|
346
|
+
LIMIT=$(($RANDOM % 20 + 1))
|
|
347
|
+
test_random "Export $i ($FORMAT, limit: $LIMIT)" \
|
|
348
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" export --format $FORMAT --limit $LIMIT" \
|
|
349
|
+
"Export"
|
|
350
|
+
done
|
|
351
|
+
|
|
352
|
+
# ============================================
|
|
353
|
+
# RANDOM STATUS & DOCTOR
|
|
354
|
+
# ============================================
|
|
355
|
+
echo ""
|
|
356
|
+
echo -e "${YELLOW}🏥 Random Status & Doctor${NC}"
|
|
357
|
+
|
|
358
|
+
test_random "Status check" \
|
|
359
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" status" \
|
|
360
|
+
"Status"
|
|
361
|
+
|
|
362
|
+
test_random "Doctor check" \
|
|
363
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" doctor" \
|
|
364
|
+
"Status"
|
|
365
|
+
|
|
366
|
+
# ============================================
|
|
367
|
+
# RANDOM LIST OPERATIONS
|
|
368
|
+
# ============================================
|
|
369
|
+
echo ""
|
|
370
|
+
echo -e "${YELLOW}📋 Random List Operations${NC}"
|
|
371
|
+
|
|
372
|
+
for i in {1..3}; do
|
|
373
|
+
LIMIT=$(($RANDOM % 20 + 1))
|
|
374
|
+
test_random "List memories $i (limit: $LIMIT)" \
|
|
375
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" memories --limit $LIMIT 2>&1 | head -10" \
|
|
376
|
+
"List"
|
|
377
|
+
done
|
|
378
|
+
|
|
379
|
+
for i in {1..3}; do
|
|
380
|
+
LIMIT=$(($RANDOM % 15 + 1))
|
|
381
|
+
test_random "List learnings $i (limit: $LIMIT)" \
|
|
382
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" learnings --limit $LIMIT 2>&1 | head -10" \
|
|
383
|
+
"List"
|
|
384
|
+
done
|
|
385
|
+
|
|
386
|
+
for i in {1..3}; do
|
|
387
|
+
LIMIT=$(($RANDOM % 15 + 1))
|
|
388
|
+
test_random "List changes $i (limit: $LIMIT)" \
|
|
389
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" changes --limit $LIMIT 2>&1 | head -10" \
|
|
390
|
+
"List"
|
|
391
|
+
done
|
|
392
|
+
|
|
393
|
+
# ============================================
|
|
394
|
+
# RANDOM EDGE CASES
|
|
395
|
+
# ============================================
|
|
396
|
+
echo ""
|
|
397
|
+
echo -e "${YELLOW}⚠️ Random Edge Cases${NC}"
|
|
398
|
+
|
|
399
|
+
# Empty inputs (should fail gracefully)
|
|
400
|
+
test_random "Empty memory (validation)" \
|
|
401
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" memory \"\" 2>&1 | head -3" \
|
|
402
|
+
"EdgeCase"
|
|
403
|
+
|
|
404
|
+
# Very long inputs
|
|
405
|
+
LONG_MSG=$(for i in {1..100}; do echo -n "$(random_str 50) "; done)
|
|
406
|
+
test_random "Very long memory (100x50 chars)" \
|
|
407
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" memory \"$LONG_MSG\" --tags long --force" \
|
|
408
|
+
"EdgeCase"
|
|
409
|
+
|
|
410
|
+
# Many tags
|
|
411
|
+
MANY_TAGS=$(for i in {1..50}; do echo -n "tag$i"; [ $i -lt 50 ] && echo -n ","; done)
|
|
412
|
+
test_random "Many tags (50 tags)" \
|
|
413
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" memory \"Test with many tags\" --tags \"$MANY_TAGS\"" \
|
|
414
|
+
"EdgeCase"
|
|
415
|
+
|
|
416
|
+
# Invalid commands (should fail gracefully)
|
|
417
|
+
test_random "Invalid command (validation)" \
|
|
418
|
+
"npx tsx \"$OLDPWD/src/cli.ts\" invalid_command 2>&1 | head -3" \
|
|
419
|
+
"EdgeCase"
|
|
420
|
+
|
|
421
|
+
# ============================================
|
|
422
|
+
# RANDOM CONCURRENT OPERATIONS
|
|
423
|
+
# ============================================
|
|
424
|
+
echo ""
|
|
425
|
+
echo -e "${YELLOW}⚡ Random Concurrent Operations${NC}"
|
|
426
|
+
|
|
427
|
+
# Concurrent memory additions
|
|
428
|
+
test_random "Concurrent memory (5 parallel)" \
|
|
429
|
+
"for i in {1..5}; do npx tsx \"$OLDPWD/src/cli.ts\" memory \"Concurrent $i: $(random_str 20)\" --tags concurrent & done; wait" \
|
|
430
|
+
"Concurrent"
|
|
431
|
+
|
|
432
|
+
# Concurrent searches
|
|
433
|
+
test_random "Concurrent searches (3 parallel)" \
|
|
434
|
+
"for i in {1..3}; do npx tsx \"$OLDPWD/src/cli.ts\" search \"test\" --limit 2 & done; wait" \
|
|
435
|
+
"Concurrent"
|
|
436
|
+
|
|
437
|
+
# ============================================
|
|
438
|
+
# FINAL SUMMARY
|
|
439
|
+
# ============================================
|
|
440
|
+
echo ""
|
|
441
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
442
|
+
echo "📊 FINAL TEST RESULTS"
|
|
443
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
444
|
+
echo ""
|
|
445
|
+
echo -e "${GREEN}✅ PASSED: $PASSED${NC}"
|
|
446
|
+
echo -e "${RED}❌ FAILED: $FAILED${NC}"
|
|
447
|
+
echo -e "${BLUE}📊 TOTAL: $TOTAL${NC}"
|
|
448
|
+
echo ""
|
|
449
|
+
|
|
450
|
+
if [ ${#BROKEN_FEATURES[@]} -gt 0 ]; then
|
|
451
|
+
echo -e "${RED}⚠️ BROKEN FEATURES FOUND:${NC}"
|
|
452
|
+
for feature in "${BROKEN_FEATURES[@]}"; do
|
|
453
|
+
echo " - $feature"
|
|
454
|
+
done
|
|
455
|
+
echo ""
|
|
456
|
+
fi
|
|
457
|
+
|
|
458
|
+
# Cleanup
|
|
459
|
+
rm -rf "$TEST_BASE"
|
|
460
|
+
rm -f /tmp/aggressive_test_$$.log
|
|
461
|
+
|
|
462
|
+
if [ $FAILED -eq 0 ]; then
|
|
463
|
+
echo -e "${GREEN}🎯 RESULT: 100% PASS RATE ✅${NC}"
|
|
464
|
+
echo ""
|
|
465
|
+
echo "No broken parts found! MemoryLink handles all random scenarios correctly."
|
|
466
|
+
exit 0
|
|
467
|
+
else
|
|
468
|
+
FAIL_RATE=$(echo "scale=2; $FAILED * 100 / $TOTAL" | bc 2>/dev/null || echo "0")
|
|
469
|
+
echo -e "${RED}⚠️ RESULT: $FAIL_RATE% FAILURE RATE${NC}"
|
|
470
|
+
echo ""
|
|
471
|
+
echo "Some features may need attention. Review failures above."
|
|
472
|
+
exit 1
|
|
473
|
+
fi
|
|
474
|
+
|