mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Download actions job logs from API (#33858)
Related to #33709, #31416 It's similar with https://docs.github.com/en/rest/actions/workflow-jobs?apiVersion=2022-11-28#download-job-logs-for-a-workflow-run--code-samples. This use `job_id` as path parameter which is consistent with Github's APIs. --------- Co-authored-by: ChristopherHX <christopher.homberger@web.de> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
		| @@ -7,10 +7,12 @@ import ( | ||||
| 	"fmt" | ||||
| 	"net/http" | ||||
| 	"net/url" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| 	"testing" | ||||
| 	"time" | ||||
|  | ||||
| 	actions_model "code.gitea.io/gitea/models/actions" | ||||
| 	auth_model "code.gitea.io/gitea/models/auth" | ||||
| 	repo_model "code.gitea.io/gitea/models/repo" | ||||
| 	"code.gitea.io/gitea/models/unittest" | ||||
| @@ -149,6 +151,27 @@ jobs: | ||||
| 					) | ||||
| 				} | ||||
|  | ||||
| 				runID, _ := strconv.ParseInt(task.Context.GetFields()["run_id"].GetStringValue(), 10, 64) | ||||
|  | ||||
| 				jobs, err := actions_model.GetRunJobsByRunID(t.Context(), runID) | ||||
| 				assert.NoError(t, err) | ||||
| 				assert.Len(t, jobs, 1) | ||||
| 				jobID := jobs[0].ID | ||||
|  | ||||
| 				// download task logs from API and check content | ||||
| 				req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/%s/actions/jobs/%d/logs", user2.Name, repo.Name, jobID)). | ||||
| 					AddTokenAuth(token) | ||||
| 				resp = MakeRequest(t, req, http.StatusOK) | ||||
| 				logTextLines = strings.Split(strings.TrimSpace(resp.Body.String()), "\n") | ||||
| 				assert.Len(t, logTextLines, len(tc.outcome.logRows)) | ||||
| 				for idx, lr := range tc.outcome.logRows { | ||||
| 					assert.Equal( | ||||
| 						t, | ||||
| 						fmt.Sprintf("%s %s", lr.Time.AsTime().Format("2006-01-02T15:04:05.0000000Z07:00"), lr.Content), | ||||
| 						logTextLines[idx], | ||||
| 					) | ||||
| 				} | ||||
|  | ||||
| 				resetFunc() | ||||
| 			}) | ||||
| 		} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user