@app.get("/api/v1/test_status/{test_id}") async def get_test_status(test_id: str): """Get test progress and results""" return get_test_results(test_id)
def export_to_csv(self, filename: str): """Export raw data to CSV""" df = pd.DataFrame(self.results['raw_data']) df.to_csv(filename, index=False)
@app.post("/api/v1/start_test") async def start_test(config: TestConfig, background_tasks: BackgroundTasks): """Start a network test""" test_id = generate_test_id() background_tasks.add_task(run_network_test, test_id, config) return {"test_id": test_id, "status": "started"}
def create_latency_chart(self): return go.Figure( data=[go.Scatter(y=list(self.latency_data), mode='lines+markers')], layout=go.Layout(title="Network Latency Over Time") ) # distributed.py import redis import json from typing import List, Dict from multiprocessing import Pool import asyncio class DistributedTester: def init (self, redis_host='localhost', redis_port=6379): self.redis_client = redis.Redis(host=redis_host, port=redis_port) self.test_nodes = []