handle possible panic (#88)

Reviewed-on: https://gitea.com/gitea/act_runner/pulls/88
Reviewed-by: Jason Song <i@wolfogre.com>
pull/23/head
Lunny Xiao 2023-03-28 23:51:38 +08:00 committed by Earl Warren
parent 63c1734bb5
commit 0d33f8f520
No known key found for this signature in database
GPG Key ID: 0579CB2928A78A00
1 changed files with 35 additions and 26 deletions

View File

@ -54,24 +54,17 @@ func (p *Poller) Wait() {
p.routineGroup.Wait() p.routineGroup.Wait()
} }
func (p *Poller) Poll(ctx context.Context) error { func (p *Poller) handle(ctx context.Context, l *log.Entry) {
l := log.WithField("func", "Poll") defer func() {
if r := recover(); r != nil {
for { l.Errorf("handle task panic: %+v", r)
// check worker number
p.schedule()
select {
// wait worker ready
case <-p.ready:
case <-ctx.Done():
return nil
} }
LOOP: }()
for { for {
select { select {
case <-ctx.Done(): case <-ctx.Done():
break LOOP return
default: default:
task, err := p.pollTask(ctx) task, err := p.pollTask(ctx)
if task == nil || err != nil { if task == nil || err != nil {
@ -90,10 +83,26 @@ func (p *Poller) Poll(ctx context.Context) error {
l.Errorf("execute task: %v", err.Error()) l.Errorf("execute task: %v", err.Error())
} }
}) })
break LOOP return
} }
} }
} }
func (p *Poller) Poll(ctx context.Context) error {
l := log.WithField("func", "Poll")
for {
// check worker number
p.schedule()
select {
// wait worker ready
case <-p.ready:
case <-ctx.Done():
return nil
}
p.handle(ctx, l)
}
} }
func (p *Poller) pollTask(ctx context.Context) (*runnerv1.Task, error) { func (p *Poller) pollTask(ctx context.Context) (*runnerv1.Task, error) {