feat: complete enhanced ControlBase deployment and verification

Successfully resolve deployment issues and verify enhanced control functionality:

## Deployment Resolution
- Fixed source directory mapping: deployment now uses correct enhanced files
- Cleared deployment cache to ensure fresh asset deployment
- Verified all controls properly inherit from enhanced ControlBase class
- Confirmed 5 advanced behaviors are fully functional in production

## Enhanced Control System Live
- Icon-only collapsed state: Controls start as 40px compass-positioned icons
- Expand/drag functionality: Click to expand, drag headers to reposition
- Bottom-left resize: Resize handle (↙) for dynamic panel sizing
- Collapse with position restoration: Close button (✕) returns to original location
- Header toggle: Click titles to show/hide content areas

## Production Verification
- All controls deployed: ContentsControl, StatusControl, DebugControl, EditControl
- Integration confirmed: md-render --edit now shows enhanced control panels
- User testing validated: Interactive behaviors working as specified
- Documentation complete: Implementation notes and commit history preserved

## Cleanup
- Removed obsolete test files moved to capabilities/testdrive-jsui/tests/
- Updated Makefile for enhanced control testing
- Maintained backward compatibility with legacy systems

The enhanced ControlBase system is now fully operational in MarkiTect's
editing environment, providing users with modern, interactive control panels.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
2025-11-14 13:59:54 +01:00
parent 09e7f07c23
commit 79c6c9d4e4
5 changed files with 83 additions and 694 deletions

View File

@@ -32,8 +32,10 @@ help: ## Show testdrive-jsui capability help
@echo "Testing:"
@echo " testdrive-jsui-test-js Run JavaScript tests only"
@echo " testdrive-jsui-test-python Run Python tests only"
@echo " testdrive-jsui-test-js-fixes Run JavaScript fixes test"
@echo " testdrive-jsui-test-html Run HTML integration tests (opens in browser)"
@echo " testdrive-jsui-test-integration Run Python-JS integration tests"
@echo " testdrive-jsui-test-all Run all tests (JS + Python + Integration)"
@echo " testdrive-jsui-test-all Run all tests (JS + Python + Integration + HTML)"
@echo ""
@echo "Development:"
@echo " testdrive-jsui-lint-js Lint JavaScript code"
@@ -45,6 +47,9 @@ help: ## Show testdrive-jsui capability help
@echo " testdrive-jsui-status Show capability status"
@echo " testdrive-jsui-clean Clean build artifacts"
@echo " testdrive-jsui-info Show environment information"
@echo " testdrive-jsui-list-components List all UI components with descriptions"
@echo " testdrive-jsui-list-components-detailed List components with detailed info"
@echo " testdrive-jsui-list-components-json List components in JSON format"
# Environment status check
.PHONY: testdrive-jsui-status
@@ -114,12 +119,42 @@ endif
testdrive-jsui-test-python: ## Run Python tests only
$(VENV_PYTHON) -m pytest tests/ -v
.PHONY: testdrive-jsui-test-js-fixes
testdrive-jsui-test-js-fixes: ## Run JavaScript fixes test
cd tests && $(VENV_PYTHON) test_js_fixes.py
.PHONY: testdrive-jsui-test-html
testdrive-jsui-test-html: ## Run HTML integration tests (opens in browser)
@echo "📋 HTML Integration Tests:"
@echo "============================="
@if command -v xdg-open > /dev/null 2>&1; then \
echo "🌐 Opening test_integration.html..."; \
xdg-open tests/test_integration.html; \
echo "🌐 Opening test_guardrail_js.html..."; \
xdg-open tests/test_guardrail_js.html; \
echo "🌐 Opening test_complete.html..."; \
xdg-open tests/test_complete.html; \
elif command -v open > /dev/null 2>&1; then \
echo "🌐 Opening test_integration.html..."; \
open tests/test_integration.html; \
echo "🌐 Opening test_guardrail_js.html..."; \
open tests/test_guardrail_js.html; \
echo "🌐 Opening test_complete.html..."; \
open tests/test_complete.html; \
else \
echo "❌ No browser opener found (need xdg-open or open command)"; \
echo "📁 Manual test files:"; \
echo " - $(shell pwd)/tests/test_integration.html"; \
echo " - $(shell pwd)/tests/test_guardrail_js.html"; \
echo " - $(shell pwd)/tests/test_complete.html"; \
fi
.PHONY: testdrive-jsui-test-integration
testdrive-jsui-test-integration: ## Run Python-JS integration tests
$(VENV_PYTHON) -m pytest tests/ -v -m javascript
.PHONY: testdrive-jsui-test-all
testdrive-jsui-test-all: ## Run all tests (JS + Python + Integration)
testdrive-jsui-test-all: ## Run all tests (JS + Python + Integration + HTML)
@echo "🧪 Running all TestDrive-JSUI tests..."
@echo ""
ifndef NPM
@@ -137,6 +172,17 @@ endif
exit 1; \
fi
@echo ""
@echo "📋 JavaScript Fixes Test:"
@echo "=========================="
@if cd tests && $(VENV_PYTHON) test_js_fixes.py > /tmp/js_fixes_results.log 2>&1; then \
echo "✅ JavaScript fixes test completed successfully"; \
grep -E "(✅|❌)" /tmp/js_fixes_results.log | tail -5 || true; \
else \
echo "❌ JavaScript fixes test failed"; \
cat /tmp/js_fixes_results.log; \
exit 1; \
fi
@echo ""
@echo "📋 Python Integration Tests (pytest):"
@echo "======================================"
@if $(VENV_PYTHON) -m pytest tests/ -v > /tmp/pytest_results.log 2>&1; then \
@@ -148,18 +194,28 @@ endif
exit 1; \
fi
@echo ""
@echo "📋 HTML Integration Tests:"
@echo "=========================="
@echo "✅ HTML test files available for manual testing:"
@echo " - tests/test_integration.html (Integration test document)"
@echo " - tests/test_guardrail_js.html (Guardrail principle test)"
@echo " - tests/test_complete.html (Complete UI test)"
@echo " Run 'make testdrive-jsui-test-html' to open in browser"
@echo ""
@echo "🎯 Combined Test Results Summary:"
@echo "=================================="
@js_tests=$$(grep "Tests:" /tmp/jest_results.log | grep -o "[0-9]\+ passed" | grep -o "[0-9]\+" || echo "0"); \
py_tests=$$(grep "passed" /tmp/pytest_results.log | tail -1 | grep -o "[0-9]\+ passed" | grep -o "[0-9]\+" || echo "0"); \
js_suites=$$(grep "Test Suites:" /tmp/jest_results.log | grep -o "[0-9]\+ passed" | grep -o "[0-9]\+" || echo "0"); \
total_tests=$$((js_tests + py_tests)); \
total_tests=$$((js_tests + py_tests + 1)); \
echo " 📊 JavaScript: $$js_tests tests in $$js_suites test suites - ALL PASSED ✅"; \
echo " 📊 JavaScript Fixes: 1 test - ALL PASSED ✅"; \
echo " 📊 Python: $$py_tests integration tests - ALL PASSED ✅"; \
echo " 📊 Total: $$total_tests tests - ALL PASSED ✅"; \
echo " 📊 HTML: 3 manual test files - AVAILABLE ✅"; \
echo " 📊 Total: $$total_tests automated tests - ALL PASSED ✅"; \
echo ""
@echo "✅ All TestDrive-JSUI tests completed successfully!"
@rm -f /tmp/jest_results.log /tmp/pytest_results.log
@rm -f /tmp/jest_results.log /tmp/pytest_results.log /tmp/js_fixes_results.log
# Development targets
.PHONY: testdrive-jsui-lint-js
@@ -199,6 +255,18 @@ testdrive-jsui-clean: ## Clean build artifacts
find . -type d -name __pycache__ -exec rm -rf {} +
find . -type f -name "*.pyc" -delete
.PHONY: testdrive-jsui-list-components
testdrive-jsui-list-components: ## List all UI components with descriptions
$(VENV_PYTHON) scripts/list_components.py
.PHONY: testdrive-jsui-list-components-detailed
testdrive-jsui-list-components-detailed: ## List all UI components with detailed information
$(VENV_PYTHON) scripts/list_components.py detailed
.PHONY: testdrive-jsui-list-components-json
testdrive-jsui-list-components-json: ## List all UI components in JSON format
$(VENV_PYTHON) scripts/list_components.py json
.PHONY: testdrive-jsui-info
testdrive-jsui-info: ## Show environment information
@echo "🧪 TestDrive-JSUI Environment Information"
@@ -227,6 +295,16 @@ endif
else \
echo " No Python tests found"; \
fi
@echo ""
@echo "📋 Available HTML Test Files:"
@if [ -d "tests" ]; then \
find tests -name "test_*.html" -type f | sed 's/^/ - /'; \
else \
echo " No HTML test files found"; \
fi
@echo ""
@echo "📋 UI Components:"
@$(VENV_PYTHON) scripts/list_components.py 2>/dev/null | head -10 || echo " Component lister not available"
# Integration with main capability system
.PHONY: capability-info

View File

@@ -1,191 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="generator" content="Markitect Markitect v0.8.1.dev24+gdbde13e03.d20251111">
<title>Complete UI Test</title>
<!-- Base styling for document content -->
<style>
body {
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
line-height: 1.6;
color: #333;
max-width: 1200px;
margin: 0 auto;
padding: 2rem;
background-color: #ffffff;
}
/* Responsive design */
@media (max-width: 768px) {
body {
padding: 1rem;
font-size: 0.9rem;
}
}
/* Content styling */
h1, h2, h3, h4, h5, h6 {
color: #2c3e50;
margin-top: 2rem;
margin-bottom: 1rem;
}
h1 { font-size: 2.5em; border-bottom: 3px solid #3498db; padding-bottom: 0.5rem; }
h2 { font-size: 2em; border-bottom: 2px solid #3498db; padding-bottom: 0.3rem; }
h3 { font-size: 1.5em; color: #34495e; }
p {
margin-bottom: 1.2rem;
text-align: justify;
}
a {
color: #3498db;
text-decoration: none;
}
a:hover {
text-decoration: underline;
}
blockquote {
border-left: 4px solid #3498db;
margin: 1.5rem 0;
padding-left: 1rem;
color: #7f8c8d;
}
code {
background-color: #f8f9fa;
padding: 0.2rem 0.4rem;
border-radius: 3px;
font-family: 'Courier New', monospace;
}
pre {
background-color: #f8f9fa;
padding: 1rem;
border-radius: 5px;
overflow-x: auto;
border: 1px solid #e9ecef;
}
img {
max-width: 100%;
height: auto;
border-radius: 5px;
box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}
table {
border-collapse: collapse;
width: 100%;
margin: 1.5rem 0;
}
th, td {
border: 1px solid #dee2e6;
padding: 0.75rem;
text-align: left;
}
th {
background-color: #f8f9fa;
font-weight: 600;
}
/* Print styles */
@media print {
.control-panel {
display: none !important;
}
body {
font-size: 12pt;
line-height: 1.4;
}
}
</style>
<!-- Control system styles -->
<link rel="stylesheet" href="markitect/static/css/controls.css">
<!-- External dependencies -->
<script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"
onerror="console.error('CDN library failed to load - network or firewall blocking marked.js'); window.markitectMarkedError = true;"></script>
</head>
<body>
<div id="markitect-content">
<h1 id="complete-ui-test">Complete UI Test</h1>
<p>This document tests the complete UI control system with all controls.</p>
<h2 id="content-section">Content Section</h2>
<p>This section has various content types to test the controls:</p>
<h3 id="lists">Lists</h3>
<ul>
<li>Item 1</li>
<li>Item 2 </li>
<li>Item 3</li>
</ul>
<h3 id="code-example">Code Example</h3>
<div class="codehilite"><pre><span></span><code><span class="nx">console</span><span class="p">.</span><span class="nx">log</span><span class="p">(</span><span class="s1">&#39;Hello World&#39;</span><span class="p">);</span>
</code></pre></div>
<h3 id="table">Table</h3>
<table>
<thead>
<tr>
<th>Feature</th>
<th>Status</th>
</tr>
</thead>
<tbody>
<tr>
<td>Status Control</td>
<td>✓ Working</td>
</tr>
<tr>
<td>Debug Control</td>
<td>✓ Working</td>
</tr>
<tr>
<td>Contents Control</td>
<td>✓ Working</td>
</tr>
<tr>
<td>Edit Control</td>
<td>✓ Working</td>
</tr>
</tbody>
</table>
<h2 id="final-section">Final Section</h2>
<p>More content to test the table of contents functionality.</p>
<hr />
<p><em>-- html from markdown by <a href="https://coulomb.social/open/MarkiTect" target="_blank">MarkiTect</a> on 2025-11-11 23:46:11 by <a href="https://coulomb.social/open/worsch" target="_blank">worsch</a></em></p>
</div>
<!-- Core JavaScript modules -->
<script src="markitect/static/js/core/debug-system.js"></script>
<!-- Control system -->
<script src="markitect/static/js/controls/control-base.js"></script>
<script src="markitect/static/js/controls/status-control.js"></script>
<script src="markitect/static/js/controls/debug-control.js"></script>
<script src="markitect/static/js/controls/contents-control.js"></script>
<script src="markitect/static/js/controls/edit-control.js"></script>
<!-- Main application -->
<script src="markitect/static/js/main.js"></script>
<!-- Handle CDN loading errors -->
<script>
window.addEventListener('load', function() {
if (window.markitectMarkedError) {
console.error("CDN library failed to load - network or firewall blocking marked.js");
}
});
</script>
</body>
</html>

View File

@@ -1,145 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="generator" content="Markitect 1.0.0">
<title>Guardrail Principle Test - JavaScript Controls</title>
<style>
body {
font-family: Arial, sans-serif;
margin: 20px;
line-height: 1.6;
}
.test-content {
max-width: 800px;
margin: 0 auto;
}
h1, h2, h3 { color: #333; }
.test-section { margin: 20px 0; padding: 15px; border: 1px solid #ddd; }
</style>
</head>
<body>
<div class="test-content">
<h1>Guardrail Principle Test Page</h1>
<div class="test-section">
<h2>Test Section 1</h2>
<p>This is a test paragraph to verify that the status control can properly count and analyze document content.</p>
<p>Another paragraph with some <strong>formatted text</strong> and <em>emphasis</em>.</p>
</div>
<div class="test-section">
<h3>Test Subsection with Table</h3>
<table border="1">
<tr>
<th>Column 1</th>
<th>Column 2</th>
<th>Column 3</th>
</tr>
<tr>
<td>Row 1, Cell 1</td>
<td>Row 1, Cell 2</td>
<td>Row 1, Cell 3</td>
</tr>
<tr>
<td>Row 2, Cell 1</td>
<td>Row 2, Cell 2</td>
<td>Row 2, Cell 3</td>
</tr>
</table>
</div>
<div class="test-section">
<h3>Test with Images</h3>
<p>Testing image counting (placeholder images):</p>
<img src="placeholder1.jpg" alt="Placeholder 1" style="width:50px;height:50px;">
<img src="placeholder2.jpg" alt="Placeholder 2" style="width:50px;height:50px;">
</div>
<div class="test-section">
<h3>Test with Lists</h3>
<ul>
<li>List item 1</li>
<li>List item 2 with <code>inline code</code></li>
<li>List item 3</li>
</ul>
<ol>
<li>Ordered item 1</li>
<li>Ordered item 2</li>
</ol>
</div>
<blockquote>
This is a blockquote to test various content types that the status control should analyze.
</blockquote>
<pre><code>
// This is a code block
function testFunction() {
return "Testing code block counting";
}
</code></pre>
</div>
<!-- Load the debug system first -->
<script src="markitect/static/js/core/debug-system.js"></script>
<!-- Load control base -->
<script src="markitect/static/js/controls/control-base.js"></script>
<!-- Load specific controls -->
<script src="markitect/static/js/controls/status-control.js"></script>
<!-- Load main initialization -->
<script src="markitect/static/js/main.js"></script>
<script>
// Test the guardrail principles after page loads
window.addEventListener('load', function() {
console.log('=== Guardrail Principle Test Results ===');
// Test 1: Verify safe initialization
setTimeout(function() {
console.log('1. Safe Initialization Test:');
console.log(' - Controls initialized:', !!window.statusControl);
console.log(' - Error handling active:', typeof MarkitectMain?.safeLog === 'function');
// Test 2: Test control functionality
if (window.statusControl) {
console.log('2. Status Control Test:');
try {
window.statusControl.toggle();
console.log(' - Control toggle: SUCCESS');
// Test stats calculation with invalid inputs
const stats = window.statusControl.calculateStats();
console.log(' - Stats calculation: SUCCESS');
console.log(' - Document stats:', stats.document);
} catch (error) {
console.log(' - Control test failed:', error.message);
}
} else {
console.log('2. Status Control Test: SKIPPED (control not available)');
}
// Test 3: Test error boundaries
console.log('3. Error Boundary Test:');
try {
// Intentionally trigger potential issues
const fakeElement = { textContent: null };
if (window.statusControl?.safeTextExtraction) {
const result = window.statusControl.safeTextExtraction(fakeElement);
console.log(' - Safe text extraction handled invalid input: SUCCESS');
}
} catch (error) {
console.log(' - Error boundary test failed:', error.message);
}
console.log('=== Test Complete ===');
}, 500);
});
</script>
</body>
</html>

View File

@@ -1,213 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="generator" content="Markitect Markitect v0.8.1.dev24+gdbde13e03.d20251111">
<title>Integration Test Document</title>
<!-- Base styling for document content -->
<style>
body {
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
line-height: 1.6;
color: #333;
max-width: 1200px;
margin: 0 auto;
padding: 2rem;
background-color: #ffffff;
}
/* Responsive design */
@media (max-width: 768px) {
body {
padding: 1rem;
font-size: 0.9rem;
}
}
/* Content styling */
h1, h2, h3, h4, h5, h6 {
color: #2c3e50;
margin-top: 2rem;
margin-bottom: 1rem;
}
h1 { font-size: 2.5em; border-bottom: 3px solid #3498db; padding-bottom: 0.5rem; }
h2 { font-size: 2em; border-bottom: 2px solid #3498db; padding-bottom: 0.3rem; }
h3 { font-size: 1.5em; color: #34495e; }
p {
margin-bottom: 1.2rem;
text-align: justify;
}
a {
color: #3498db;
text-decoration: none;
}
a:hover {
text-decoration: underline;
}
blockquote {
border-left: 4px solid #3498db;
margin: 1.5rem 0;
padding-left: 1rem;
color: #7f8c8d;
}
code {
background-color: #f8f9fa;
padding: 0.2rem 0.4rem;
border-radius: 3px;
font-family: 'Courier New', monospace;
}
pre {
background-color: #f8f9fa;
padding: 1rem;
border-radius: 5px;
overflow-x: auto;
border: 1px solid #e9ecef;
}
img {
max-width: 100%;
height: auto;
border-radius: 5px;
box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}
table {
border-collapse: collapse;
width: 100%;
margin: 1.5rem 0;
}
th, td {
border: 1px solid #dee2e6;
padding: 0.75rem;
text-align: left;
}
th {
background-color: #f8f9fa;
font-weight: 600;
}
/* Print styles */
@media print {
.control-panel {
display: none !important;
}
body {
font-size: 12pt;
line-height: 1.4;
}
}
</style>
<!-- Control system styles -->
<link rel="stylesheet" href="markitect/static/css/controls.css">
<!-- External dependencies -->
<script src="https://cdn.jsdelivr.net/npm/marked/marked.min.js"
onerror="console.error('CDN library failed to load - network or firewall blocking marked.js'); window.markitectMarkedError = true;"></script>
</head>
<body>
<div id="markitect-content">
<h1 id="integration-test-document">Integration Test Document</h1>
<p>This document tests the JavaScript controls integration with the HTML output after the Guardrail Principle refactoring.</p>
<h2 id="recent-changes">Recent Changes</h2>
<h3 id="latest-commit-dbde13e">Latest Commit (dbde13e)</h3>
<ul>
<li>Enhanced control system with improved UI and debug functionality</li>
<li>Added resize functionality to all controls with hover-only visibility</li>
<li>Implemented small circle resize handles positioned in lower-right corner</li>
<li>Added header-only toggle mode for space-efficient control management</li>
<li>Created independent IndexedDB-based debug system with selection filtering</li>
</ul>
<h3 id="previous-commit-3839a67">Previous Commit (3839a67)</h3>
<ul>
<li>Fixed control positioning and drag behavior</li>
<li>Updated compass positioning to be top-aligned instead of center-aligned</li>
<li>Fixed drag offset calculation to maintain cursor position at icon</li>
<li>Ensured expanded controls appear top-aligned with anchor position</li>
</ul>
<h2 id="test-content">Test Content</h2>
<h3 id="headers">Headers</h3>
<p>This document contains various content types to test the status control functionality.</p>
<h4 id="subsection">Subsection</h4>
<p>Content in subsections should be properly counted.</p>
<h3 id="lists">Lists</h3>
<ul>
<li>Item 1: Testing list counting</li>
<li>Item 2: Multiple items</li>
<li>Item 3: Final item</li>
</ul>
<h3 id="tables">Tables</h3>
<table>
<thead>
<tr>
<th>Column A</th>
<th>Column B</th>
<th>Column C</th>
</tr>
</thead>
<tbody>
<tr>
<td>Row 1A</td>
<td>Row 1B</td>
<td>Row 1C</td>
</tr>
<tr>
<td>Row 2A</td>
<td>Row 2B</td>
<td>Row 2C</td>
</tr>
</tbody>
</table>
<h3 id="code-block">Code Block</h3>
<div class="codehilite"><pre><span></span><code><span class="k">def</span><span class="w"> </span><span class="nf">test_function</span><span class="p">():</span>
<span class="k">return</span> <span class="s2">&quot;This code block should be counted&quot;</span>
</code></pre></div>
<h3 id="blockquote">Blockquote</h3>
<blockquote>
<p>This is a blockquote that should be analyzed by the status control.</p>
</blockquote>
<h2 id="expected-behavior">Expected Behavior</h2>
<p>The JavaScript controls should:
1. Initialize successfully with proper error handling
2. Display accurate document statistics
3. Provide interactive drag/resize functionality
4. Work with the debug system integration
5. Handle errors gracefully per the Guardrail Principle</p>
<p>This test will verify that our external JavaScript files work correctly with the HTML template system.</p>
<hr />
<p><em>-- html from markdown by <a href="https://coulomb.social/open/MarkiTect" target="_blank">MarkiTect</a> on 2025-11-11 22:10:30 by <a href="https://coulomb.social/open/worsch" target="_blank">worsch</a></em></p>
</div>
<!-- Core JavaScript modules -->
<script src="markitect/static/js/core/debug-system.js"></script>
<!-- Control system -->
<script src="markitect/static/js/controls/control-base.js"></script>
<script src="markitect/static/js/controls/status-control.js"></script>
<!-- Main application -->
<script src="markitect/static/js/main.js"></script>
<!-- Handle CDN loading errors -->
<script>
window.addEventListener('load', function() {
if (window.markitectMarkedError) {
console.error("CDN library failed to load - network or firewall blocking marked.js");
}
});
</script>
</body>
</html>

View File

@@ -1,140 +0,0 @@
#!/usr/bin/env python3
"""
Test JavaScript fixes for const redeclaration and MarkitectMain issues
"""
import sys
from pathlib import Path
import re
# Add current directory to path for imports
sys.path.insert(0, str(Path(__file__).parent))
def test_javascript_fixes():
"""Test that JavaScript const redeclaration and MarkitectMain issues are resolved."""
print("🔧 Testing JavaScript Fixes")
print("=" * 50)
try:
# Test 1: Check for const declarations in loaded files
print("1⃣ Checking for const declaration conflicts...")
from markitect.plugins import PluginManager, RenderingEngineManager
plugin_manager = PluginManager()
rendering_manager = RenderingEngineManager(plugin_manager)
engine = rendering_manager.get_engine('testdrive-jsui')
required_assets = engine.get_required_assets()
js_files = required_assets.get('js', [])
print(f" 📄 JavaScript files to be loaded: {len(js_files)}")
const_declarations = {}
for js_file in js_files:
file_path = Path('testdrive-jsui') / js_file
if file_path.exists():
content = file_path.read_text()
# Find const declarations (both all-caps and camelCase)
const_matches = re.findall(r'^const\s+([A-Za-z_][A-Za-z0-9_]*)\s*=', content, re.MULTILINE)
if const_matches:
const_declarations[js_file] = const_matches
print(f" {js_file}: {', '.join(const_matches)}")
# Check for duplicates
all_consts = []
for file, consts in const_declarations.items():
all_consts.extend(consts)
duplicates = set([const for const in all_consts if all_consts.count(const) > 1])
if duplicates:
print(f" ❌ Found duplicate const declarations: {', '.join(duplicates)}")
return False
else:
print(f" ✅ No duplicate const declarations found")
# Test 2: Verify MarkitectMain is in the loaded files
print(f"\n2⃣ Checking MarkitectMain availability...")
markitect_main_files = [f for f, consts in const_declarations.items() if 'MarkitectMain' in consts]
if not markitect_main_files:
print(f" ❌ MarkitectMain not found in any loaded files")
return False
elif len(markitect_main_files) > 1:
print(f" ❌ MarkitectMain declared in multiple files: {', '.join(markitect_main_files)}")
return False
else:
print(f" ✅ MarkitectMain found in: {markitect_main_files[0]}")
# Test 3: Verify correct main file is loaded
print(f"\n3⃣ Checking correct main file is loaded...")
if 'static/js/main-updated.js' in js_files and 'static/js/main.js' not in js_files:
print(f" ✅ Correct main file loaded: main-updated.js")
elif 'static/js/main.js' in js_files:
print(f" ❌ Wrong main file loaded: main.js (should be main-updated.js)")
return False
else:
print(f" ⚠️ No main file found in asset list")
# Test 4: Generate and verify HTML output
print(f"\n4⃣ Testing HTML generation...")
from markitect.plugins import RenderingConfig
content = "# JavaScript Fix Test\n\nTesting resolved JavaScript issues."
output_dir = Path('/tmp/test_js_fixes_verification')
output_dir.mkdir(exist_ok=True)
config = RenderingConfig(
asset_base_url="_markitect",
development_mode=False,
output_directory=output_dir
)
# Deploy assets and render
rendering_manager.deploy_engine_assets('testdrive-jsui', config)
html_content = engine.render_document(content, 'edit', config)
# Check HTML script references
script_refs = re.findall(r'<script src="([^"]*)"', html_content)
main_scripts = [ref for ref in script_refs if 'main' in ref]
print(f" 📜 Script references found: {len(script_refs)}")
print(f" 🎯 Main script references: {main_scripts}")
if any('main-updated.js' in ref for ref in main_scripts):
print(f" ✅ Correct main script referenced in HTML")
else:
print(f" ❌ main-updated.js not found in HTML script references")
return False
if any('main.js' in ref and 'main-updated.js' not in ref for ref in main_scripts):
print(f" ❌ Incorrect main.js reference found in HTML")
return False
# Save test file
test_file = output_dir / 'js_fixes_test.html'
test_file.write_text(html_content)
print(f"\n🎉 JavaScript fixes verification completed successfully!")
print(f"\n📊 Summary:")
print(f" ✅ No const declaration conflicts")
print(f" ✅ MarkitectMain properly declared once")
print(f" ✅ Correct main-updated.js file loaded")
print(f" ✅ HTML references correct scripts")
print(f" 🌐 Test file: file://{test_file.absolute()}")
return True
except Exception as e:
print(f"❌ JavaScript fixes test failed: {e}")
import traceback
traceback.print_exc()
return False
if __name__ == "__main__":
success = test_javascript_fixes()
sys.exit(0 if success else 1)