feat: add ecc2 dashboard session deletion controls

This commit is contained in:
Affaan Mustafa
2026-04-07 11:56:07 -07:00
parent 52fc93180b
commit e923c60bee
4 changed files with 131 additions and 1 deletions

View File

@@ -42,6 +42,7 @@ pub async fn run(db: StateStore, cfg: Config) -> Result<()> {
(_, KeyCode::Char('s')) => dashboard.stop_selected().await,
(_, KeyCode::Char('u')) => dashboard.resume_selected().await,
(_, KeyCode::Char('x')) => dashboard.cleanup_selected_worktree().await,
(_, KeyCode::Char('d')) => dashboard.delete_selected_session().await,
(_, KeyCode::Char('r')) => dashboard.refresh(),
(_, KeyCode::Char('?')) => dashboard.toggle_help(),
_ => {}

View File

@@ -349,7 +349,7 @@ impl Dashboard {
fn render_status_bar(&self, frame: &mut Frame, area: Rect) {
let text = format!(
" [n]ew session [s]top [u]resume [x]cleanup [r]efresh [Tab] switch pane [j/k] scroll [+/-] resize [{}] layout [?] help [q]uit ",
" [n]ew session [s]top [u]resume [x]cleanup [d]elete [r]efresh [Tab] switch pane [j/k] scroll [+/-] resize [{}] layout [?] help [q]uit ",
self.layout_label()
);
let aggregate = self.aggregate_usage();
@@ -392,6 +392,7 @@ impl Dashboard {
" s Stop selected session",
" u Resume selected session",
" x Cleanup selected worktree",
" d Delete selected inactive session",
" Tab Next pane",
" S-Tab Previous pane",
" j/↓ Scroll down",
@@ -575,6 +576,19 @@ impl Dashboard {
self.refresh();
}
pub async fn delete_selected_session(&mut self) {
let Some(session) = self.sessions.get(self.selected_session) else {
return;
};
if let Err(error) = manager::delete_session(&self.db, &session.id).await {
tracing::warn!("Failed to delete session {}: {error}", session.id);
return;
}
self.refresh();
}
pub fn refresh(&mut self) {
self.sync_from_store();
}
@@ -1503,6 +1517,34 @@ mod tests {
Ok(())
}
#[tokio::test]
async fn delete_selected_session_removes_inactive_session() -> Result<()> {
let db_path = std::env::temp_dir().join(format!("ecc2-dashboard-{}.db", Uuid::new_v4()));
let db = StateStore::open(&db_path)?;
let now = Utc::now();
db.insert_session(&Session {
id: "done-1".to_string(),
task: "delete me".to_string(),
agent_type: "claude".to_string(),
state: SessionState::Completed,
pid: None,
worktree: None,
created_at: now,
updated_at: now,
metrics: SessionMetrics::default(),
})?;
let dashboard_store = StateStore::open(&db_path)?;
let mut dashboard = Dashboard::new(dashboard_store, Config::default());
dashboard.delete_selected_session().await;
assert!(db.get_session("done-1")?.is_none(), "session should be deleted");
let _ = std::fs::remove_file(db_path);
Ok(())
}
#[test]
fn grid_layout_renders_four_panes() {
let mut dashboard = test_dashboard(vec![sample_session("grid-1", "claude", SessionState::Running, None, 1, 1)], 0);