File: profiles.feature

package info (click to toggle)
cucumber 2.4.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 3,076 kB
  • sloc: ruby: 17,016; javascript: 4,641; makefile: 12; sh: 10; tcl: 3
file content (120 lines) | stat: -rw-r--r-- 4,369 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
Feature: Profiles

  In order to save time and prevent carpal tunnel syndrome
  Cucumber users can save and reuse commonly used cucumber flags in a 'cucumber.yml' file.
  These named arguments are called profiles and the yml file should be in the root of your project.
  Any cucumber argument is valid in a profile.  To see all the available flags type 'cucumber --help'
  For more information about profiles please see the wiki:
  http://wiki.github.com/cucumber/cucumber/cucumber.yml

  Background: Basic App
    Given a file named "features/sample.feature" with:
      """
      Feature: Sample
        Scenario: this is a test
          Given this step raises an error
      """
    And an empty file named "features/support/env.rb"
    And an empty file named "features/support/super_env.rb"
    And the following profiles are defined:
      """
      default: features/sample.feature --require features/support/env.rb -v
      super: features/sample.feature --require features/support/super_env.rb -v
      """

  Scenario: Explicitly defining a profile to run
    When I run `cucumber features/sample.feature --profile super`
    Then the output should contain:
      """
      Using the super profile...
      """
    And exactly these files should be loaded: features/support/super_env.rb

  Scenario: Explicitly defining a profile defined in an ERB formatted file
    Given the following profiles are defined:
      """
      <% requires = "--require features/support/super_env.rb" %>
      super: <%= "features/sample.feature #{requires} -v" %>
      """
    When I run `cucumber features/sample.feature --profile super`
    Then the output should contain:
      """
      Using the super profile...
      """
    And exactly these files should be loaded: features/support/super_env.rb

  Scenario: Defining multiple profiles to run
    When I run `cucumber features/sample.feature --profile default --profile super`
    Then the output should contain:
      """
      Using the default and super profiles...
      """
    And exactly these files should be loaded: features/support/env.rb, features/support/super_env.rb

  Scenario: Arguments passed in but no profile specified
    When I run `cucumber -v`
    Then the default profile should be used
    And exactly these files should be loaded: features/support/env.rb

  Scenario: Trying to use a missing profile
    When I run `cucumber -p foo`
    Then the stderr should contain:
      """
      Could not find profile: 'foo'

      Defined profiles in cucumber.yml:
        * default
        * super

      """

  Scenario Outline: Disabling the default profile
    When I run `cucumber -v features/ <flag>`
    Then the output should contain:
      """
      Disabling profiles...
      """
    And exactly these files should be loaded: features/support/env.rb, features/support/super_env.rb

    Examples:
      | flag         |
      | -P           |
      | --no-profile |

  Scenario: Overriding the profile's features to run
    Given a file named "features/another.feature" with:
      """
      Feature: Just this one should be run
      """
    When I run `cucumber -p default features/another.feature`
    Then exactly these features should be run: features/another.feature

  Scenario: Overriding the profile's formatter
    You will most likely want to define a formatter in your default formatter.
    However, you often want to run your features with a different formatter
    yet still use the other the other arguments in the profile. Cucumber will
    allow you to do this by giving precedence to the formatter specified on the
    command line and override the one in the profile.

    Given the following profiles are defined:
      """
      default: features/sample.feature --require features/support/env.rb -v --format profile
      """
    When I run `cucumber features --format pretty`
    Then the output should contain:
      """
      Feature: Sample
      """

  Scenario Outline: Showing profiles when listing failing scenarios
    Given the standard step definitions
    When I run `cucumber -q -p super -p default -f <format> features/sample.feature --require features/step_definitions/steps.rb`
    Then it should fail with:
       """
       cucumber -p super features/sample.feature:2
       """

    Examples:
      | format   |
      | pretty   |
      | progress |