mirror of
https://github.com/blackboxprogramming/BlackRoad-Operating-System.git
synced 2026-03-17 03:57:13 -05:00
Implements complete Phase 2 scaffold across 6 core modules: ## New Modules ### 1. Backend API Enhancements - Add system router with /version, /config/public, /os/state endpoints - Register system router in main.py - Add comprehensive tests for system endpoints ### 2. Core OS Runtime (core_os/) - Implement UserSession, Window, OSState models - Add state management functions (open_window, close_window, etc.) - Create Backend API adapter for communication - Include full test suite for models and state ### 3. Operator Engine (operator_engine/) - Build job registry with example jobs - Implement simple scheduler with lifecycle management - Optional HTTP server on port 8001 - Complete tests for jobs and scheduler ### 4. Web Client Enhancements - Add CoreOSClient JavaScript class - Integrate system API endpoints - Event-driven architecture for state updates - Zero dependencies, vanilla JavaScript ### 5. Prism Console (prism-console/) - Modern dark-themed admin UI - Multi-tab navigation (Overview, Jobs, Agents, Logs, System) - Real-time metrics dashboard - Backend API integration with auto-refresh ### 6. Documentation (codex-docs/) - Complete MkDocs-based documentation - Architecture guides and component docs - Infrastructure setup guides - API reference documentation ## CI/CD - Add core-os-tests.yml workflow - Add operator-tests.yml workflow - Add docs-build.yml workflow ## Documentation - Create BLACKROAD_OS_REPO_MAP.md cross-reference - Add README for each module - Comprehensive integration documentation ## Summary - 37 new files created - ~3,500 lines of new code - 5 test suites with 15+ tests - 3 new CI workflows - 10+ documentation pages All modules are minimal working skeletons ready for integration. Designed to be extracted into separate repos if needed. Phase 2 scaffold complete and ready for review.
46 lines
1.2 KiB
Python
46 lines
1.2 KiB
Python
"""Tests for scheduler"""
|
|
import pytest
|
|
from operator_engine.scheduler import Scheduler
|
|
from operator_engine.jobs import Job, JobStatus, job_registry
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_scheduler_status():
|
|
"""Test getting scheduler status"""
|
|
scheduler = Scheduler()
|
|
status = scheduler.get_status()
|
|
|
|
assert "running" in status
|
|
assert "total_jobs" in status
|
|
assert "pending_jobs" in status
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_execute_job():
|
|
"""Test executing a single job"""
|
|
scheduler = Scheduler()
|
|
|
|
# Add a test job
|
|
test_job = Job(name="Test Execution Job")
|
|
job_registry.add_job(test_job)
|
|
|
|
# Execute the job
|
|
result = await scheduler.execute_job(test_job.id)
|
|
|
|
assert result is not None
|
|
# After execution, job should be completed (in stub mode)
|
|
assert result.status == JobStatus.COMPLETED
|
|
assert result.started_at is not None
|
|
assert result.completed_at is not None
|
|
|
|
# Clean up
|
|
job_registry.remove_job(test_job.id)
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_execute_nonexistent_job():
|
|
"""Test executing a job that doesn't exist"""
|
|
scheduler = Scheduler()
|
|
result = await scheduler.execute_job("nonexistent-id")
|
|
assert result is None
|