Add new CLI flag to log just the job id and not the entire job name (#1920)
* Add new CLI flag to log just the job id and not the entire job name * Up the action test timeout to 20m from 15m
This commit is contained in:
		
							
								
								
									
										2
									
								
								.github/actions/run-tests/action.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/actions/run-tests/action.yml
									
									
									
									
										vendored
									
									
								
							| @@ -54,7 +54,7 @@ runs: | |||||||
|               } |               } | ||||||
|             } |             } | ||||||
|           }; |           }; | ||||||
|           var args = ['test', '-v', '-cover', '-coverprofile=coverage.txt', '-covermode=atomic', '-timeout', '15m']; |           var args = ['test', '-v', '-cover', '-coverprofile=coverage.txt', '-covermode=atomic', '-timeout', '20m']; | ||||||
|           var filter = process.env.FILTER; |           var filter = process.env.FILTER; | ||||||
|           if(filter) { |           if(filter) { | ||||||
|             args.push('-run'); |             args.push('-run'); | ||||||
|   | |||||||
| @@ -55,6 +55,7 @@ type Input struct { | |||||||
| 	replaceGheActionTokenWithGithubCom string | 	replaceGheActionTokenWithGithubCom string | ||||||
| 	matrix                             []string | 	matrix                             []string | ||||||
| 	actionCachePath                    string | 	actionCachePath                    string | ||||||
|  | 	logPrefixJobID                     bool | ||||||
| } | } | ||||||
|  |  | ||||||
| func (i *Input) resolve(path string) string { | func (i *Input) resolve(path string) string { | ||||||
|   | |||||||
| @@ -75,6 +75,7 @@ func Execute(ctx context.Context, version string) { | |||||||
| 	rootCmd.PersistentFlags().StringVarP(&input.workdir, "directory", "C", ".", "working directory") | 	rootCmd.PersistentFlags().StringVarP(&input.workdir, "directory", "C", ".", "working directory") | ||||||
| 	rootCmd.PersistentFlags().BoolP("verbose", "v", false, "verbose output") | 	rootCmd.PersistentFlags().BoolP("verbose", "v", false, "verbose output") | ||||||
| 	rootCmd.PersistentFlags().BoolVar(&input.jsonLogger, "json", false, "Output logs in json format") | 	rootCmd.PersistentFlags().BoolVar(&input.jsonLogger, "json", false, "Output logs in json format") | ||||||
|  | 	rootCmd.PersistentFlags().BoolVar(&input.logPrefixJobID, "log-prefix-job-id", false, "Output the job id within non-json logs instead of the entire name") | ||||||
| 	rootCmd.PersistentFlags().BoolVarP(&input.noOutput, "quiet", "q", false, "disable logging of output from steps") | 	rootCmd.PersistentFlags().BoolVarP(&input.noOutput, "quiet", "q", false, "disable logging of output from steps") | ||||||
| 	rootCmd.PersistentFlags().BoolVarP(&input.dryrun, "dryrun", "n", false, "dryrun mode") | 	rootCmd.PersistentFlags().BoolVarP(&input.dryrun, "dryrun", "n", false, "dryrun mode") | ||||||
| 	rootCmd.PersistentFlags().StringVarP(&input.secretfile, "secret-file", "", ".secrets", "file with list of secrets to read from (e.g. --secret-file .secrets)") | 	rootCmd.PersistentFlags().StringVarP(&input.secretfile, "secret-file", "", ".secrets", "file with list of secrets to read from (e.g. --secret-file .secrets)") | ||||||
| @@ -584,6 +585,7 @@ func newRunCommand(ctx context.Context, input *Input) func(*cobra.Command, []str | |||||||
| 			BindWorkdir:                        input.bindWorkdir, | 			BindWorkdir:                        input.bindWorkdir, | ||||||
| 			LogOutput:                          !input.noOutput, | 			LogOutput:                          !input.noOutput, | ||||||
| 			JSONLogger:                         input.jsonLogger, | 			JSONLogger:                         input.jsonLogger, | ||||||
|  | 			LogPrefixJobID:                     input.logPrefixJobID, | ||||||
| 			Env:                                envs, | 			Env:                                envs, | ||||||
| 			Secrets:                            secrets, | 			Secrets:                            secrets, | ||||||
| 			Vars:                               vars, | 			Vars:                               vars, | ||||||
|   | |||||||
| @@ -86,6 +86,7 @@ func WithJobLogger(ctx context.Context, jobID string, jobName string, config *Co | |||||||
| 			nextColor++ | 			nextColor++ | ||||||
| 			formatter = &jobLogFormatter{ | 			formatter = &jobLogFormatter{ | ||||||
| 				color:          colors[nextColor%len(colors)], | 				color:          colors[nextColor%len(colors)], | ||||||
|  | 				logPrefixJobID: config.LogPrefixJobID, | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| @@ -177,6 +178,7 @@ func (f *maskedFormatter) Format(entry *logrus.Entry) ([]byte, error) { | |||||||
|  |  | ||||||
| type jobLogFormatter struct { | type jobLogFormatter struct { | ||||||
| 	color          int | 	color          int | ||||||
|  | 	logPrefixJobID bool | ||||||
| } | } | ||||||
|  |  | ||||||
| func (f *jobLogFormatter) Format(entry *logrus.Entry) ([]byte, error) { | func (f *jobLogFormatter) Format(entry *logrus.Entry) ([]byte, error) { | ||||||
| @@ -194,7 +196,14 @@ func (f *jobLogFormatter) Format(entry *logrus.Entry) ([]byte, error) { | |||||||
|  |  | ||||||
| func (f *jobLogFormatter) printColored(b *bytes.Buffer, entry *logrus.Entry) { | func (f *jobLogFormatter) printColored(b *bytes.Buffer, entry *logrus.Entry) { | ||||||
| 	entry.Message = strings.TrimSuffix(entry.Message, "\n") | 	entry.Message = strings.TrimSuffix(entry.Message, "\n") | ||||||
| 	jobName := entry.Data["job"] |  | ||||||
|  | 	var job any | ||||||
|  | 	if f.logPrefixJobID { | ||||||
|  | 		job = entry.Data["jobID"] | ||||||
|  | 	} else { | ||||||
|  | 		job = entry.Data["job"] | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	debugFlag := "" | 	debugFlag := "" | ||||||
| 	if entry.Level == logrus.DebugLevel { | 	if entry.Level == logrus.DebugLevel { | ||||||
| 		debugFlag = "[DEBUG] " | 		debugFlag = "[DEBUG] " | ||||||
| @@ -203,26 +212,33 @@ func (f *jobLogFormatter) printColored(b *bytes.Buffer, entry *logrus.Entry) { | |||||||
| 	if entry.Data["raw_output"] == true { | 	if entry.Data["raw_output"] == true { | ||||||
| 		fmt.Fprintf(b, "\x1b[%dm|\x1b[0m %s", f.color, entry.Message) | 		fmt.Fprintf(b, "\x1b[%dm|\x1b[0m %s", f.color, entry.Message) | ||||||
| 	} else if entry.Data["dryrun"] == true { | 	} else if entry.Data["dryrun"] == true { | ||||||
| 		fmt.Fprintf(b, "\x1b[1m\x1b[%dm\x1b[7m*DRYRUN*\x1b[0m \x1b[%dm[%s] \x1b[0m%s%s", gray, f.color, jobName, debugFlag, entry.Message) | 		fmt.Fprintf(b, "\x1b[1m\x1b[%dm\x1b[7m*DRYRUN*\x1b[0m \x1b[%dm[%s] \x1b[0m%s%s", gray, f.color, job, debugFlag, entry.Message) | ||||||
| 	} else { | 	} else { | ||||||
| 		fmt.Fprintf(b, "\x1b[%dm[%s] \x1b[0m%s%s", f.color, jobName, debugFlag, entry.Message) | 		fmt.Fprintf(b, "\x1b[%dm[%s] \x1b[0m%s%s", f.color, job, debugFlag, entry.Message) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
| func (f *jobLogFormatter) print(b *bytes.Buffer, entry *logrus.Entry) { | func (f *jobLogFormatter) print(b *bytes.Buffer, entry *logrus.Entry) { | ||||||
| 	entry.Message = strings.TrimSuffix(entry.Message, "\n") | 	entry.Message = strings.TrimSuffix(entry.Message, "\n") | ||||||
| 	jobName := entry.Data["job"] |  | ||||||
|  | 	var job any | ||||||
|  | 	if f.logPrefixJobID { | ||||||
|  | 		job = entry.Data["jobID"] | ||||||
|  | 	} else { | ||||||
|  | 		job = entry.Data["job"] | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	debugFlag := "" | 	debugFlag := "" | ||||||
| 	if entry.Level == logrus.DebugLevel { | 	if entry.Level == logrus.DebugLevel { | ||||||
| 		debugFlag = "[DEBUG] " | 		debugFlag = "[DEBUG] " | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if entry.Data["raw_output"] == true { | 	if entry.Data["raw_output"] == true { | ||||||
| 		fmt.Fprintf(b, "[%s]   | %s", jobName, entry.Message) | 		fmt.Fprintf(b, "[%s]   | %s", job, entry.Message) | ||||||
| 	} else if entry.Data["dryrun"] == true { | 	} else if entry.Data["dryrun"] == true { | ||||||
| 		fmt.Fprintf(b, "*DRYRUN* [%s] %s%s", jobName, debugFlag, entry.Message) | 		fmt.Fprintf(b, "*DRYRUN* [%s] %s%s", job, debugFlag, entry.Message) | ||||||
| 	} else { | 	} else { | ||||||
| 		fmt.Fprintf(b, "[%s] %s%s", jobName, debugFlag, entry.Message) | 		fmt.Fprintf(b, "[%s] %s%s", job, debugFlag, entry.Message) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -32,6 +32,7 @@ type Config struct { | |||||||
| 	ForceRebuild                       bool                       // force rebuilding local docker image action | 	ForceRebuild                       bool                       // force rebuilding local docker image action | ||||||
| 	LogOutput                          bool                       // log the output from docker run | 	LogOutput                          bool                       // log the output from docker run | ||||||
| 	JSONLogger                         bool                       // use json or text logger | 	JSONLogger                         bool                       // use json or text logger | ||||||
|  | 	LogPrefixJobID                     bool                       // switches from the full job name to the job id | ||||||
| 	Env                                map[string]string          // env for containers | 	Env                                map[string]string          // env for containers | ||||||
| 	Inputs                             map[string]string          // manually passed action inputs | 	Inputs                             map[string]string          // manually passed action inputs | ||||||
| 	Secrets                            map[string]string          // list of secrets | 	Secrets                            map[string]string          // list of secrets | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user