Files
fn_registry/functions/infra/job_cleanup.md
T
egutierrez b5a867ca5a feat: cola de jobs asincrona basada en SQLite (issue 0013)
Implementa el subsistema completo de background jobs para apps Go en el
dominio infra. 9 funciones + 3 tipos + 17 tests, todos pasando.

- Tipos: Job (product), JobQueue (product), JobStatus (sum) con
  JobHandler, EnqueueOption y WorkerOption usando functional options pattern
- job_queue_create: CREATE TABLE + indices + WAL mode
- job_enqueue: INSERT con UUID (github.com/google/uuid), WithPriority/WithScheduledAt/WithMaxAttempts
- job_dequeue: SELECT+UPDATE atomico en transaccion exclusiva, filtro por jobTypes
- job_complete / job_fail: transiciones de estado; fail → dead cuando attempts >= max_attempts
- job_status_summary: pura, formatea conteo de jobs por estado
- job_worker: poll loop bloqueante, context-cancelable, graceful shutdown
- job_worker_pool: N workers con golang.org/x/sync/errgroup
- job_cleanup: DELETE jobs terminales mas viejos que olderThan

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-04-13 02:00:44 +02:00

1.4 KiB

name, kind, lang, domain, version, purity, signature, description, tags, uses_functions, uses_types, returns, returns_optional, error_type, imports, params, output, tested, tests, test_file_path, file_path
name kind lang domain version purity signature description tags uses_functions uses_types returns returns_optional error_type imports params output tested tests test_file_path file_path
job_cleanup function go infra 1.0.0 impure func JobCleanup(q *JobQueue, olderThan time.Duration) (int64, error) Elimina jobs en estados terminales (completed, failed, dead) cuyo created_at sea mas antiguo que olderThan. Retorna el numero de filas eliminadas. Util para mantener la tabla compacta en apps de larga duracion.
job
queue
cleanup
delete
maintenance
sqlite
async
background
infra
job_queue_go_infra
false error_go_core
fmt
time
name desc
q cola de jobs creada con JobQueueCreate
name desc
olderThan duracion maxima de retension; jobs mas viejos que esto se eliminan (ej: 24*time.Hour)
numero de filas eliminadas true
job_cleanup_removes_old_terminal_jobs
job_cleanup_keeps_recent_jobs
functions/infra/job_queue_test.go functions/infra/job_cleanup.go

Ejemplo

// Limpiar jobs terminados hace mas de 7 dias
n, err := JobCleanup(q, 7*24*time.Hour)
fmt.Printf("eliminados: %d jobs\n", n)

Notas

Solo elimina jobs en estados terminales: completed, failed, dead. Los jobs pending y running nunca se eliminan. El cutoff se calcula en UTC. Llamar periodicamente con CronTicker u otro scheduler para mantener la tabla compacta.