This introduces an expiry date (default: 14 days from insert date) and adjust the service-maintenance script to delete jobs that are older than the expiration date.
87 lines
2 KiB
Go
87 lines
2 KiB
Go
// +build integration
|
|
|
|
package main
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/google/uuid"
|
|
"github.com/osbuild/osbuild-composer/pkg/jobqueue/dbjobqueue"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
const url = "postgres://postgres:foobar@localhost:5432/osbuildcomposer"
|
|
|
|
func TestDBJobQueueMaintenance(t *testing.T) {
|
|
dbMaintenance, err := newDB(url)
|
|
require.NoError(t, err)
|
|
defer dbMaintenance.Close()
|
|
q, err := dbjobqueue.New(url)
|
|
require.NoError(t, err)
|
|
defer q.Close()
|
|
|
|
_, err = dbMaintenance.Conn.Exec(context.Background(), "DELETE FROM jobs")
|
|
require.NoError(t, err)
|
|
|
|
t.Run("testDeleteJob", func(t *testing.T) {
|
|
testDeleteJob(t, dbMaintenance, q)
|
|
})
|
|
t.Run("testVacuum", func(t *testing.T) {
|
|
testVacuum(t, dbMaintenance, q)
|
|
})
|
|
|
|
}
|
|
|
|
func setExpired(t *testing.T, d db, id uuid.UUID) {
|
|
expires := time.Now().Add(-time.Second)
|
|
_, err := d.Conn.Exec(context.Background(), "UPDATE jobs SET expires_at = $1 WHERE id = $2", expires, id)
|
|
require.NoError(t, err)
|
|
}
|
|
|
|
func testDeleteJob(t *testing.T, d db, q *dbjobqueue.DBJobQueue) {
|
|
id, err := q.Enqueue("octopus", nil, nil, "")
|
|
require.NoError(t, err)
|
|
require.NotEqual(t, uuid.Nil, id)
|
|
_, _, _, _, _, err = q.Dequeue(context.Background(), []string{"octopus"}, []string{""})
|
|
require.NoError(t, err)
|
|
|
|
type Result struct {
|
|
Result string `json:"result"`
|
|
}
|
|
result := Result{
|
|
"deleteme",
|
|
}
|
|
|
|
res, err := json.Marshal(result)
|
|
require.NoError(t, err)
|
|
err = q.FinishJob(id, res)
|
|
require.NoError(t, err)
|
|
|
|
_, _, r, _, _, _, _, _, err := q.JobStatus(id)
|
|
require.NoError(t, err)
|
|
|
|
var r1 Result
|
|
require.NoError(t, json.Unmarshal(r, &r1))
|
|
require.Equal(t, result, r1)
|
|
|
|
rows, err := d.DeleteJob()
|
|
require.NoError(t, err)
|
|
require.Equal(t, int64(0), rows)
|
|
|
|
setExpired(t, d, id)
|
|
|
|
rows, err = d.DeleteJob()
|
|
require.NoError(t, err)
|
|
require.Equal(t, int64(1), rows)
|
|
|
|
_, _, _, _, _, _, _, _, err = q.JobStatus(id)
|
|
require.Error(t, err)
|
|
}
|
|
|
|
func testVacuum(t *testing.T, d db, q *dbjobqueue.DBJobQueue) {
|
|
require.NoError(t, d.VacuumAnalyze())
|
|
require.NoError(t, d.LogVacuumStats())
|
|
}
|