mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Support upload outputs and use needs context on Actions (#24230)
				
					
				
			See [Defining outputs for jobs](https://docs.github.com/en/actions/using-jobs/defining-outputs-for-jobs) and [Example usage of the needs context](https://docs.github.com/en/actions/learn-github-actions/contexts#example-usage-of-the-needs-context). Related to: - [actions-proto-def #5](https://gitea.com/gitea/actions-proto-def/pulls/5) - [act_runner #133](https://gitea.com/gitea/act_runner/pulls/133) <details> <summary>Tests & screenshots</summary> Test workflow file: ```yaml name: outputs on: push jobs: job1: runs-on: ubuntu-latest outputs: output1: ${{ steps.step1.outputs.output1 }} output2: ${{ steps.step2.outputs.output2 }} steps: - name: step1 id: step1 run: | date -Is > output1 cat output1 echo "output1=$(cat output1)" >> $GITHUB_OUTPUT - name: step2 id: step2 run: | cat /proc/sys/kernel/random/uuid > output2 cat output2 echo "output2=$(cat output2)" >> $GITHUB_OUTPUT job2: needs: job1 runs-on: ubuntu-latest steps: - run: echo ${{ needs.job1.outputs.output1 }} - run: echo ${{ needs.job1.outputs.output2 }} - run: echo ${{ needs.job1.result }} ``` <img width="397" alt="image" src="https://user-images.githubusercontent.com/9418365/233313322-903e7ebf-49a7-48e2-8c17-95a4581b3284.png"> <img width="385" alt="image" src="https://user-images.githubusercontent.com/9418365/233313442-30909135-1711-4b78-a5c6-133fcc79f47c.png"> </details> --------- Co-authored-by: Giteabot <teabot@gitea.io>
This commit is contained in:
		| @@ -97,7 +97,7 @@ func (s *Service) Register( | ||||
| // FetchTask assigns a task to the runner | ||||
| func (s *Service) FetchTask( | ||||
| 	ctx context.Context, | ||||
| 	req *connect.Request[runnerv1.FetchTaskRequest], | ||||
| 	_ *connect.Request[runnerv1.FetchTaskRequest], | ||||
| ) (*connect.Response[runnerv1.FetchTaskResponse], error) { | ||||
| 	runner := GetRunner(ctx) | ||||
|  | ||||
| @@ -145,6 +145,31 @@ func (s *Service) UpdateTask( | ||||
| 		return nil, status.Errorf(codes.Internal, "update task: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	for k, v := range req.Msg.Outputs { | ||||
| 		if len(k) > 255 { | ||||
| 			log.Warn("Ignore the output of task %d because the key is too long: %q", task.ID, k) | ||||
| 			continue | ||||
| 		} | ||||
| 		// The value can be a maximum of 1 MB | ||||
| 		if l := len(v); l > 1024*1024 { | ||||
| 			log.Warn("Ignore the output %q of task %d because the value is too long: %v", k, task.ID, l) | ||||
| 			continue | ||||
| 		} | ||||
| 		// There's another limitation on GitHub that the total of all outputs in a workflow run can be a maximum of 50 MB. | ||||
| 		// We don't check the total size here because it's not easy to do, and it doesn't really worth it. | ||||
| 		// See https://docs.github.com/en/actions/using-jobs/defining-outputs-for-jobs | ||||
|  | ||||
| 		if err := actions_model.InsertTaskOutputIfNotExist(ctx, task.ID, k, v); err != nil { | ||||
| 			log.Warn("Failed to insert the output %q of task %d: %v", k, task.ID, err) | ||||
| 			// It's ok not to return errors, the runner will resend the outputs. | ||||
| 		} | ||||
| 	} | ||||
| 	sentOutputs, err := actions_model.FindTaskOutputKeyByTaskID(ctx, task.ID) | ||||
| 	if err != nil { | ||||
| 		log.Warn("Failed to find the sent outputs of task %d: %v", task.ID, err) | ||||
| 		// It's not to return errors, it can be handled when the runner resends sent outputs. | ||||
| 	} | ||||
|  | ||||
| 	if err := task.LoadJob(ctx); err != nil { | ||||
| 		return nil, status.Errorf(codes.Internal, "load job: %v", err) | ||||
| 	} | ||||
| @@ -162,6 +187,7 @@ func (s *Service) UpdateTask( | ||||
| 			Id:     req.Msg.State.Id, | ||||
| 			Result: task.Status.AsResult(), | ||||
| 		}, | ||||
| 		SentOutputs: sentOutputs, | ||||
| 	}), nil | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user