a try to make the Junit test to pass on older go versions
Этот коммит содержится в:
		
							родитель
							
								
									10ac7158d1
								
							
						
					
					
						коммит
						46ec5fdb90
					
				
					 3 изменённых файлов: 82 добавлений и 73 удалений
				
			
		|  | @ -126,7 +126,7 @@ func buildJUNITPackageSuite(suiteName string, startedAt time.Time, features []*f | |||
| 		Time:       timeNowFunc().Sub(startedAt).String(), | ||||
| 	} | ||||
| 
 | ||||
| 	sort.Sort(sortByOrderGiven(features)) | ||||
| 	sort.Sort(sortByName(features)) | ||||
| 
 | ||||
| 	for idx, feat := range features { | ||||
| 		ts := junitTestSuite{ | ||||
|  |  | |||
							
								
								
									
										147
									
								
								run_test.go
									
										
									
									
									
								
							
							
						
						
									
										147
									
								
								run_test.go
									
										
									
									
									
								
							|  | @ -8,6 +8,7 @@ import ( | |||
| 	"os" | ||||
| 	"strings" | ||||
| 	"testing" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/DATA-DOG/godog/colors" | ||||
| 	"github.com/DATA-DOG/godog/gherkin" | ||||
|  | @ -324,89 +325,91 @@ func TestSucceedWithJunitAndConcurrencyOption(t *testing.T) { | |||
| 		Output:      output, | ||||
| 	} | ||||
| 
 | ||||
| 	zeroSecondsString := (0 * time.Second).String() | ||||
| 
 | ||||
| 	expectedOutput := `<?xml version="1.0" encoding="UTF-8"?> | ||||
| <testsuites name="succeed" tests="60" skipped="0" failures="0" errors="0" time="0s"> | ||||
|   <testsuite name="run background" tests="3" skipped="0" failures="0" errors="0" time="0s"> | ||||
|     <testcase name="should run background steps" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should skip all consequent steps on failure" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should continue undefined steps" status="passed" time="0s"></testcase> | ||||
| <testsuites name="succeed" tests="60" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|   <testsuite name="cucumber json formatter" tests="9" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|     <testcase name="Support of Feature Plus Scenario Node" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="Support of Feature Plus Scenario Node With Tags" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="Support of Feature Plus Scenario Outline" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="Support of Feature Plus Scenario Outline With Tags" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="Support of Feature Plus Scenario With Steps" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="Support of Feature Plus Scenario Outline With Steps" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="Support of Comments" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="Support of Docstrings" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="Support of Undefined, Pending and Skipped status" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|   </testsuite> | ||||
|   <testsuite name="cucumber json formatter" tests="9" skipped="0" failures="0" errors="0" time="0s"> | ||||
|     <testcase name="Support of Feature Plus Scenario Node" status="passed" time="0s"></testcase> | ||||
|     <testcase name="Support of Feature Plus Scenario Node With Tags" status="passed" time="0s"></testcase> | ||||
|     <testcase name="Support of Feature Plus Scenario Outline" status="passed" time="0s"></testcase> | ||||
|     <testcase name="Support of Feature Plus Scenario Outline With Tags" status="passed" time="0s"></testcase> | ||||
|     <testcase name="Support of Feature Plus Scenario With Steps" status="passed" time="0s"></testcase> | ||||
|     <testcase name="Support of Feature Plus Scenario Outline With Steps" status="passed" time="0s"></testcase> | ||||
|     <testcase name="Support of Comments" status="passed" time="0s"></testcase> | ||||
|     <testcase name="Support of Docstrings" status="passed" time="0s"></testcase> | ||||
|     <testcase name="Support of Undefined, Pending and Skipped status" status="passed" time="0s"></testcase> | ||||
|   <testsuite name="event stream formatter" tests="3" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|     <testcase name="should fire only suite events without any scenario" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should process simple scenario" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should process outline scenario" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|   </testsuite> | ||||
|   <testsuite name="suite events" tests="6" skipped="0" failures="0" errors="0" time="0s"> | ||||
|     <testcase name="triggers before scenario event" status="passed" time="0s"></testcase> | ||||
|     <testcase name="triggers appropriate events for a single scenario" status="passed" time="0s"></testcase> | ||||
|     <testcase name="triggers appropriate events whole feature" status="passed" time="0s"></testcase> | ||||
|     <testcase name="triggers appropriate events for two feature files" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should not trigger events on empty feature" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should not trigger events on empty scenarios" status="passed" time="0s"></testcase> | ||||
|   <testsuite name="load features" tests="6" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|     <testcase name="load features within path" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="load a specific feature file" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="loaded feature should have a number of scenarios #1" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="loaded feature should have a number of scenarios #2" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="loaded feature should have a number of scenarios #3" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="load a number of feature files" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|   </testsuite> | ||||
|   <testsuite name="event stream formatter" tests="3" skipped="0" failures="0" errors="0" time="0s"> | ||||
|     <testcase name="should fire only suite events without any scenario" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should process simple scenario" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should process outline scenario" status="passed" time="0s"></testcase> | ||||
|   <testsuite name="run background" tests="3" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|     <testcase name="should run background steps" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should skip all consequent steps on failure" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should continue undefined steps" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|   </testsuite> | ||||
|   <testsuite name="užkrauti savybes" tests="1" skipped="0" failures="0" errors="0" time="0s"> | ||||
|     <testcase name="savybių užkrovimas iš aplanko" status="passed" time="0s"></testcase> | ||||
|   <testsuite name="run features" tests="11" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|     <testcase name="should run a normal feature" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should skip steps after failure" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should skip all scenarios if background fails" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should skip steps after undefined" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should match undefined steps in a row" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should skip steps on pending" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should handle pending step" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should mark undefined steps after pending" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should fail suite if undefined steps follow after the failure" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should fail suite and skip pending step after failed step" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should fail suite and skip next step after failed step" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|   </testsuite> | ||||
|   <testsuite name="load features" tests="6" skipped="0" failures="0" errors="0" time="0s"> | ||||
|     <testcase name="load features within path" status="passed" time="0s"></testcase> | ||||
|     <testcase name="load a specific feature file" status="passed" time="0s"></testcase> | ||||
|     <testcase name="loaded feature should have a number of scenarios #1" status="passed" time="0s"></testcase> | ||||
|     <testcase name="loaded feature should have a number of scenarios #2" status="passed" time="0s"></testcase> | ||||
|     <testcase name="loaded feature should have a number of scenarios #3" status="passed" time="0s"></testcase> | ||||
|     <testcase name="load a number of feature files" status="passed" time="0s"></testcase> | ||||
|   <testsuite name="run features with nested steps" tests="6" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|     <testcase name="should run passing multistep successfully" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should fail multistep" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should fail nested multistep" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should skip steps after undefined multistep" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should match undefined steps in a row" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should mark undefined steps after pending" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|   </testsuite> | ||||
|   <testsuite name="run features with nested steps" tests="6" skipped="0" failures="0" errors="0" time="0s"> | ||||
|     <testcase name="should run passing multistep successfully" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should fail multistep" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should fail nested multistep" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should skip steps after undefined multistep" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should match undefined steps in a row" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should mark undefined steps after pending" status="passed" time="0s"></testcase> | ||||
|   <testsuite name="run outline" tests="6" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|     <testcase name="should run a normal outline" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should continue through examples on failure" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should skip examples on background failure" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should translate step table body" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should translate step doc string argument #1" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should translate step doc string argument #2" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|   </testsuite> | ||||
|   <testsuite name="run features" tests="11" skipped="0" failures="0" errors="0" time="0s"> | ||||
|     <testcase name="should run a normal feature" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should skip steps after failure" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should skip all scenarios if background fails" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should skip steps after undefined" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should match undefined steps in a row" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should skip steps on pending" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should handle pending step" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should mark undefined steps after pending" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should fail suite if undefined steps follow after the failure" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should fail suite and skip pending step after failed step" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should fail suite and skip next step after failed step" status="passed" time="0s"></testcase> | ||||
|   <testsuite name="suite events" tests="6" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|     <testcase name="triggers before scenario event" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="triggers appropriate events for a single scenario" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="triggers appropriate events whole feature" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="triggers appropriate events for two feature files" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should not trigger events on empty feature" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should not trigger events on empty scenarios" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|   </testsuite> | ||||
|   <testsuite name="undefined step snippets" tests="5" skipped="0" failures="0" errors="0" time="0s"> | ||||
|     <testcase name="should generate snippets" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should generate snippets with more arguments" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should handle escaped symbols" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should handle string argument followed by comma" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should handle arguments in the beggining or end of the step" status="passed" time="0s"></testcase> | ||||
|   <testsuite name="tag filters" tests="4" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|     <testcase name="should filter outline examples by tags" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should filter scenarios by X tag" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should filter scenarios by X tag not having Y" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should filter scenarios having Y and Z tags" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|   </testsuite> | ||||
|   <testsuite name="run outline" tests="6" skipped="0" failures="0" errors="0" time="0s"> | ||||
|     <testcase name="should run a normal outline" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should continue through examples on failure" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should skip examples on background failure" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should translate step table body" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should translate step doc string argument #1" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should translate step doc string argument #2" status="passed" time="0s"></testcase> | ||||
|   <testsuite name="undefined step snippets" tests="5" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|     <testcase name="should generate snippets" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should generate snippets with more arguments" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should handle escaped symbols" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should handle string argument followed by comma" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|     <testcase name="should handle arguments in the beggining or end of the step" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|   </testsuite> | ||||
|   <testsuite name="tag filters" tests="4" skipped="0" failures="0" errors="0" time="0s"> | ||||
|     <testcase name="should filter outline examples by tags" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should filter scenarios by X tag" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should filter scenarios by X tag not having Y" status="passed" time="0s"></testcase> | ||||
|     <testcase name="should filter scenarios having Y and Z tags" status="passed" time="0s"></testcase> | ||||
|   <testsuite name="užkrauti savybes" tests="1" skipped="0" failures="0" errors="0" time="` + zeroSecondsString + `"> | ||||
|     <testcase name="savybių užkrovimas iš aplanko" status="passed" time="` + zeroSecondsString + `"></testcase> | ||||
|   </testsuite> | ||||
| </testsuites>` | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										6
									
								
								suite.go
									
										
									
									
									
								
							
							
						
						
									
										6
									
								
								suite.go
									
										
									
									
									
								
							|  | @ -49,6 +49,12 @@ func (f feature) appendStepResult(s *stepResult) { | |||
| 	scenario.Steps = append(scenario.Steps, s) | ||||
| } | ||||
| 
 | ||||
| type sortByName []*feature | ||||
| 
 | ||||
| func (s sortByName) Len() int           { return len(s) } | ||||
| func (s sortByName) Less(i, j int) bool { return s[i].Name < s[j].Name } | ||||
| func (s sortByName) Swap(i, j int)      { s[i], s[j] = s[j], s[i] } | ||||
| 
 | ||||
| type scenario struct { | ||||
| 	Name        string | ||||
| 	OutlineName string | ||||
|  |  | |||
		Загрузка…
	
	Создание таблицы
		
		Сослаться в новой задаче
	
	 Fredrik Lönnblad
						Fredrik Lönnblad