func convertSingleCase()

in internal/config/globalConfig.go [97:139]


func convertSingleCase(verifyCase *VerifyCase, baseFile string) ([]VerifyCase, error) {
	if len(verifyCase.Includes) > 0 && (verifyCase.Expected != "" || verifyCase.Query != "") {
		return nil, fmt.Errorf("include and query/expected only support selecting one of them in a case")
	}
	if len(verifyCase.Includes) == 0 {
		// using base path to resolve case paths
		if verifyCase.Expected != "" {
			verifyCase.Expected = util.ResolveAbsWithBase(verifyCase.Expected, baseFile)
		}
		if verifyCase.Actual != "" {
			verifyCase.Actual = util.ResolveAbsWithBase(verifyCase.Actual, baseFile)
		}
		return []VerifyCase{*verifyCase}, nil
	}
	result := make([]VerifyCase, 0)
	for _, include := range verifyCase.Includes {
		includePath := util.ResolveAbsWithBase(include, baseFile)

		if !util.PathExist(includePath) {
			return nil, fmt.Errorf("reuse case config file %s not exist", includePath)
		}

		data, err := os.ReadFile(includePath)
		if err != nil {
			return nil, fmt.Errorf("reuse case config file %s error: %s", includePath, err)
		}

		r := &ReusingCases{}
		if err := yaml.Unmarshal(data, r); err != nil {
			return nil, fmt.Errorf("unmarshal reuse case config file %s error: %s", includePath, err)
		}

		for idx := range r.Cases {
			// using include file path as base path to resolve cases
			cases, err := convertSingleCase(&r.Cases[idx], includePath)
			if err != nil {
				return nil, err
			}
			result = append(result, cases...)
		}
	}
	return result, nil
}