mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-29 10:57:44 +09:00 
			
		
		
		
	Queue: Make WorkerPools and Queues flushable (#10001)
* Make WorkerPools and Queues flushable Adds Flush methods to Queues and the WorkerPool Further abstracts the WorkerPool Adds a final step to Flush the queues in the defer from PrintCurrentTest Fixes an issue with Settings inheritance in queues Signed-off-by: Andrew Thornton <art27@cantab.net> * Change to for loop * Add IsEmpty and begin just making the queues composed WorkerPools * subsume workerpool into the queues and create a flushable interface * Add manager command * Move flushall to queue.Manager and add to testlogger * As per @guillep2k * as per @guillep2k * Just make queues all implement flushable and clean up the wrapped queue flushes * cope with no timeout Co-authored-by: Lauris BH <lauris@nix.lv>
This commit is contained in:
		| @@ -404,6 +404,28 @@ func WorkerCancel(ctx *context.Context) { | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| // Flush flushes a queue | ||||
| func Flush(ctx *context.Context) { | ||||
| 	qid := ctx.ParamsInt64("qid") | ||||
| 	mq := queue.GetManager().GetManagedQueue(qid) | ||||
| 	if mq == nil { | ||||
| 		ctx.Status(404) | ||||
| 		return | ||||
| 	} | ||||
| 	timeout, err := time.ParseDuration(ctx.Query("timeout")) | ||||
| 	if err != nil { | ||||
| 		timeout = -1 | ||||
| 	} | ||||
| 	ctx.Flash.Info(ctx.Tr("admin.monitor.queue.pool.flush.added", mq.Name)) | ||||
| 	go func() { | ||||
| 		err := mq.Flush(timeout) | ||||
| 		if err != nil { | ||||
| 			log.Error("Flushing failure for %s: Error %v", mq.Name, err) | ||||
| 		} | ||||
| 	}() | ||||
| 	ctx.Redirect(setting.AppSubURL + fmt.Sprintf("/admin/monitor/queue/%d", qid)) | ||||
| } | ||||
|  | ||||
| // AddWorkers adds workers to a worker group | ||||
| func AddWorkers(ctx *context.Context) { | ||||
| 	qid := ctx.ParamsInt64("qid") | ||||
| @@ -424,7 +446,7 @@ func AddWorkers(ctx *context.Context) { | ||||
| 		ctx.Redirect(setting.AppSubURL + fmt.Sprintf("/admin/monitor/queue/%d", qid)) | ||||
| 		return | ||||
| 	} | ||||
| 	if mq.Pool == nil { | ||||
| 	if _, ok := mq.Managed.(queue.ManagedPool); !ok { | ||||
| 		ctx.Flash.Error(ctx.Tr("admin.monitor.queue.pool.none")) | ||||
| 		ctx.Redirect(setting.AppSubURL + fmt.Sprintf("/admin/monitor/queue/%d", qid)) | ||||
| 		return | ||||
| @@ -442,7 +464,7 @@ func SetQueueSettings(ctx *context.Context) { | ||||
| 		ctx.Status(404) | ||||
| 		return | ||||
| 	} | ||||
| 	if mq.Pool == nil { | ||||
| 	if _, ok := mq.Managed.(queue.ManagedPool); !ok { | ||||
| 		ctx.Flash.Error(ctx.Tr("admin.monitor.queue.pool.none")) | ||||
| 		ctx.Redirect(setting.AppSubURL + fmt.Sprintf("/admin/monitor/queue/%d", qid)) | ||||
| 		return | ||||
| @@ -488,10 +510,10 @@ func SetQueueSettings(ctx *context.Context) { | ||||
| 			return | ||||
| 		} | ||||
| 	} else { | ||||
| 		timeout = mq.Pool.BoostTimeout() | ||||
| 		timeout = mq.BoostTimeout() | ||||
| 	} | ||||
|  | ||||
| 	mq.SetSettings(maxNumber, number, timeout) | ||||
| 	mq.SetPoolSettings(maxNumber, number, timeout) | ||||
| 	ctx.Flash.Success(ctx.Tr("admin.monitor.queue.settings.changed")) | ||||
| 	ctx.Redirect(setting.AppSubURL + fmt.Sprintf("/admin/monitor/queue/%d", qid)) | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user