feat: decide which stage to run based on commit msg
This commit is contained in:
		
							parent
							
								
									8d0000016a
								
							
						
					
					
						commit
						2d08a435a8
					
				
							
								
								
									
										105
									
								
								cmd/joj3/conf.go
									
									
									
									
									
								
							
							
						
						
									
										105
									
								
								cmd/joj3/conf.go
									
									
									
									
									
								
							| 
						 | 
				
			
			@ -11,25 +11,35 @@ import (
 | 
			
		|||
	"github.com/koding/multiconfig"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type JobType int
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	HC JobType = iota
 | 
			
		||||
	CQ
 | 
			
		||||
	OJ
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type Stage struct {
 | 
			
		||||
	Name     string
 | 
			
		||||
	Executor struct {
 | 
			
		||||
		Name string
 | 
			
		||||
		With struct {
 | 
			
		||||
			Default stage.Cmd
 | 
			
		||||
			Cases   []OptionalCmd
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	Parser struct {
 | 
			
		||||
		Name string
 | 
			
		||||
		With interface{}
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type Conf struct {
 | 
			
		||||
	SandboxExecServer string `default:"localhost:5051"`
 | 
			
		||||
	SandboxToken      string `default:""`
 | 
			
		||||
	LogLevel          int    `default:"0"`
 | 
			
		||||
	OutputPath        string `default:"joj3_result.json"`
 | 
			
		||||
	Stages            []struct {
 | 
			
		||||
		Name     string
 | 
			
		||||
		Executor struct {
 | 
			
		||||
			Name string
 | 
			
		||||
			With struct {
 | 
			
		||||
				Default stage.Cmd
 | 
			
		||||
				Cases   []OptionalCmd
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		Parser struct {
 | 
			
		||||
			Name string
 | 
			
		||||
			With interface{}
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	Stages            []Stage
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
type OptionalCmd struct {
 | 
			
		||||
| 
						 | 
				
			
			@ -63,24 +73,51 @@ type OptionalCmd struct {
 | 
			
		|||
	AddressSpaceLimit *bool
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func parseConfFile(path string) (conf Conf, err error) {
 | 
			
		||||
func parseConfFile(path string, jobtype JobType) (conf Conf, err error) {
 | 
			
		||||
	d := &multiconfig.DefaultLoader{}
 | 
			
		||||
	d.Loader = multiconfig.MultiLoader(
 | 
			
		||||
		&multiconfig.TagLoader{},
 | 
			
		||||
		&multiconfig.JSONLoader{Path: path},
 | 
			
		||||
	)
 | 
			
		||||
	d.Validator = multiconfig.MultiValidator(&multiconfig.RequiredValidator{})
 | 
			
		||||
 | 
			
		||||
	if err = d.Load(&conf); err != nil {
 | 
			
		||||
		slog.Error("parse stages conf", "error", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if err = d.Validate(&conf); err != nil {
 | 
			
		||||
		slog.Error("validate stages conf", "error", err)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	filteredStages := []Stage{}
 | 
			
		||||
 | 
			
		||||
	for _, stage := range conf.Stages {
 | 
			
		||||
		if filterStage(stage, jobtype) {
 | 
			
		||||
			filteredStages = append(filteredStages, stage)
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	conf.Stages = filteredStages
 | 
			
		||||
 | 
			
		||||
	return
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func filterStage(stage Stage, jobtype JobType,
 | 
			
		||||
) bool {
 | 
			
		||||
	switch jobtype {
 | 
			
		||||
	case HC:
 | 
			
		||||
		return stage.Name == "healthcheck"
 | 
			
		||||
	case CQ:
 | 
			
		||||
		return stage.Name == "compile" || stage.Name == "healthcheck"
 | 
			
		||||
	case OJ:
 | 
			
		||||
		return true
 | 
			
		||||
	default:
 | 
			
		||||
		return false
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func validateHw(hw string) error {
 | 
			
		||||
	matched, err := regexp.MatchString(`^hw[0-9]+$`, hw)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
| 
						 | 
				
			
			@ -109,11 +146,12 @@ func commitMsgToConf() (conf Conf, err error) {
 | 
			
		|||
	}
 | 
			
		||||
 | 
			
		||||
	file := "conf.json"
 | 
			
		||||
	jobtype := HC
 | 
			
		||||
 | 
			
		||||
	msg := commit.Message
 | 
			
		||||
	slog.Debug("commit msg to conf", "msg", msg)
 | 
			
		||||
	if msg == "" {
 | 
			
		||||
		conf, err = parseConfFile(file)
 | 
			
		||||
		conf, err = parseConfFile(file, jobtype)
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -128,31 +166,22 @@ func commitMsgToConf() (conf Conf, err error) {
 | 
			
		|||
		head = head[:len(head)-1]
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	switch head {
 | 
			
		||||
	case "feat", "fix", "refactor", "perf", "test", "build", "revert":
 | 
			
		||||
		// TODO: Decide strategy to give students error
 | 
			
		||||
		// if len(words) < 2 {
 | 
			
		||||
		// 	return Conf{}, fmt.Errorf("error: hw not assigned")
 | 
			
		||||
		// }
 | 
			
		||||
		if len(words) >= 2 {
 | 
			
		||||
			hw = words[1]
 | 
			
		||||
			if err = validateHw(hw); err == nil {
 | 
			
		||||
				file = strings.Replace(file, "conf", "conf-"+hw+"-cq", 1)
 | 
			
		||||
			}
 | 
			
		||||
	if len(words) == 3 {
 | 
			
		||||
		hw = words[1]
 | 
			
		||||
		if err = validateHw(hw); err != nil {
 | 
			
		||||
			return
 | 
			
		||||
		}
 | 
			
		||||
	case "joj", "grading":
 | 
			
		||||
		// TODO: Decide strategy to give students error
 | 
			
		||||
		// if len(words) < 2 {
 | 
			
		||||
		// 	return Conf{}, fmt.Errorf("error: hw not assigned")
 | 
			
		||||
		// }
 | 
			
		||||
		if len(words) >= 2 {
 | 
			
		||||
			hw = words[1]
 | 
			
		||||
			if err = validateHw(hw); err == nil {
 | 
			
		||||
				file = strings.Replace(file, "conf", "conf-"+hw+"-oj", 1)
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
		switch head {
 | 
			
		||||
		case "feat", "fix", "refactor", "perf", "test", "build", "revert":
 | 
			
		||||
			file = strings.Replace(file, "conf", "conf-"+hw, 1)
 | 
			
		||||
			jobtype = CQ
 | 
			
		||||
		case "joj", "grading":
 | 
			
		||||
			file = strings.Replace(file, "conf", "conf-"+hw, 1)
 | 
			
		||||
			jobtype = OJ
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	conf, err = parseConfFile(file)
 | 
			
		||||
	conf, err = parseConfFile(file, jobtype)
 | 
			
		||||
	return
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue
	
	Block a user