mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 12:27:06 +00:00 
			
		
		
		
	Timeout on flush in testing (#16864)
* Timeout on flush in testing At the end of each test the queues are flushed. At present there is no limit on the length of time a flush can take which can lead to long flushes. However, if the CI task is cancelled we lose the log information as to where the long flush was taking place. This PR simply adds a default time limit of 2 minutes - at which point an error will be produced. This should allow us to more easily find the culprit. Signed-off-by: Andrew Thornton <art27@cantab.net> * return better error Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: 6543 <6543@obermui.de>
This commit is contained in:
		| @@ -9,6 +9,7 @@ import ( | ||||
| 	"fmt" | ||||
| 	"reflect" | ||||
| 	"sort" | ||||
| 	"strings" | ||||
| 	"sync" | ||||
| 	"time" | ||||
|  | ||||
| @@ -169,7 +170,17 @@ func (m *Manager) FlushAll(baseCtx context.Context, timeout time.Duration) error | ||||
| 	for { | ||||
| 		select { | ||||
| 		case <-ctx.Done(): | ||||
| 			return ctx.Err() | ||||
| 			mqs := m.ManagedQueues() | ||||
| 			nonEmptyQueues := []string{} | ||||
| 			for _, mq := range mqs { | ||||
| 				if !mq.IsEmpty() { | ||||
| 					nonEmptyQueues = append(nonEmptyQueues, mq.Name) | ||||
| 				} | ||||
| 			} | ||||
| 			if len(nonEmptyQueues) > 0 { | ||||
| 				return fmt.Errorf("flush timeout with non-empty queues: %s", strings.Join(nonEmptyQueues, ", ")) | ||||
| 			} | ||||
| 			return nil | ||||
| 		default: | ||||
| 		} | ||||
| 		mqs := m.ManagedQueues() | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 zeripath
					zeripath