add method to allow running from go source, without flags, see #50
Этот коммит содержится в:
		
							родитель
							
								
									eac32e6f48
								
							
						
					
					
						коммит
						49e59d9296
					
				
					 6 изменённых файлов: 92 добавлений и 78 удалений
				
			
		
							
								
								
									
										17
									
								
								README.md
									
										
									
									
									
								
							
							
						
						
									
										17
									
								
								README.md
									
										
									
									
									
								
							|  | @ -206,7 +206,6 @@ installed. See the following example: | ||||||
| package main | package main | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"flag" |  | ||||||
| 	"os" | 	"os" | ||||||
| 	"testing" | 	"testing" | ||||||
| 
 | 
 | ||||||
|  | @ -214,21 +213,13 @@ import ( | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func TestMain(m *testing.M) { | func TestMain(m *testing.M) { | ||||||
| 	args := os.Args | 	status := godog.RunWithOptions(func(s *godog.Suite) { | ||||||
| 	// args for godog |  | ||||||
| 	os.Args = []string{ |  | ||||||
| 		args[0], |  | ||||||
| 		"-f", "progress", |  | ||||||
| 		"features", |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	status := godog.Run(func(s *godog.Suite) { |  | ||||||
| 		FeatureContext(s) | 		FeatureContext(s) | ||||||
|  | 	}, godog.Options{ | ||||||
|  | 		Format: "progress", | ||||||
|  | 		Paths:  []string{"features"}, | ||||||
| 	}) | 	}) | ||||||
| 
 | 
 | ||||||
| 	os.Args = args |  | ||||||
| 	flag.Parse() |  | ||||||
| 
 |  | ||||||
| 	if st := m.Run(); st > status { | 	if st := m.Run(); st > status { | ||||||
| 		status = st | 		status = st | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -68,8 +68,10 @@ func main() { | ||||||
| 	var tags, format, output string | 	var tags, format, output string | ||||||
| 	var concurrency int | 	var concurrency int | ||||||
| 
 | 
 | ||||||
| 	flagSet := godog.FlagSet(&format, &tags, &defs, &sof, &noclr, &concurrency, &output) | 	flagSet := godog.FlagSet(&format, &tags, &defs, &sof, &noclr, &concurrency) | ||||||
| 	flagSet.BoolVar(&vers, "version", false, "Show current version.") | 	flagSet.BoolVar(&vers, "version", false, "Show current version.") | ||||||
|  | 	flagSet.StringVar(&output, "o", "", "Build and output test runner executable to given target path.") | ||||||
|  | 	flagSet.StringVar(&output, "output", "", "Build and output test runner executable to given target path.") | ||||||
| 
 | 
 | ||||||
| 	err := flagSet.Parse(os.Args[1:]) | 	err := flagSet.Parse(os.Args[1:]) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
|  |  | ||||||
|  | @ -2,7 +2,6 @@ | ||||||
| package main | package main | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"flag" |  | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"os" | 	"os" | ||||||
| 	"testing" | 	"testing" | ||||||
|  | @ -11,21 +10,13 @@ import ( | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func TestMain(m *testing.M) { | func TestMain(m *testing.M) { | ||||||
| 	args := os.Args | 	status := godog.RunWithOptions(func(s *godog.Suite) { | ||||||
| 	// args for godog |  | ||||||
| 	os.Args = []string{ |  | ||||||
| 		args[0], |  | ||||||
| 		"-f", "progress", |  | ||||||
| 		"features", |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	status := godog.Run(func(s *godog.Suite) { |  | ||||||
| 		FeatureContext(s) | 		FeatureContext(s) | ||||||
|  | 	}, godog.Options{ | ||||||
|  | 		Format: "progress", | ||||||
|  | 		Paths:  []string{"features"}, | ||||||
| 	}) | 	}) | ||||||
| 
 | 
 | ||||||
| 	os.Args = args |  | ||||||
| 	flag.Parse() |  | ||||||
| 
 |  | ||||||
| 	if st := m.Run(); st > status { | 	if st := m.Run(); st > status { | ||||||
| 		status = st | 		status = st | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
							
								
								
									
										7
									
								
								flags.go
									
										
									
									
									
								
							
							
						
						
									
										7
									
								
								flags.go
									
										
									
									
									
								
							|  | @ -23,11 +23,8 @@ var descTagsOption = "Filter scenarios by tags. Expression can be:\n" + | ||||||
| 	s(4) + "- " + cl(`"@wip && ~@new"`, yellow) + ": run wip scenarios, but exclude new\n" + | 	s(4) + "- " + cl(`"@wip && ~@new"`, yellow) + ": run wip scenarios, but exclude new\n" + | ||||||
| 	s(4) + "- " + cl(`"@wip,@undone"`, yellow) + ": run wip or undone scenarios" | 	s(4) + "- " + cl(`"@wip,@undone"`, yellow) + ": run wip or undone scenarios" | ||||||
| 
 | 
 | ||||||
| var descOutputOption = "Output the temporary test runner executable:\n" + |  | ||||||
| 	s(4) + "- supply the name to give the executable " + cl("test_features.exe", yellow) + "\n" |  | ||||||
| 
 |  | ||||||
| // FlagSet allows to manage flags by external suite runner | // FlagSet allows to manage flags by external suite runner | ||||||
| func FlagSet(format, tags *string, defs, sof, noclr *bool, cr *int, output *string) *flag.FlagSet { | func FlagSet(format, tags *string, defs, sof, noclr *bool, cr *int) *flag.FlagSet { | ||||||
| 	descFormatOption := "How to format tests output. Available formats:\n" | 	descFormatOption := "How to format tests output. Available formats:\n" | ||||||
| 	for _, f := range formatters { | 	for _, f := range formatters { | ||||||
| 		descFormatOption += s(4) + "- " + cl(f.name, yellow) + ": " + f.description + "\n" | 		descFormatOption += s(4) + "- " + cl(f.name, yellow) + ": " + f.description + "\n" | ||||||
|  | @ -45,8 +42,6 @@ func FlagSet(format, tags *string, defs, sof, noclr *bool, cr *int, output *stri | ||||||
| 	set.BoolVar(defs, "d", false, "Print all available step definitions.") | 	set.BoolVar(defs, "d", false, "Print all available step definitions.") | ||||||
| 	set.BoolVar(sof, "stop-on-failure", false, "Stop processing on first failed scenario.") | 	set.BoolVar(sof, "stop-on-failure", false, "Stop processing on first failed scenario.") | ||||||
| 	set.BoolVar(noclr, "no-colors", false, "Disable ansi colors.") | 	set.BoolVar(noclr, "no-colors", false, "Disable ansi colors.") | ||||||
| 	set.StringVar(output, "output", "", descOutputOption) |  | ||||||
| 	set.StringVar(output, "o", "", descOutputOption) |  | ||||||
| 	set.Usage = usage(set) | 	set.Usage = usage(set) | ||||||
| 	return set | 	return set | ||||||
| } | } | ||||||
|  |  | ||||||
							
								
								
									
										18
									
								
								options.go
									
										
									
									
									
										Обычный файл
									
								
							
							
						
						
									
										18
									
								
								options.go
									
										
									
									
									
										Обычный файл
									
								
							|  | @ -0,0 +1,18 @@ | ||||||
|  | package godog | ||||||
|  | 
 | ||||||
|  | // Options are suite run options | ||||||
|  | // flags are mapped to these options. | ||||||
|  | // | ||||||
|  | // It can also be used together with godog.RunWithOptions | ||||||
|  | // to run test suite from go source directly | ||||||
|  | // | ||||||
|  | // See the flags for more details | ||||||
|  | type Options struct { | ||||||
|  | 	ShowStepDefinitions bool | ||||||
|  | 	StopOnFailure       bool | ||||||
|  | 	NoColors            bool | ||||||
|  | 	Tags                string | ||||||
|  | 	Format              string | ||||||
|  | 	Concurrency         int | ||||||
|  | 	Paths               []string | ||||||
|  | } | ||||||
							
								
								
									
										107
									
								
								run.go
									
										
									
									
									
								
							
							
						
						
									
										107
									
								
								run.go
									
										
									
									
									
								
							|  | @ -61,7 +61,58 @@ func (r *runner) run() (failed bool) { | ||||||
| 	return suite.failed | 	return suite.failed | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | // RunWithOptions is same as Run function, except | ||||||
|  | // it uses Options provided in order to run the | ||||||
|  | // test suite without parsing flags | ||||||
|  | // | ||||||
|  | // This method is useful in case if you run | ||||||
|  | // godog in for example TestMain function together | ||||||
|  | // with go tests | ||||||
|  | func RunWithOptions(contextInitializer func(suite *Suite), opt Options) int { | ||||||
|  | 	if opt.ShowStepDefinitions { | ||||||
|  | 		s := &Suite{} | ||||||
|  | 		contextInitializer(s) | ||||||
|  | 		s.printStepDefinitions() | ||||||
|  | 		return 0 | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if len(opt.Paths) == 0 { | ||||||
|  | 		inf, err := os.Stat("features") | ||||||
|  | 		if err == nil && inf.IsDir() { | ||||||
|  | 			opt.Paths = []string{"features"} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if opt.Concurrency > 1 && opt.Format != "progress" { | ||||||
|  | 		fatal(fmt.Errorf("when concurrency level is higher than 1, only progress format is supported")) | ||||||
|  | 	} | ||||||
|  | 	formatter, err := findFmt(opt.Format) | ||||||
|  | 	fatal(err) | ||||||
|  | 
 | ||||||
|  | 	features, err := parseFeatures(opt.Tags, opt.Paths) | ||||||
|  | 	fatal(err) | ||||||
|  | 
 | ||||||
|  | 	r := runner{ | ||||||
|  | 		fmt:           formatter, | ||||||
|  | 		initializer:   contextInitializer, | ||||||
|  | 		features:      features, | ||||||
|  | 		stopOnFailure: opt.StopOnFailure, | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	var failed bool | ||||||
|  | 	if opt.Concurrency > 1 { | ||||||
|  | 		failed = r.concurrent(opt.Concurrency) | ||||||
|  | 	} else { | ||||||
|  | 		failed = r.run() | ||||||
|  | 	} | ||||||
|  | 	if failed { | ||||||
|  | 		return 1 | ||||||
|  | 	} | ||||||
|  | 	return 0 | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // Run creates and runs the feature suite. | // Run creates and runs the feature suite. | ||||||
|  | // Reads all configuration options from flags. | ||||||
| // uses contextInitializer to register contexts | // uses contextInitializer to register contexts | ||||||
| // | // | ||||||
| // the concurrency option allows runner to | // the concurrency option allows runner to | ||||||
|  | @ -73,52 +124,18 @@ func (r *runner) run() (failed bool) { | ||||||
| // contextInitializer must be able to register | // contextInitializer must be able to register | ||||||
| // the step definitions and event handlers. | // the step definitions and event handlers. | ||||||
| func Run(contextInitializer func(suite *Suite)) int { | func Run(contextInitializer func(suite *Suite)) int { | ||||||
| 	var defs, sof, noclr bool | 	var opt Options | ||||||
| 	var tags, format, output string | 	flagSet := FlagSet( | ||||||
| 	var concurrency int | 		&opt.Format, | ||||||
| 	flagSet := FlagSet(&format, &tags, &defs, &sof, &noclr, &concurrency, &output) | 		&opt.Tags, | ||||||
|  | 		&opt.ShowStepDefinitions, | ||||||
|  | 		&opt.StopOnFailure, | ||||||
|  | 		&opt.NoColors, | ||||||
|  | 		&opt.Concurrency, | ||||||
|  | 	) | ||||||
| 	err := flagSet.Parse(os.Args[1:]) | 	err := flagSet.Parse(os.Args[1:]) | ||||||
| 	fatal(err) | 	fatal(err) | ||||||
|  | 	opt.Paths = flagSet.Args() | ||||||
| 
 | 
 | ||||||
| 	if defs { | 	return RunWithOptions(contextInitializer, opt) | ||||||
| 		s := &Suite{} |  | ||||||
| 		contextInitializer(s) |  | ||||||
| 		s.printStepDefinitions() |  | ||||||
| 		return 0 |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	paths := flagSet.Args() |  | ||||||
| 	if len(paths) == 0 { |  | ||||||
| 		inf, err := os.Stat("features") |  | ||||||
| 		if err == nil && inf.IsDir() { |  | ||||||
| 			paths = []string{"features"} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if concurrency > 1 && format != "progress" { |  | ||||||
| 		fatal(fmt.Errorf("when concurrency level is higher than 1, only progress format is supported")) |  | ||||||
| 	} |  | ||||||
| 	formatter, err := findFmt(format) |  | ||||||
| 	fatal(err) |  | ||||||
| 
 |  | ||||||
| 	features, err := parseFeatures(tags, paths) |  | ||||||
| 	fatal(err) |  | ||||||
| 
 |  | ||||||
| 	r := runner{ |  | ||||||
| 		fmt:           formatter, |  | ||||||
| 		initializer:   contextInitializer, |  | ||||||
| 		features:      features, |  | ||||||
| 		stopOnFailure: sof, |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	var failed bool |  | ||||||
| 	if concurrency > 1 { |  | ||||||
| 		failed = r.concurrent(concurrency) |  | ||||||
| 	} else { |  | ||||||
| 		failed = r.run() |  | ||||||
| 	} |  | ||||||
| 	if failed { |  | ||||||
| 		return 1 |  | ||||||
| 	} |  | ||||||
| 	return 0 |  | ||||||
| } | } | ||||||
|  |  | ||||||
		Загрузка…
	
	Создание таблицы
		
		Сослаться в новой задаче
	
	 gedi
						gedi