mirror of
https://github.com/httprunner/httprunner.git
synced 2026-05-12 02:21:29 +08:00
122 lines
3.1 KiB
Go
122 lines
3.1 KiB
Go
package scaffold
|
|
|
|
import (
|
|
"fmt"
|
|
"io/ioutil"
|
|
"os"
|
|
"os/exec"
|
|
"path"
|
|
"strings"
|
|
|
|
"github.com/httprunner/hrp/internal/ga"
|
|
"github.com/rs/zerolog/log"
|
|
)
|
|
|
|
func CreateScaffold(projectName string) error {
|
|
// report event
|
|
ga.SendEvent(ga.EventTracking{
|
|
Category: "Scaffold",
|
|
Action: "hrp startproject",
|
|
})
|
|
|
|
// check if projectName exists
|
|
if _, err := os.Stat(projectName); err == nil {
|
|
log.Warn().Str("projectName", projectName).
|
|
Msg("project name already exists, please specify a new one.")
|
|
return fmt.Errorf("project name already exists")
|
|
}
|
|
|
|
log.Info().Str("projectName", projectName).Msg("create new scaffold project")
|
|
|
|
// create project folders
|
|
if err := createFolder(projectName); err != nil {
|
|
return err
|
|
}
|
|
if err := createFolder(path.Join(projectName, "har")); err != nil {
|
|
return err
|
|
}
|
|
if err := createFolder(path.Join(projectName, "testcases")); err != nil {
|
|
return err
|
|
}
|
|
pluginDir := path.Join(projectName, "plugin")
|
|
if err := createFolder(pluginDir); err != nil {
|
|
return err
|
|
}
|
|
if err := createFolder(path.Join(projectName, "reports")); err != nil {
|
|
return err
|
|
}
|
|
|
|
// create demo testcases
|
|
tCase, _ := demoTestCase.ToTCase()
|
|
err := tCase.Dump2JSON(path.Join(projectName, "testcases", "demo.json"))
|
|
if err != nil {
|
|
log.Error().Err(err).Msg("create demo.json testcase failed")
|
|
return err
|
|
}
|
|
err = tCase.Dump2YAML(path.Join(projectName, "testcases", "demo.yaml"))
|
|
if err != nil {
|
|
log.Error().Err(err).Msg("create demo.yml testcase failed")
|
|
return err
|
|
}
|
|
|
|
// create debugtalk.go
|
|
pluginFile := path.Join(pluginDir, "debugtalk.go")
|
|
if err := createFile(pluginFile, demoPlugin); err != nil {
|
|
return err
|
|
}
|
|
|
|
// download plugin dependency
|
|
if err := execCommand(exec.Command("go", "get", "github.com/httprunner/hrp/plugin"), pluginDir); err != nil {
|
|
return err
|
|
}
|
|
|
|
// build plugin debugtalk.bin
|
|
if err := execCommand(exec.Command("go", "build", "-o", path.Join("..", "debugtalk.bin"), "debugtalk.go"), pluginDir); err != nil {
|
|
return err
|
|
}
|
|
|
|
// create .gitignore
|
|
if err := createFile(path.Join(projectName, ".gitignore"), demoIgnoreContent); err != nil {
|
|
return err
|
|
}
|
|
// create .env
|
|
if err := createFile(path.Join(projectName, ".env"), demoEnvContent); err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func execCommand(cmd *exec.Cmd, cwd string) error {
|
|
log.Info().Str("cmd", cmd.String()).Str("cwd", cwd).Msg("exec command")
|
|
cmd.Dir = cwd
|
|
output, err := cmd.CombinedOutput()
|
|
out := strings.TrimSpace(string(output))
|
|
if err != nil {
|
|
log.Error().Err(err).Str("output", out).Msg("exec command failed")
|
|
} else if len(out) != 0 {
|
|
log.Info().Str("output", out).Msg("exec command success")
|
|
}
|
|
return err
|
|
}
|
|
|
|
func createFolder(folderPath string) error {
|
|
log.Info().Str("path", folderPath).Msg("create folder")
|
|
err := os.MkdirAll(folderPath, os.ModePerm)
|
|
if err != nil {
|
|
log.Error().Err(err).Msg("create folder failed")
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func createFile(filePath string, data string) error {
|
|
log.Info().Str("path", filePath).Msg("create file")
|
|
err := ioutil.WriteFile(filePath, []byte(data), 0o644)
|
|
if err != nil {
|
|
log.Error().Err(err).Msg("create file failed")
|
|
return err
|
|
}
|
|
return nil
|
|
}
|