Сравнить коммиты
4 коммитов
Автор | SHA1 | Дата | |
---|---|---|---|
![]() |
69e0676d93 | ||
![]() |
8d882348a0 | ||
![]() |
3cfd1f25e9 | ||
![]() |
a7166810c4 |
6 изменённых файлов: 182 добавлений и 79 удалений
1
.gitignore
предоставленный
1
.gitignore
предоставленный
|
@ -6,7 +6,6 @@ Gopkg.toml
|
||||||
|
|
||||||
.DS_Store
|
.DS_Store
|
||||||
.idea
|
.idea
|
||||||
.vscode
|
|
||||||
|
|
||||||
_artifacts
|
_artifacts
|
||||||
|
|
||||||
|
|
|
@ -46,18 +46,20 @@ func (a *ASTer) ДобавитьШаг(шаг, f, ps string) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *ASTer) найтиТестовыйФайл() error {
|
func (a *ASTer) найтиТестовыйФайл() error {
|
||||||
a.сгенеритьИмяФайла()
|
|
||||||
_, err := os.Stat(INIT_TEST_GO_FNAME)
|
_, err := os.Stat(INIT_TEST_GO_FNAME)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err = os.Stat(a.pkg_test_go_fname)
|
имя, err := найтиТестовыйФайлВЭтойДире()
|
||||||
|
if err != nil {
|
||||||
|
return errors.Join(errors.New("Не могу найти *_test.go файл"), err)
|
||||||
|
}
|
||||||
|
|
||||||
|
a.pkg_test_go_fname = имя
|
||||||
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
func (a *ASTer) сгенеритьИмяФайла() {
|
|
||||||
a.pkg_test_go_fname = a.pkg + "_test.go"
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *ASTer) добавитьШаг(шаг, f, ps string) error {
|
func (a *ASTer) добавитьШаг(шаг, f, ps string) error {
|
||||||
err := a.добавитьШагвInitФайл(шаг, f)
|
err := a.добавитьШагвInitФайл(шаг, f)
|
||||||
|
@ -252,7 +254,7 @@ func (a *ASTer) сконвертитьСтрокувПараметры(in string
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *ASTer) перезаписатьInitФайл() error {
|
func (a *ASTer) перезаписатьInitФайл() error {
|
||||||
err := переименоватьФайлСоВременем(INIT_TEST_GO_FNAME)
|
err := забекапитьФайлСоВременем(INIT_TEST_GO_FNAME)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.Join(err, errors.New("cant backup orig file"))
|
return errors.Join(err, errors.New("cant backup orig file"))
|
||||||
}
|
}
|
||||||
|
@ -266,7 +268,7 @@ func (a *ASTer) перезаписатьInitФайл() error {
|
||||||
return format.Node(f, a.init_test_fset, a.init_test_node)
|
return format.Node(f, a.init_test_fset, a.init_test_node)
|
||||||
}
|
}
|
||||||
func (a *ASTer) перезаписатьФайл() error {
|
func (a *ASTer) перезаписатьФайл() error {
|
||||||
err := переименоватьФайлСоВременем(a.pkg_test_go_fname)
|
err := забекапитьФайлСоВременем(a.pkg_test_go_fname)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.Join(err, errors.New("cant backup orig file"))
|
return errors.Join(err, errors.New("cant backup orig file"))
|
||||||
}
|
}
|
||||||
|
|
|
@ -54,6 +54,58 @@
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Сценарий: Добавление шага, с другим тестовым файлом
|
||||||
|
Дано Файл "init_test.go":
|
||||||
|
```
|
||||||
|
package mypkg
|
||||||
|
|
||||||
|
func InitializeScenario(ctx *godog.ScenarioContext) {
|
||||||
|
|
||||||
|
ctx.Before(func(ctx context.Context, sc *godog.Scenario) (context.Context, error) {
|
||||||
|
beforeScenario()
|
||||||
|
return ctx, nil
|
||||||
|
})
|
||||||
|
ctx.After(func(ctx context.Context, sc *godog.Scenario, err error) (context.Context, error) {
|
||||||
|
afterScenario()
|
||||||
|
return ctx, nil
|
||||||
|
})
|
||||||
|
InitializeGomegaForGodog(ctx)
|
||||||
|
}
|
||||||
|
|
||||||
|
```
|
||||||
|
Дано Файл "system_test.go":
|
||||||
|
```
|
||||||
|
package mypkg
|
||||||
|
```
|
||||||
|
Когда Добавляется шаг: "^Привет Мир!$" с функцией "ПриветМир" с ""
|
||||||
|
То Файл "init_test.go" должен содержать:
|
||||||
|
```
|
||||||
|
package mypkg
|
||||||
|
|
||||||
|
func InitializeScenario(ctx *godog.ScenarioContext) {
|
||||||
|
ctx.Step(`^Привет Мир!$`, ПриветМир)
|
||||||
|
|
||||||
|
ctx.Before(func(ctx context.Context, sc *godog.Scenario) (context.Context, error) {
|
||||||
|
beforeScenario()
|
||||||
|
return ctx, nil
|
||||||
|
})
|
||||||
|
ctx.After(func(ctx context.Context, sc *godog.Scenario, err error) (context.Context, error) {
|
||||||
|
afterScenario()
|
||||||
|
return ctx, nil
|
||||||
|
})
|
||||||
|
InitializeGomegaForGodog(ctx)
|
||||||
|
}
|
||||||
|
|
||||||
|
```
|
||||||
|
То Файл "system_test.go" должен содержать:
|
||||||
|
```
|
||||||
|
package mypkg
|
||||||
|
|
||||||
|
func ПриветМир() {
|
||||||
|
}
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
Сценарий: Добавление шага с параметрами: int
|
Сценарий: Добавление шага с параметрами: int
|
||||||
Дано Файл "init_test.go":
|
Дано Файл "init_test.go":
|
||||||
```
|
```
|
||||||
|
|
|
@ -1,10 +1,19 @@
|
||||||
package ast
|
package ast
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
// 0: имя, 1: тип
|
// 0: имя, 1: тип
|
||||||
type Параметр []string
|
type Параметр []string
|
||||||
type Параметры []Параметр
|
type Параметры []Параметр
|
||||||
|
|
||||||
func ДобавитьШаг(шаг, f string, ps string) error {
|
func ДобавитьШаг(шаг, f string, ps string) error {
|
||||||
|
err := добавитьШаг(шаг, f, ps)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println("Ошибка добавления тестового шага:", err)
|
||||||
|
}
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
func добавитьШаг(шаг, f string, ps string) error {
|
||||||
a, err := NewASTer()
|
a, err := NewASTer()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
|
|
@ -5,6 +5,7 @@ import (
|
||||||
"go/ast"
|
"go/ast"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"errors"
|
"errors"
|
||||||
|
@ -12,10 +13,14 @@ import (
|
||||||
"git.golang1.ru/softonik/godog/pkg/lib"
|
"git.golang1.ru/softonik/godog/pkg/lib"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
var (
|
||||||
BACKUP_DIR = ".back"
|
BACKUP_DIR = "backup"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
BACKUP_DIR = os.TempDir() + "/godog/" + BACKUP_DIR
|
||||||
|
}
|
||||||
|
|
||||||
func получитьИмяGoПакетаВЭтойДире() (pkg_name string, err_ret error) {
|
func получитьИмяGoПакетаВЭтойДире() (pkg_name string, err_ret error) {
|
||||||
err_ret = errors.New("not found")
|
err_ret = errors.New("not found")
|
||||||
|
|
||||||
|
@ -41,12 +46,39 @@ func получитьИмяGoПакетаВЭтойДире() (pkg_name string,
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func переименоватьФайлСоВременем(fname string) error {
|
func найтиТестовыйФайлВЭтойДире() (name string, err_ret error) {
|
||||||
|
err_ret = errors.New("not found")
|
||||||
|
|
||||||
|
err := filepath.Walk(".", func(path string, info os.FileInfo, err error) error {
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if !info.IsDir() && strings.HasSuffix(info.Name(), "_test.go") {
|
||||||
|
if info.Name() == "init_test.go" ||
|
||||||
|
strings.HasSuffix(info.Name(), "_mock_test.go") {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
name = info.Name()
|
||||||
|
err_ret = nil
|
||||||
|
return filepath.SkipDir
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
func забекапитьФайлСоВременем(fname string) error {
|
||||||
os.MkdirAll(BACKUP_DIR, 0755)
|
os.MkdirAll(BACKUP_DIR, 0755)
|
||||||
currentTime := time.Now()
|
currentTime := time.Now()
|
||||||
timestamp := currentTime.Format("20060102_150405")
|
timestamp := currentTime.Format("20060102_150405")
|
||||||
new_fname := fmt.Sprintf(BACKUP_DIR+"/%v_%v", fname, timestamp)
|
new_fname := fmt.Sprintf(BACKUP_DIR+"/%v_%v", fname, timestamp)
|
||||||
return os.Rename(fname, new_fname)
|
return lib.CopyFile(fname, new_fname)
|
||||||
}
|
}
|
||||||
|
|
||||||
func являетсяЛиШагомсТакойЖеФункцией(stmt ast.Stmt, step *ast.ExprStmt) bool {
|
func являетсяЛиШагомсТакойЖеФункцией(stmt ast.Stmt, step *ast.ExprStmt) bool {
|
||||||
|
|
|
@ -44,3 +44,12 @@ func CopyFile(src, dst string) (err error) {
|
||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func MoveFile(src, dst string) (err error) {
|
||||||
|
err = CopyFile(src, dst)
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
return os.Remove(src)
|
||||||
|
}
|
||||||
|
|
Загрузка…
Создание таблицы
Сослаться в новой задаче