How to use Test method of rerun Package

Best Gauge code snippet using rerun.Test

main_test.go

Source:main_test.go Github

copy

Full Screen

...11 "gotest.tools/v3/assert/cmp"12 "gotest.tools/v3/env"13 "gotest.tools/v3/golden"14)15func TestUsage_WithFlagsFromSetupFlags(t *testing.T) {16 defer env.PatchAll(t, nil)()17 name := "gotestsum"18 flags, _ := setupFlags(name)19 buf := new(bytes.Buffer)20 usage(buf, name, flags)21 golden.Assert(t, buf.String(), "gotestsum-help-text")22}23func TestOptions_Validate_FromFlags(t *testing.T) {24 type testCase struct {25 name string26 args []string27 expected string28 }29 fn := func(t *testing.T, tc testCase) {30 flags, opts := setupFlags("gotestsum")31 err := flags.Parse(tc.args)32 assert.NilError(t, err)33 opts.args = flags.Args()34 err = opts.Validate()35 if tc.expected == "" {36 assert.NilError(t, err)37 return38 }39 assert.ErrorContains(t, err, tc.expected, "opts: %#v", opts)40 }41 var testCases = []testCase{42 {43 name: "no flags",44 },45 {46 name: "rerun flag, raw command",47 args: []string{"--rerun-fails", "--raw-command", "--", "./test-all"},48 },49 {50 name: "rerun flag, no go-test args",51 args: []string{"--rerun-fails", "--"},52 },53 {54 name: "rerun flag, go-test args, no packages flag",55 args: []string{"--rerun-fails", "--", "./..."},56 expected: "the list of packages to test must be specified by the --packages flag",57 },58 {59 name: "rerun flag, go-test args, with packages flag",60 args: []string{"--rerun-fails", "--packages", "./...", "--", "--foo"},61 },62 {63 name: "rerun flag, no go-test args, with packages flag",64 args: []string{"--rerun-fails", "--packages", "./..."},65 },66 }67 for _, tc := range testCases {68 t.Run(tc.name, func(t *testing.T) {69 fn(t, tc)70 })71 }72}73func TestGoTestCmdArgs(t *testing.T) {74 type testCase struct {75 opts *options76 rerunOpts rerunOpts77 env []string78 expected []string79 }80 run := func(t *testing.T, name string, tc testCase) {81 t.Helper()82 runCase(t, name, func(t *testing.T) {83 defer env.PatchAll(t, env.ToMap(tc.env))()84 actual := goTestCmdArgs(tc.opts, tc.rerunOpts)85 assert.DeepEqual(t, actual, tc.expected)86 })87 }88 run(t, "raw command", testCase{89 opts: &options{90 rawCommand: true,91 args: []string{"./script", "-test.timeout=20m"},92 },93 expected: []string{"./script", "-test.timeout=20m"},94 })95 run(t, "no args", testCase{96 opts: &options{},97 expected: []string{"go", "test", "-json", "./..."},98 })99 run(t, "no args, with rerunPackageList arg", testCase{100 opts: &options{101 packages: []string{"./pkg"},102 },103 expected: []string{"go", "test", "-json", "./pkg"},104 })105 run(t, "TEST_DIRECTORY env var no args", testCase{106 opts: &options{},107 env: []string{"TEST_DIRECTORY=testdir"},108 expected: []string{"go", "test", "-json", "testdir"},109 })110 run(t, "TEST_DIRECTORY env var with args", testCase{111 opts: &options{112 args: []string{"-tags=integration"},113 },114 env: []string{"TEST_DIRECTORY=testdir"},115 expected: []string{"go", "test", "-json", "-tags=integration", "testdir"},116 })117 run(t, "no -json arg", testCase{118 opts: &options{119 args: []string{"-timeout=2m", "./pkg"},120 },121 expected: []string{"go", "test", "-json", "-timeout=2m", "./pkg"},122 })123 run(t, "with -json arg", testCase{124 opts: &options{125 args: []string{"-json", "-timeout=2m", "./pkg"},126 },127 expected: []string{"go", "test", "-json", "-timeout=2m", "./pkg"},128 })129 run(t, "raw command, with rerunOpts", testCase{130 opts: &options{131 rawCommand: true,132 args: []string{"./script", "-test.timeout=20m"},133 },134 rerunOpts: rerunOpts{135 runFlag: "-run=TestOne|TestTwo",136 pkg: "./fails",137 },138 expected: []string{"./script", "-test.timeout=20m", "-run=TestOne|TestTwo", "./fails"},139 })140 run(t, "no args, with rerunOpts", testCase{141 opts: &options{},142 rerunOpts: rerunOpts{143 runFlag: "-run=TestOne|TestTwo",144 pkg: "./fails",145 },146 expected: []string{"go", "test", "-json", "-run=TestOne|TestTwo", "./fails"},147 })148 run(t, "TEST_DIRECTORY env var, no args, with rerunOpts", testCase{149 opts: &options{},150 rerunOpts: rerunOpts{151 runFlag: "-run=TestOne|TestTwo",152 pkg: "./fails",153 },154 env: []string{"TEST_DIRECTORY=testdir"},155 // TEST_DIRECTORY should be overridden by rerun opts156 expected: []string{"go", "test", "-json", "-run=TestOne|TestTwo", "./fails"},157 })158 run(t, "TEST_DIRECTORY env var, with args, with rerunOpts", testCase{159 opts: &options{160 args: []string{"-tags=integration"},161 },162 rerunOpts: rerunOpts{163 runFlag: "-run=TestOne|TestTwo",164 pkg: "./fails",165 },166 env: []string{"TEST_DIRECTORY=testdir"},167 expected: []string{"go", "test", "-json", "-run=TestOne|TestTwo", "-tags=integration", "./fails"},168 })169 run(t, "no -json arg, with rerunOpts", testCase{170 opts: &options{171 args: []string{"-timeout=2m"},172 packages: []string{"./pkg"},173 },174 rerunOpts: rerunOpts{175 runFlag: "-run=TestOne|TestTwo",176 pkg: "./fails",177 },178 expected: []string{"go", "test", "-json", "-run=TestOne|TestTwo", "-timeout=2m", "./fails"},179 })180 run(t, "with -json arg, with rerunOpts", testCase{181 opts: &options{182 args: []string{"-json", "-timeout=2m"},183 packages: []string{"./pkg"},184 },185 rerunOpts: rerunOpts{186 runFlag: "-run=TestOne|TestTwo",187 pkg: "./fails",188 },189 expected: []string{"go", "test", "-run=TestOne|TestTwo", "-json", "-timeout=2m", "./fails"},190 })191 run(t, "with args, with reunFailsPackageList args, with rerunOpts", testCase{192 opts: &options{193 args: []string{"-timeout=2m"},194 packages: []string{"./pkg1", "./pkg2", "./pkg3"},195 },196 rerunOpts: rerunOpts{197 runFlag: "-run=TestOne|TestTwo",198 pkg: "./fails",199 },200 expected: []string{"go", "test", "-json", "-run=TestOne|TestTwo", "-timeout=2m", "./fails"},201 })202 run(t, "with args, with reunFailsPackageList", testCase{203 opts: &options{204 args: []string{"-timeout=2m"},205 packages: []string{"./pkg1", "./pkg2", "./pkg3"},206 },207 expected: []string{"go", "test", "-json", "-timeout=2m", "./pkg1", "./pkg2", "./pkg3"},208 })209 run(t, "reunFailsPackageList args, with rerunOpts ", testCase{210 opts: &options{211 packages: []string{"./pkg1", "./pkg2", "./pkg3"},212 },213 rerunOpts: rerunOpts{214 runFlag: "-run=TestOne|TestTwo",215 pkg: "./fails",216 },217 expected: []string{"go", "test", "-json", "-run=TestOne|TestTwo", "./fails"},218 })219 run(t, "reunFailsPackageList args, with rerunOpts, with -args ", testCase{220 opts: &options{221 args: []string{"before", "-args", "after"},222 packages: []string{"./pkg1"},223 },224 rerunOpts: rerunOpts{225 runFlag: "-run=TestOne|TestTwo",226 pkg: "./fails",227 },228 expected: []string{"go", "test", "-json", "-run=TestOne|TestTwo", "before", "./fails", "-args", "after"},229 })230 run(t, "reunFailsPackageList args, with rerunOpts, with -args at end", testCase{231 opts: &options{232 args: []string{"before", "-args"},233 packages: []string{"./pkg1"},234 },235 rerunOpts: rerunOpts{236 runFlag: "-run=TestOne|TestTwo",237 pkg: "./fails",238 },239 expected: []string{"go", "test", "-json", "-run=TestOne|TestTwo", "before", "./fails", "-args"},240 })241 run(t, "reunFailsPackageList args, with -args at start", testCase{242 opts: &options{243 args: []string{"-args", "after"},244 packages: []string{"./pkg1"},245 },246 expected: []string{"go", "test", "-json", "./pkg1", "-args", "after"},247 })248 run(t, "-run arg at start, with rerunOpts ", testCase{249 opts: &options{250 args: []string{"-run=TestFoo", "-args"},251 packages: []string{"./pkg"},252 },253 rerunOpts: rerunOpts{254 runFlag: "-run=TestOne|TestTwo",255 pkg: "./fails",256 },257 expected: []string{"go", "test", "-json", "-run=TestOne|TestTwo", "./fails", "-args"},258 })259 run(t, "-run arg in middle, with rerunOpts ", testCase{260 opts: &options{261 args: []string{"-count", "1", "--run", "TestFoo", "-args"},262 packages: []string{"./pkg"},263 },264 rerunOpts: rerunOpts{265 runFlag: "-run=TestOne|TestTwo",266 pkg: "./fails",267 },268 expected: []string{"go", "test", "-json", "-run=TestOne|TestTwo", "-count", "1", "./fails", "-args"},269 })270 run(t, "-run arg at end with missing value, with rerunOpts ", testCase{271 opts: &options{272 args: []string{"-count", "1", "-run"},273 packages: []string{"./pkg"},274 },275 rerunOpts: rerunOpts{276 runFlag: "-run=TestOne|TestTwo",277 pkg: "./fails",278 },279 expected: []string{"go", "test", "-json", "-run=TestOne|TestTwo", "-count", "1", "-run", "./fails"},280 })281}282func runCase(t *testing.T, name string, fn func(t *testing.T)) {283 t.Helper()284 t.Run(name, func(t *testing.T) {285 t.Helper()286 t.Log("case:", name)287 fn(t)288 })289}290func TestRun_RerunFails_WithTooManyInitialFailures(t *testing.T) {291 jsonFailed := `{"Package": "pkg", "Action": "run"}292{"Package": "pkg", "Test": "TestOne", "Action": "run"}293{"Package": "pkg", "Test": "TestOne", "Action": "fail"}294{"Package": "pkg", "Test": "TestTwo", "Action": "run"}295{"Package": "pkg", "Test": "TestTwo", "Action": "fail"}296{"Package": "pkg", "Action": "fail"}297`298 fn := func(args []string) *proc {299 return &proc{300 cmd: fakeWaiter{result: newExitCode("failed", 1)},301 stdout: strings.NewReader(jsonFailed),302 stderr: bytes.NewReader(nil),303 }304 }305 reset := patchStartGoTestFn(fn)306 defer reset()307 out := new(bytes.Buffer)308 opts := &options{309 rawCommand: true,310 args: []string{"./test.test"},311 format: "testname",312 rerunFailsMaxAttempts: 3,313 rerunFailsMaxInitialFailures: 1,314 stdout: out,315 stderr: os.Stderr,316 hideSummary: newHideSummaryValue(),317 }318 err := run(opts)319 assert.ErrorContains(t, err, "number of test failures (2) exceeds maximum (1)", out.String())320}321func TestRun_RerunFails_BuildErrorPreventsRerun(t *testing.T) {322 jsonFailed := `{"Package": "pkg", "Action": "run"}323{"Package": "pkg", "Test": "TestOne", "Action": "run"}324{"Package": "pkg", "Test": "TestOne", "Action": "fail"}325{"Package": "pkg", "Test": "TestTwo", "Action": "run"}326{"Package": "pkg", "Test": "TestTwo", "Action": "fail"}327{"Package": "pkg", "Action": "fail"}328`329 fn := func(args []string) *proc {330 return &proc{331 cmd: fakeWaiter{result: newExitCode("failed", 1)},332 stdout: strings.NewReader(jsonFailed),333 stderr: strings.NewReader("anything here is an error\n"),334 }335 }336 reset := patchStartGoTestFn(fn)337 defer reset()338 out := new(bytes.Buffer)339 opts := &options{340 rawCommand: true,341 args: []string{"./test.test"},342 format: "testname",343 rerunFailsMaxAttempts: 3,344 rerunFailsMaxInitialFailures: 1,345 stdout: out,346 stderr: os.Stderr,347 hideSummary: newHideSummaryValue(),348 }349 err := run(opts)350 assert.ErrorContains(t, err, "rerun aborted because previous run had errors", out.String())351}352// type checking of os/exec.ExitError is done in a test file so that users353// installing from source can continue to use versions prior to go1.12.354var _ exitCoder = &exec.ExitError{}355func TestRun_RerunFails_PanicPreventsRerun(t *testing.T) {356 jsonFailed := `{"Package": "pkg", "Action": "run"}357{"Package": "pkg", "Test": "TestOne", "Action": "run"}358{"Package": "pkg", "Test": "TestOne", "Action": "output","Output":"panic: something went wrong\n"}359{"Package": "pkg", "Action": "fail"}360`361 fn := func(args []string) *proc {362 return &proc{363 cmd: fakeWaiter{result: newExitCode("failed", 1)},364 stdout: strings.NewReader(jsonFailed),365 stderr: bytes.NewReader(nil),366 }367 }368 reset := patchStartGoTestFn(fn)369 defer reset()370 out := new(bytes.Buffer)371 opts := &options{372 rawCommand: true,373 args: []string{"./test.test"},374 format: "testname",375 rerunFailsMaxAttempts: 3,376 rerunFailsMaxInitialFailures: 1,377 stdout: out,378 stderr: os.Stderr,379 hideSummary: newHideSummaryValue(),380 }381 err := run(opts)382 assert.ErrorContains(t, err, "rerun aborted because previous run had a suspected panic", out.String())383}384func TestRun_InputFromStdin(t *testing.T) {385 stdin := os.Stdin386 t.Cleanup(func() { os.Stdin = stdin })387 r, w, err := os.Pipe()388 assert.NilError(t, err)389 t.Cleanup(func() { _ = r.Close() })390 os.Stdin = r391 go func() {392 defer func() { _ = w.Close() }()393 e := json.NewEncoder(w)394 for _, event := range []testjson.TestEvent{395 {Action: "run", Package: "pkg"},396 {Action: "run", Package: "pkg", Test: "TestOne"},397 {Action: "fail", Package: "pkg", Test: "TestOne"},398 {Action: "fail", Package: "pkg"},399 } {400 assert.Check(t, e.Encode(event))401 }402 }()403 stdout := new(bytes.Buffer)404 err = run(&options{405 args: []string{"cat"},406 format: "testname",407 hideSummary: newHideSummaryValue(),408 rawCommand: true,409 stdout: stdout,410 stderr: os.Stderr,411 })...

Full Screen

Full Screen

main.go

Source:main.go Github

copy

Full Screen

...36}37func setupFlags(name string) (*pflag.FlagSet, *options) {38 opts := &options{39 hideSummary: newHideSummaryValue(),40 junitTestCaseClassnameFormat: &junitFieldFormatValue{},41 junitTestSuiteNameFormat: &junitFieldFormatValue{},42 postRunHookCmd: &commandValue{},43 stdout: os.Stdout,44 stderr: os.Stderr,45 }46 flags := pflag.NewFlagSet(name, pflag.ContinueOnError)47 flags.SetInterspersed(false)48 flags.Usage = func() {49 usage(os.Stdout, name, flags)50 }51 flags.StringVarP(&opts.format, "format", "f",52 lookEnvWithDefault("GOTESTSUM_FORMAT", "short"),53 "print format of test input")54 flags.BoolVar(&opts.rawCommand, "raw-command", false,55 "don't prepend 'go test -json' to the 'go test' command")56 flags.BoolVar(&opts.ignoreNonJSONOutputLines, "ignore-non-json-output-lines", false,57 "write non-JSON 'go test' output lines to stderr instead of failing")58 flags.Lookup("ignore-non-json-output-lines").Hidden = true59 flags.StringVar(&opts.jsonFile, "jsonfile",60 lookEnvWithDefault("GOTESTSUM_JSONFILE", ""),61 "write all TestEvents to file")62 flags.BoolVar(&opts.noColor, "no-color", color.NoColor, "disable color output")63 flags.Var(opts.hideSummary, "no-summary",64 "do not print summary of: "+testjson.SummarizeAll.String())65 flags.Lookup("no-summary").Hidden = true66 flags.Var(opts.hideSummary, "hide-summary",67 "hide sections of the summary: "+testjson.SummarizeAll.String())68 flags.Var(opts.postRunHookCmd, "post-run-command",69 "command to run after the tests have completed")70 flags.BoolVar(&opts.watch, "watch", false,71 "watch go files, and run tests when a file is modified")72 flags.IntVar(&opts.maxFails, "max-fails", 0,73 "end the test run after this number of failures")74 flags.StringVar(&opts.junitFile, "junitfile",75 lookEnvWithDefault("GOTESTSUM_JUNITFILE", ""),76 "write a JUnit XML file")77 flags.Var(opts.junitTestSuiteNameFormat, "junitfile-testsuite-name",78 "format the testsuite name field as: "+junitFieldFormatValues)79 flags.Var(opts.junitTestCaseClassnameFormat, "junitfile-testcase-classname",80 "format the testcase classname field as: "+junitFieldFormatValues)81 flags.IntVar(&opts.rerunFailsMaxAttempts, "rerun-fails", 0,82 "rerun failed tests until they all pass, or attempts exceeds maximum. Defaults to max 2 reruns when enabled.")83 flags.Lookup("rerun-fails").NoOptDefVal = "2"84 flags.IntVar(&opts.rerunFailsMaxInitialFailures, "rerun-fails-max-failures", 10,85 "do not rerun any tests if the initial run has more than this number of failures")86 flags.Var((*stringSlice)(&opts.packages), "packages",87 "space separated list of package to test")88 flags.StringVar(&opts.rerunFailsReportFile, "rerun-fails-report", "",89 "write a report to the file, of the tests that were rerun")90 flags.BoolVar(&opts.rerunFailsOnlyRootCases, "rerun-fails-only-root-testcases", false,91 "rerun only root testcaes, instead of only subtests")92 flags.Lookup("rerun-fails-only-root-testcases").Hidden = true93 flags.BoolVar(&opts.debug, "debug", false, "enabled debug logging")94 flags.BoolVar(&opts.version, "version", false, "show version and exit")95 return flags, opts96}97func usage(out io.Writer, name string, flags *pflag.FlagSet) {98 fmt.Fprintf(out, `Usage:99 %[1]s [flags] [--] [go test flags]100 %[1]s [command]101Flags:102`, name)103 flags.SetOutput(out)104 flags.PrintDefaults()105 fmt.Fprint(out, `106Formats:107 dots print a character for each test108 dots-v2 experimental dots format, one package per line109 pkgname print a line for each package110 pkgname-and-test-fails print a line for each package and failed test output111 testname print a line for each test and package112 standard-quiet standard go test format113 standard-verbose standard go test -v format114Commands:115 tool tools for working with test2json output116`)117}118func lookEnvWithDefault(key, defValue string) string {119 if value := os.Getenv(key); value != "" {120 return value121 }122 return defValue123}124type options struct {125 args []string126 format string127 debug bool128 rawCommand bool129 ignoreNonJSONOutputLines bool130 jsonFile string131 junitFile string132 postRunHookCmd *commandValue133 noColor bool134 hideSummary *hideSummaryValue135 junitTestSuiteNameFormat *junitFieldFormatValue136 junitTestCaseClassnameFormat *junitFieldFormatValue137 rerunFailsMaxAttempts int138 rerunFailsMaxInitialFailures int139 rerunFailsReportFile string140 rerunFailsOnlyRootCases bool141 packages []string142 watch bool143 maxFails int144 version bool145 // shims for testing146 stdout io.Writer147 stderr io.Writer148}149func (o options) Validate() error {150 if o.rerunFailsMaxAttempts > 0 && len(o.args) > 0 && !o.rawCommand && len(o.packages) == 0 {151 return fmt.Errorf(152 "when go test args are used with --rerun-fails-max-attempts " +153 "the list of packages to test must be specified by the --packages flag")154 }155 return nil156}157func setupLogging(opts *options) {158 if opts.debug {159 log.SetLevel(log.DebugLevel)160 }161 color.NoColor = opts.noColor162}163func run(opts *options) error {164 ctx, cancel := context.WithCancel(context.Background())165 defer cancel()166 if err := opts.Validate(); err != nil {167 return err168 }169 goTestProc, err := startGoTestFn(ctx, goTestCmdArgs(opts, rerunOpts{}))170 if err != nil {171 return err172 }173 handler, err := newEventHandler(opts)174 if err != nil {175 return err176 }177 defer handler.Close() // nolint: errcheck178 cfg := testjson.ScanConfig{179 Stdout: goTestProc.stdout,180 Stderr: goTestProc.stderr,181 Handler: handler,182 Stop: cancel,183 IgnoreNonJSONOutputLines: opts.ignoreNonJSONOutputLines,184 }185 exec, err := testjson.ScanTestOutput(cfg)186 if err != nil {187 return finishRun(opts, exec, err)188 }189 exitErr := goTestProc.cmd.Wait()190 if exitErr == nil || opts.rerunFailsMaxAttempts == 0 {191 return finishRun(opts, exec, exitErr)192 }193 if err := hasErrors(exitErr, exec); err != nil {194 return finishRun(opts, exec, err)195 }196 failed := len(rerunFailsFilter(opts)(exec.Failed()))197 if failed > opts.rerunFailsMaxInitialFailures {198 err := fmt.Errorf(199 "number of test failures (%d) exceeds maximum (%d) set by --rerun-fails-max-failures",200 failed, opts.rerunFailsMaxInitialFailures)201 return finishRun(opts, exec, err)202 }203 cfg = testjson.ScanConfig{Execution: exec, Handler: handler}204 exitErr = rerunFailed(ctx, opts, cfg)205 if err := writeRerunFailsReport(opts, exec); err != nil {206 return err207 }208 return finishRun(opts, exec, exitErr)209}210func finishRun(opts *options, exec *testjson.Execution, exitErr error) error {211 testjson.PrintSummary(opts.stdout, exec, opts.hideSummary.value)212 if err := writeJUnitFile(opts, exec); err != nil {213 return fmt.Errorf("failed to write junit file: %w", err)214 }215 if err := postRunHook(opts, exec); err != nil {216 return fmt.Errorf("post run command failed: %w", err)217 }218 return exitErr219}220func goTestCmdArgs(opts *options, rerunOpts rerunOpts) []string {221 if opts.rawCommand {222 var result []string223 result = append(result, opts.args...)224 result = append(result, rerunOpts.Args()...)225 return result226 }227 args := opts.args228 result := []string{"go", "test"}229 if len(args) == 0 {230 result = append(result, "-json")231 if rerunOpts.runFlag != "" {232 result = append(result, rerunOpts.runFlag)233 }234 return append(result, cmdArgPackageList(opts, rerunOpts, "./...")...)235 }236 if boolArgIndex("json", args) < 0 {237 result = append(result, "-json")238 }239 if rerunOpts.runFlag != "" {240 // Remove any existing run arg, it needs to be replaced with our new one241 // and duplicate args are not allowed by 'go test'.242 runIndex, runIndexEnd := argIndex("run", args)243 if runIndex >= 0 && runIndexEnd < len(args) {244 args = append(args[:runIndex], args[runIndexEnd+1:]...)245 }246 result = append(result, rerunOpts.runFlag)247 }248 pkgArgIndex := findPkgArgPosition(args)249 result = append(result, args[:pkgArgIndex]...)250 result = append(result, cmdArgPackageList(opts, rerunOpts)...)251 result = append(result, args[pkgArgIndex:]...)252 return result253}254func cmdArgPackageList(opts *options, rerunOpts rerunOpts, defPkgList ...string) []string {255 switch {256 case rerunOpts.pkg != "":257 return []string{rerunOpts.pkg}258 case len(opts.packages) > 0:259 return opts.packages260 case os.Getenv("TEST_DIRECTORY") != "":261 return []string{os.Getenv("TEST_DIRECTORY")}262 default:263 return defPkgList264 }265}266func boolArgIndex(flag string, args []string) int {267 for i, arg := range args {268 if arg == "-"+flag || arg == "--"+flag {269 return i270 }271 }272 return -1273}274func argIndex(flag string, args []string) (start, end int) {275 for i, arg := range args {276 if arg == "-"+flag || arg == "--"+flag {277 return i, i + 1278 }279 if strings.HasPrefix(arg, "-"+flag+"=") || strings.HasPrefix(arg, "--"+flag+"=") {280 return i, i281 }282 }283 return -1, -1284}285// The package list is before the -args flag, or at the end of the args list286// if the -args flag is not in args.287// The -args flag is a 'go test' flag that indicates that all subsequent288// args should be passed to the test binary. It requires that the list of289// packages comes before -args, so we re-use it as a placeholder in the case290// where some args must be passed to the test binary.291func findPkgArgPosition(args []string) int {292 if i := boolArgIndex("args", args); i >= 0 {293 return i294 }295 return len(args)296}297type proc struct {298 cmd waiter299 stdout io.Reader300 stderr io.Reader301}302type waiter interface {303 Wait() error304}305func startGoTest(ctx context.Context, args []string) (proc, error) {306 if len(args) == 0 {307 return proc{}, errors.New("missing command to run")308 }309 cmd := exec.CommandContext(ctx, args[0], args[1:]...)310 p := proc{cmd: cmd}311 log.Debugf("exec: %s", cmd.Args)312 var err error313 p.stdout, err = cmd.StdoutPipe()314 if err != nil {315 return p, err316 }317 p.stderr, err = cmd.StderrPipe()318 if err != nil {319 return p, err...

Full Screen

Full Screen

rerunfails.go

Source:rerunfails.go Github

copy

Full Screen

...19 result = append(result, o.pkg)20 }21 return result22}23func newRerunOptsFromTestCase(tc testjson.TestCase) rerunOpts {24 return rerunOpts{25 runFlag: goTestRunFlagForTestCase(tc.Test),26 pkg: tc.Package,27 }28}29type testCaseFilter func([]testjson.TestCase) []testjson.TestCase30func rerunFailsFilter(o *options) testCaseFilter {31 if o.rerunFailsOnlyRootCases {32 return func(tcs []testjson.TestCase) []testjson.TestCase {33 return tcs34 }35 }36 return testjson.FilterFailedUnique37}38func rerunFailed(ctx context.Context, opts *options, scanConfig testjson.ScanConfig) error {39 ctx, cancel := context.WithCancel(ctx)40 defer cancel()41 tcFilter := rerunFailsFilter(opts)42 rec := newFailureRecorderFromExecution(scanConfig.Execution)43 for attempts := 0; rec.count() > 0 && attempts < opts.rerunFailsMaxAttempts; attempts++ {44 testjson.PrintSummary(opts.stdout, scanConfig.Execution, testjson.SummarizeNone)45 opts.stdout.Write([]byte("\n")) // nolint: errcheck46 nextRec := newFailureRecorder(scanConfig.Handler)47 for _, tc := range tcFilter(rec.failures) {48 goTestProc, err := startGoTestFn(ctx, goTestCmdArgs(opts, newRerunOptsFromTestCase(tc)))49 if err != nil {50 return err51 }52 cfg := testjson.ScanConfig{53 RunID: attempts + 1,54 Stdout: goTestProc.stdout,55 Stderr: goTestProc.stderr,56 Handler: nextRec,57 Execution: scanConfig.Execution,58 Stop: cancel,59 }60 if _, err := testjson.ScanTestOutput(cfg); err != nil {61 return err62 }63 exitErr := goTestProc.cmd.Wait()64 if exitErr != nil {65 nextRec.lastErr = exitErr66 }67 if err := hasErrors(exitErr, scanConfig.Execution); err != nil {68 return err69 }70 }71 rec = nextRec72 }73 return rec.lastErr74}75// startGoTestFn is a shim for testing76var startGoTestFn = startGoTest77func hasErrors(err error, exec *testjson.Execution) error {78 switch {79 case len(exec.Errors()) > 0:80 return fmt.Errorf("rerun aborted because previous run had errors")81 // Exit code 0 and 1 are expected.82 case ExitCodeWithDefault(err) > 1:83 return fmt.Errorf("unexpected go test exit code: %v", err)84 case exec.HasPanic():85 return fmt.Errorf("rerun aborted because previous run had a suspected panic and some test may not have run")86 default:87 return nil88 }89}90type failureRecorder struct {91 testjson.EventHandler92 failures []testjson.TestCase93 lastErr error94}95func newFailureRecorder(handler testjson.EventHandler) *failureRecorder {96 return &failureRecorder{EventHandler: handler}97}98func newFailureRecorderFromExecution(exec *testjson.Execution) *failureRecorder {99 return &failureRecorder{failures: exec.Failed()}100}101func (r *failureRecorder) Event(event testjson.TestEvent, execution *testjson.Execution) error {102 if !event.PackageEvent() && event.Action == testjson.ActionFail {103 pkg := execution.Package(event.Package)104 tc := pkg.LastFailedByName(event.Test)105 r.failures = append(r.failures, tc)106 }107 return r.EventHandler.Event(event, execution)108}109func (r *failureRecorder) count() int {110 return len(r.failures)111}112func goTestRunFlagForTestCase(test testjson.TestName) string {113 if test.IsSubTest() {114 root, sub := test.Split()115 return "-test.run=^" + root + "$/^" + sub + "$"116 }117 return "-test.run=^" + test.Name() + "$"118}119func writeRerunFailsReport(opts *options, exec *testjson.Execution) error {120 if opts.rerunFailsMaxAttempts == 0 || opts.rerunFailsReportFile == "" {121 return nil122 }123 type testCaseCounts struct {124 total int125 failed int126 }127 names := []string{}128 results := map[string]testCaseCounts{}129 for _, failure := range exec.Failed() {130 name := failure.Package + "." + failure.Test.Name()131 if _, ok := results[name]; ok {132 continue133 }134 names = append(names, name)135 pkg := exec.Package(failure.Package)136 counts := testCaseCounts{}137 for _, tc := range pkg.Failed {138 if tc.Test == failure.Test {139 counts.total++140 counts.failed++141 }142 }143 for _, tc := range pkg.Passed {144 if tc.Test == failure.Test {145 counts.total++146 }147 }148 // Skipped tests are not counted, but presumably skipped tests can not fail149 results[name] = counts150 }151 fh, err := os.Create(opts.rerunFailsReportFile)152 if err != nil {153 return err154 }155 sort.Strings(names)156 for _, name := range names {157 counts := results[name]158 fmt.Fprintf(fh, "%s: %d runs, %d failures\n", name, counts.total, counts.failed)...

Full Screen

Full Screen

Test

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 rerun.Test()4}5import (6func Test() {7 fmt.Println("Test function of re

Full Screen

Full Screen

Test

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 fmt.Println("Hello World!")4 rerun.Test()5}6import (7func Test() {8 fmt.Println("Hello rerun!")9}10import (11func TestTest(t *testing.T) {12 fmt.Println("Hello rerun_test!")13}14--- PASS: TestTest (0.00s)15import (16func Test() {17 fmt.Println("Hello rerun!")18 fmt.Println("Hello rerun!")19}20--- PASS: TestTest (0.00s)21--- PASS: TestTest (0.00s)22--- PASS: Test (0.00s)23--- PASS: TestTest (0.00s)

Full Screen

Full Screen

Test

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 rerun := new(rerun)4 rerun.Test()5}6import (7func main() {8 rerun := new(rerun)9 rerun.Test()10}11import (12func main() {13 rerun := new(rerun)14 rerun.Test()15}16import (17func main() {18 rerun := new(rerun)19 rerun.Test()20}21import (22func main() {23 rerun := new(r

Full Screen

Full Screen

Test

Using AI Code Generation

copy

Full Screen

1import(2func main(){3 x := rerun.Test()4 fmt.Println(x)5}6import(7func main(){8 x := rerun.Test()9 fmt.Println(x)10}11func Test() int{12}

Full Screen

Full Screen

Test

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 fmt.Println("Hello, playground")4 r := rerun{}5 r.Test()6}7import (8func main() {9 fmt.Println("Hello, playground")10 r := rerun{}11 r.Test()12}13import (14func main() {15 fmt.Println("Hello, playground")16 r := rerun{}17 r.Test()18}19import (20func main() {21 fmt.Println("Hello, playground")22 r := rerun{}23 r.Test()24}25import (26func main() {27 fmt.Println("Hello, playground")28 r := rerun{}29 r.Test()30}31import (32func main() {33 fmt.Println("Hello, playground")34 r := rerun{}35 r.Test()36}37import (38func main() {39 fmt.Println("Hello, playground")40 r := rerun{}41 r.Test()42}43import (44func main() {45 fmt.Println("Hello, playground")46 r := rerun{}47 r.Test()48}49import (50func main() {51 fmt.Println("Hello, playground")52 r := rerun{}53 r.Test()54}

Full Screen

Full Screen

Test

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 fmt.Println("Start")4 cmd := exec.Command("go", "run", "2.go")5 err := cmd.Run()6 if err != nil {7 log.Fatal(err)8 }9}10import (11func main() {12 fmt.Println("Start")13 c := make(chan os.Signal, 1)14 signal.Notify(c, os.Interrupt, syscall.SIGTERM)15 fmt.Println("End")16}

Full Screen

Full Screen

Test

Using AI Code Generation

copy

Full Screen

1func main() {2 r := rerun.Test{}3 r.Test()4}5func main() {6 r := rerun.Test{}7 r.Test()8}9func main() {10 r := rerun.Test{}11 r.Test()12}13func main() {14 r := rerun.Test{}15 r.Test()16}17func main() {18 r := rerun.Test{}19 r.Test()20}

Full Screen

Full Screen

Automation Testing Tutorials

Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.

LambdaTest Learning Hubs:

YouTube

You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.

Try LambdaTest Now !!

Get 100 minutes of automation test minutes FREE!!

Next-Gen App & Browser Testing Cloud

Was this article helpful?

Helpful

NotHelpful