 7017c73ef8
			
		
	
	
		7017c73ef8
		
			
		
	
	
	
	
		
			
			* Attempting to provide a useful implementation of something compatible with testing.T * Handle Fail calls on the TestingT in the right place * Provide as much of testing.T as possible + tidy up * Add initial tests for testingT support * Check compatibility with testing.T and friends Co-authored-by: Piotr Bocheński <bochenski.piotr@gmail.com> * Update assert-godogs example to show new usage. Rename 'GetTestingT(ctx)' to 'T(ctx)' * Update changelog and readme with new usage * Improve test coverage * Review updates --------- Co-authored-by: Piotr Bocheński <bochenski.piotr@gmail.com>
		
			
				
	
	
		
			687 строки
		
	
	
		
			Без EOL
		
	
	
		
			21 КиБ
		
	
	
	
		
			Gherkin
		
	
	
	
	
	
			
		
		
	
	
			687 строки
		
	
	
		
			Без EOL
		
	
	
		
			21 КиБ
		
	
	
	
		
			Gherkin
		
	
	
	
	
	
| Feature: pretty formatter
 | |
|   In order to support tools that import pretty output
 | |
|   I need to be able to support pretty formatted output
 | |
| 
 | |
|   Scenario: Support of Feature Plus Scenario Node
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         Feature: simple feature
 | |
|             simple feature description
 | |
|         Scenario: simple scenario
 | |
|             simple scenario description
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature
 | |
|         simple feature description
 | |
| 
 | |
|         Scenario: simple scenario # features/simple.feature:3
 | |
| 
 | |
|       1 scenarios (1 undefined)
 | |
|       No steps
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Support of Feature Plus Scenario Node With Tags
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         @TAG1
 | |
|         Feature: simple feature
 | |
|             simple feature description
 | |
|         @TAG2 @TAG3
 | |
|         Scenario: simple scenario
 | |
|             simple scenario description
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature
 | |
|         simple feature description
 | |
| 
 | |
|         Scenario: simple scenario # features/simple.feature:5
 | |
| 
 | |
|       1 scenarios (1 undefined)
 | |
|       No steps
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Support of Feature Plus Scenario Outline
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         Feature: simple feature
 | |
|             simple feature description
 | |
| 
 | |
|         Scenario Outline: simple scenario
 | |
|             simple scenario description
 | |
| 
 | |
|         Examples: simple examples
 | |
|         | status |
 | |
|         | pass   |
 | |
|         | fail   |
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature
 | |
|         simple feature description
 | |
| 
 | |
|         Scenario Outline: simple scenario # features/simple.feature:4
 | |
| 
 | |
|           Examples: simple examples
 | |
|             | status |
 | |
|             | pass   |
 | |
|             | fail   |
 | |
| 
 | |
|       2 scenarios (2 undefined)
 | |
|       No steps
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Support of Feature Plus Scenario Outline With Tags
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         @TAG1
 | |
|         Feature: simple feature
 | |
|             simple feature description
 | |
| 
 | |
|         @TAG2
 | |
|         Scenario Outline: simple scenario
 | |
|             simple scenario description
 | |
| 
 | |
|         @TAG3
 | |
|         Examples: simple examples
 | |
|         | status |
 | |
|         | pass   |
 | |
|         | fail   |
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature
 | |
|         simple feature description
 | |
| 
 | |
|         Scenario Outline: simple scenario # features/simple.feature:6
 | |
| 
 | |
|           Examples: simple examples
 | |
|             | status |
 | |
|             | pass   |
 | |
|             | fail   |
 | |
| 
 | |
|       2 scenarios (2 undefined)
 | |
|       No steps
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Support of Feature Plus Scenario With Steps
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         Feature: simple feature
 | |
|             simple feature description
 | |
| 
 | |
|         Scenario: simple scenario
 | |
|             simple scenario description
 | |
| 
 | |
|         Given passing step
 | |
|         Then a failing step
 | |
| 
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature
 | |
|         simple feature description
 | |
| 
 | |
|         Scenario: simple scenario # features/simple.feature:4
 | |
|           Given passing step      # suite_context.go:0 -> SuiteContext.func2
 | |
|           Then a failing step     # suite_context.go:0 -> *suiteContext
 | |
|           intentional failure
 | |
| 
 | |
|       --- Failed steps:
 | |
| 
 | |
|         Scenario: simple scenario # features/simple.feature:4
 | |
|           Then a failing step # features/simple.feature:8
 | |
|             Error: intentional failure
 | |
| 
 | |
| 
 | |
|       1 scenarios (1 failed)
 | |
|       2 steps (1 passed, 1 failed)
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Support of Feature Plus Scenario Outline With Steps
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|       Feature: simple feature
 | |
|         simple feature description
 | |
| 
 | |
|         Scenario Outline: simple scenario
 | |
|         simple scenario description
 | |
| 
 | |
|           Given <status> step
 | |
| 
 | |
|         Examples: simple examples
 | |
|         | status |
 | |
|         | passing |
 | |
|         | failing |
 | |
| 
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature
 | |
|         simple feature description
 | |
| 
 | |
|         Scenario Outline: simple scenario # features/simple.feature:4
 | |
|           Given <status> step             # suite_context.go:0 -> SuiteContext.func2
 | |
| 
 | |
|           Examples: simple examples
 | |
|             | status  |
 | |
|             | passing |
 | |
|             | failing |
 | |
|               intentional failure
 | |
| 
 | |
|       --- Failed steps:
 | |
| 
 | |
|         Scenario Outline: simple scenario # features/simple.feature:4
 | |
|           Given failing step # features/simple.feature:7
 | |
|             Error: intentional failure
 | |
| 
 | |
| 
 | |
|       2 scenarios (1 passed, 1 failed)
 | |
|       2 steps (1 passed, 1 failed)
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   # Currently godog only supports comments on Feature and not
 | |
|   # scenario and steps.
 | |
|   Scenario: Support of Comments
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         #Feature comment
 | |
|         Feature: simple feature
 | |
|           simple description
 | |
| 
 | |
|           Scenario: simple scenario
 | |
|           simple feature description
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature
 | |
|         simple description
 | |
| 
 | |
|         Scenario: simple scenario # features/simple.feature:5
 | |
| 
 | |
|       1 scenarios (1 undefined)
 | |
|       No steps
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Support of Docstrings
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         Feature: simple feature
 | |
|           simple description
 | |
| 
 | |
|           Scenario: simple scenario
 | |
|           simple feature description
 | |
| 
 | |
|           Given passing step
 | |
|           \"\"\" content type
 | |
|           step doc string
 | |
|           \"\"\"
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature
 | |
|         simple description
 | |
| 
 | |
|         Scenario: simple scenario # features/simple.feature:4
 | |
|           Given passing step      # suite_context.go:0 -> SuiteContext.func2
 | |
|             \"\"\"  content type
 | |
|             step doc string
 | |
|             \"\"\"
 | |
| 
 | |
|       1 scenarios (1 passed)
 | |
|       1 steps (1 passed)
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Support of Undefined, Pending and Skipped status
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|       Feature: simple feature
 | |
|       simple feature description
 | |
| 
 | |
|       Scenario: simple scenario
 | |
|       simple scenario description
 | |
| 
 | |
|         Given passing step
 | |
|         And pending step
 | |
|         And undefined doc string
 | |
|         \"\"\"
 | |
|         abc
 | |
|         \"\"\"
 | |
|         And undefined table
 | |
|         | a | b | c |
 | |
|         | 1 | 2 | 3 |
 | |
|         And passing step
 | |
| 
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature
 | |
|         simple feature description
 | |
| 
 | |
|         Scenario: simple scenario  # features/simple.feature:4
 | |
|           Given passing step       # suite_context.go:0 -> SuiteContext.func2
 | |
|           And pending step         # suite_context.go:0 -> SuiteContext.func1
 | |
|             TODO: write pending definition
 | |
|           And undefined doc string
 | |
|           \"\"\"
 | |
|           abc
 | |
|           \"\"\"
 | |
|           And undefined table
 | |
|           | a | b | c |
 | |
|           | 1 | 2 | 3 |
 | |
|           And passing step         # suite_context.go:0 -> SuiteContext.func2
 | |
| 
 | |
|       1 scenarios (1 pending, 1 undefined)
 | |
|       5 steps (1 passed, 1 pending, 2 undefined, 1 skipped)
 | |
|       0s
 | |
| 
 | |
|       You can implement step definitions for undefined steps with these snippets:
 | |
| 
 | |
|       func undefinedDocString(arg1 *godog.DocString) error {
 | |
|         return godog.ErrPending
 | |
|       }
 | |
| 
 | |
|       func undefinedTable(arg1 *godog.Table) error {
 | |
|         return godog.ErrPending
 | |
|       }
 | |
| 
 | |
|       func InitializeScenario(ctx *godog.ScenarioContext) {
 | |
|         ctx.Step(`^undefined doc string$`, undefinedDocString)
 | |
|         ctx.Step(`^undefined table$`, undefinedTable)
 | |
|       }
 | |
|     """
 | |
| 
 | |
|   # Ensure s will not break when injecting data from BeforeStep
 | |
|   Scenario: Support data injection in BeforeStep
 | |
|     Given a feature "features/inject.feature" file:
 | |
|     """
 | |
|       Feature: inject long value
 | |
| 
 | |
|       Scenario: test scenario
 | |
|         Given Ignore I save some value X under key Y
 | |
|         And I allow variable injection
 | |
|         When Ignore I use value {{Y}}
 | |
|         Then Ignore Godog rendering should not break
 | |
|         And Ignore test
 | |
|           | key | val |
 | |
|           | 1   | 2   |
 | |
|           | 3   | 4   |
 | |
|         And I disable variable injection
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: inject long value
 | |
| 
 | |
|         Scenario: test scenario                        # features/inject.feature:3
 | |
|           Given Ignore I save some value X under key Y # suite_context.go:0 -> SuiteContext.func12
 | |
|           And I allow variable injection               # suite_context.go:0 -> *suiteContext
 | |
|           When Ignore I use value someverylonginjectionsoweacanbesureitsurpasstheinitiallongeststeplenghtanditwillhelptestsmethodsafety # suite_context.go:0 -> SuiteContext.func12
 | |
|           Then Ignore Godog rendering should not break # suite_context.go:0 -> SuiteContext.func12
 | |
|           And Ignore test                              # suite_context.go:0 -> SuiteContext.func12
 | |
|             | key | val |
 | |
|             | 1   | 2   |
 | |
|             | 3   | 4   |
 | |
|           And I disable variable injection             # suite_context.go:0 -> *suiteContext
 | |
| 
 | |
|       1 scenarios (1 passed)
 | |
|       6 steps (6 passed)
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Should scenarios identified with path:line and preserve the order.
 | |
|     Given a feature path "features/load.feature:6"
 | |
|     And a feature path "features/multistep.feature:6"
 | |
|     And a feature path "features/load.feature:27"
 | |
|     And a feature path "features/multistep.feature:23"
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|     Feature: load features
 | |
|       In order to run features
 | |
|       As a test suite
 | |
|       I need to be able to load features
 | |
| 
 | |
|       Scenario: load features within path    # features/load.feature:6
 | |
|         Given a feature path "features"      # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|         When I parse features                # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|         Then I should have 14 feature files: # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|           \"\"\"
 | |
|           features/background.feature
 | |
|           features/events.feature
 | |
|           features/formatter/cucumber.feature
 | |
|           features/formatter/events.feature
 | |
|           features/formatter/junit.feature
 | |
|           features/formatter/pretty.feature
 | |
|           features/lang.feature
 | |
|           features/load.feature
 | |
|           features/multistep.feature
 | |
|           features/outline.feature
 | |
|           features/run.feature
 | |
|           features/snippets.feature
 | |
|           features/tags.feature
 | |
|           features/testingt.feature
 | |
|           \"\"\"
 | |
| 
 | |
|     Feature: run features with nested steps
 | |
|       In order to test multisteps
 | |
|       As a test suite
 | |
|       I need to be able to execute multisteps
 | |
| 
 | |
|       Scenario: should run passing multistep successfully # features/multistep.feature:6
 | |
|         Given a feature "normal.feature" file:            # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|           \"\"\"
 | |
|           Feature: normal feature
 | |
| 
 | |
|             Scenario: run passing multistep
 | |
|               Given passing step
 | |
|               Then passing multistep
 | |
|           \"\"\"
 | |
|         When I run feature suite                          # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|         Then the suite should have passed                 # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|         And the following steps should be passed:         # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|           \"\"\"
 | |
|           passing step
 | |
|           passing multistep
 | |
|           \"\"\"
 | |
| 
 | |
|     Feature: load features
 | |
|       In order to run features
 | |
|       As a test suite
 | |
|       I need to be able to load features
 | |
| 
 | |
|       Scenario: load a specific feature file         # features/load.feature:27
 | |
|         Given a feature path "features/load.feature" # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|         When I parse features                        # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|         Then I should have 1 feature file:           # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|           \"\"\"
 | |
|           features/load.feature
 | |
|           \"\"\"
 | |
| 
 | |
|     Feature: run features with nested steps
 | |
|       In order to test multisteps
 | |
|       As a test suite
 | |
|       I need to be able to execute multisteps
 | |
| 
 | |
|       Scenario: should fail multistep              # features/multistep.feature:23
 | |
|         Given a feature "failed.feature" file:     # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|           \"\"\"
 | |
|           Feature: failed feature
 | |
| 
 | |
|             Scenario: run failing multistep
 | |
|               Given passing step
 | |
|               When failing multistep
 | |
|               Then I should have 1 scenario registered
 | |
|           \"\"\"
 | |
|         When I run feature suite                   # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|         Then the suite should have failed          # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|         And the following step should be failed:   # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|           \"\"\"
 | |
|           failing multistep
 | |
|           \"\"\"
 | |
|         And the following steps should be skipped: # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|           \"\"\"
 | |
|           I should have 1 scenario registered
 | |
|           \"\"\"
 | |
|         And the following steps should be passed:  # suite_context_test.go:0 -> *godogFeaturesScenario
 | |
|           \"\"\"
 | |
|           passing step
 | |
|           \"\"\"
 | |
| 
 | |
|     4 scenarios (4 passed)
 | |
|     16 steps (16 passed)
 | |
|     0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Support of Feature Plus Rule
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         Feature: simple feature with a rule
 | |
|             simple feature description
 | |
|          Rule: simple rule
 | |
|              simple rule description
 | |
|          Example: simple scenario
 | |
|             simple scenario description
 | |
|           Given passing step
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature with a rule
 | |
|         simple feature description
 | |
| 
 | |
|         Example: simple scenario # features/simple.feature:5
 | |
|           Given passing step     # suite_context.go:0 -> SuiteContext.func2
 | |
| 
 | |
|       1 scenarios (1 passed)
 | |
|       1 steps (1 passed)
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Support of Feature Plus Rule with Background
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         Feature: simple feature with a rule with Background
 | |
|             simple feature description
 | |
|          Rule: simple rule
 | |
|              simple rule description
 | |
|          Background:
 | |
|              Given passing step
 | |
|          Example: simple scenario
 | |
|             simple scenario description
 | |
|           Given passing step
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature with a rule with Background
 | |
|         simple feature description
 | |
| 
 | |
|         Background:
 | |
|           Given passing step     # suite_context.go:0 -> SuiteContext.func2
 | |
| 
 | |
|         Example: simple scenario # features/simple.feature:7
 | |
|           Given passing step     # suite_context.go:0 -> SuiteContext.func2
 | |
| 
 | |
|       1 scenarios (1 passed)
 | |
|       2 steps (2 passed)
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Support of Feature Plus Rule with Scenario Outline
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         Feature: simple feature with a rule with Scenario Outline
 | |
|             simple feature description
 | |
|          Rule: simple rule
 | |
|              simple rule description
 | |
|          Scenario Outline: simple scenario
 | |
|              simple scenario description
 | |
| 
 | |
|               Given <status> step
 | |
| 
 | |
|           Examples: simple examples
 | |
|           | status |
 | |
|           | passing |
 | |
|           | failing |
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature with a rule with Scenario Outline
 | |
|         simple feature description
 | |
| 
 | |
|         Scenario Outline: simple scenario # features/simple.feature:5
 | |
|           Given <status> step             # suite_context.go:0 -> SuiteContext.func2
 | |
| 
 | |
|           Examples: simple examples
 | |
|             | status  |
 | |
|             | passing |
 | |
|             | failing |
 | |
|               intentional failure
 | |
| 
 | |
|       --- Failed steps:
 | |
| 
 | |
|         Scenario Outline: simple scenario # features/simple.feature:5
 | |
|           Given failing step # features/simple.feature:8
 | |
|           Error: intentional failure
 | |
| 
 | |
| 
 | |
|       2 scenarios (1 passed, 1 failed)
 | |
|       2 steps (1 passed, 1 failed)
 | |
|       0s
 | |
|     """
 | |
| 
 | |
|   Scenario: Use 'given' keyword on a declared 'when' step
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         Feature: simple feature with a rule
 | |
|             simple feature description
 | |
|          Rule: simple rule
 | |
|              simple rule description
 | |
|          Example: simple scenario
 | |
|             simple scenario description
 | |
|           Given a when step
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature with a rule
 | |
|         simple feature description
 | |
| 
 | |
|         Example: simple scenario # features/simple.feature:5
 | |
|           Given a when step
 | |
| 
 | |
|       1 scenarios (1 undefined)
 | |
|       1 steps (1 undefined)
 | |
|       0s
 | |
| 
 | |
|       You can implement step definitions for undefined steps with these snippets:
 | |
| 
 | |
|       func aWhenStep() error {
 | |
|         return godog.ErrPending
 | |
|       }
 | |
| 
 | |
|       func InitializeScenario(ctx *godog.ScenarioContext) {
 | |
|         ctx.Step(`^a when step$`, aWhenStep)
 | |
|       }
 | |
|     """
 | |
| 
 | |
|   Scenario: Use 'when' keyword on a declared 'then' step
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         Feature: simple feature with a rule
 | |
|             simple feature description
 | |
|          Rule: simple rule
 | |
|              simple rule description
 | |
|          Example: simple scenario
 | |
|             simple scenario description
 | |
|           When a then step
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature with a rule
 | |
|         simple feature description
 | |
| 
 | |
|         Example: simple scenario # features/simple.feature:5
 | |
|           When a then step
 | |
| 
 | |
|       1 scenarios (1 undefined)
 | |
|       1 steps (1 undefined)
 | |
|       0s
 | |
| 
 | |
|       You can implement step definitions for undefined steps with these snippets:
 | |
| 
 | |
|       func aThenStep() error {
 | |
|         return godog.ErrPending
 | |
|       }
 | |
| 
 | |
|       func InitializeScenario(ctx *godog.ScenarioContext) {
 | |
|         ctx.Step(`^a then step$`, aThenStep)
 | |
|       }
 | |
|     """
 | |
| 
 | |
|   Scenario: Use 'then' keyword on a declared 'given' step
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         Feature: simple feature with a rule
 | |
|             simple feature description
 | |
|          Rule: simple rule
 | |
|              simple rule description
 | |
|          Example: simple scenario
 | |
|             simple scenario description
 | |
|           Then a given step
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature with a rule
 | |
|         simple feature description
 | |
| 
 | |
|         Example: simple scenario # features/simple.feature:5
 | |
|           Then a given step
 | |
| 
 | |
|       1 scenarios (1 undefined)
 | |
|       1 steps (1 undefined)
 | |
|       0s
 | |
| 
 | |
|       You can implement step definitions for undefined steps with these snippets:
 | |
| 
 | |
|       func aGivenStep() error {
 | |
|         return godog.ErrPending
 | |
|       }
 | |
| 
 | |
|       func InitializeScenario(ctx *godog.ScenarioContext) {
 | |
|         ctx.Step(`^a given step$`, aGivenStep)
 | |
|       }
 | |
|     """
 | |
| 
 | |
|   Scenario: Match keyword functions correctly
 | |
|     Given a feature "features/simple.feature" file:
 | |
|     """
 | |
|         Feature: simple feature with a rule
 | |
|             simple feature description
 | |
|          Rule: simple rule
 | |
|              simple rule description
 | |
|          Example: simple scenario
 | |
|             simple scenario description
 | |
|           Given a given step
 | |
|           When a when step
 | |
|           Then a then step
 | |
|           And a then step
 | |
|     """
 | |
|     When I run feature suite with formatter "pretty"
 | |
|     Then the rendered output will be as follows:
 | |
|     """
 | |
|       Feature: simple feature with a rule
 | |
|         simple feature description
 | |
| 
 | |
| 	    Example: simple scenario # features/simple.feature:5
 | |
| 	      Given a given step     # suite_context_test.go:0 -> InitializeScenario.func3
 | |
| 	      When a when step       # suite_context_test.go:0 -> InitializeScenario.func4
 | |
| 	      Then a then step       # suite_context_test.go:0 -> InitializeScenario.func5
 | |
| 	      And a then step        # suite_context_test.go:0 -> InitializeScenario.func5
 | |
| 
 | |
|       1 scenarios (1 passed)
 | |
|       4 steps (4 passed)
 | |
|       0s
 | |
|     """ |