mirror of
				https://gitea.com/gitea/act_runner.git
				synced 2025-10-25 19:10:42 +02:00 
			
		
		
		
	Once flag polls and completes one job then exits. I use this with Windows Sandbox (and creating users with local brew install on Mac) to create a fresh environment every time. Co-authored-by: Garet Halliday <garet@pit.dev> Co-authored-by: Jason Song <wolfogre@noreply.gitea.com> Reviewed-on: https://gitea.com/gitea/act_runner/pulls/598 Reviewed-by: techknowlogick <techknowlogick@noreply.gitea.com> Reviewed-by: Jason Song <wolfogre@noreply.gitea.com> Co-authored-by: garet90 <garet90@noreply.gitea.com> Co-committed-by: garet90 <garet90@noreply.gitea.com>
This commit is contained in:
		| @@ -70,6 +70,15 @@ func (p *Poller) Poll() { | ||||
| 	close(p.done) | ||||
| } | ||||
|  | ||||
| func (p *Poller) PollOnce() { | ||||
| 	limiter := rate.NewLimiter(rate.Every(p.cfg.Runner.FetchInterval), 1) | ||||
|  | ||||
| 	p.pollOnce(limiter) | ||||
|  | ||||
| 	// signal that we're done | ||||
| 	close(p.done) | ||||
| } | ||||
|  | ||||
| func (p *Poller) Shutdown(ctx context.Context) error { | ||||
| 	p.shutdownPolling() | ||||
|  | ||||
| @@ -101,6 +110,19 @@ func (p *Poller) Shutdown(ctx context.Context) error { | ||||
|  | ||||
| func (p *Poller) poll(wg *sync.WaitGroup, limiter *rate.Limiter) { | ||||
| 	defer wg.Done() | ||||
| 	for { | ||||
| 		p.pollOnce(limiter) | ||||
|  | ||||
| 		select { | ||||
| 		case <-p.pollingCtx.Done(): | ||||
| 			return | ||||
| 		default: | ||||
| 			continue | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (p *Poller) pollOnce(limiter *rate.Limiter) { | ||||
| 	for { | ||||
| 		if err := limiter.Wait(p.pollingCtx); err != nil { | ||||
| 			if p.pollingCtx.Err() != nil { | ||||
| @@ -114,6 +136,7 @@ func (p *Poller) poll(wg *sync.WaitGroup, limiter *rate.Limiter) { | ||||
| 		} | ||||
|  | ||||
| 		p.runTaskWithRecover(p.jobsCtx, task) | ||||
| 		return | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user