cucumber-in-the-yard 1.5.4 → 1.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (29) hide show
  1. data/History.txt +6 -0
  2. data/README.md +18 -14
  3. data/city.gemspec +1 -1
  4. data/example/step_definitions/example.step.rb +4 -0
  5. data/example/sub_features/second_example.feature +51 -0
  6. data/lib/city.rb +1 -1
  7. data/lib/cucumber/city_builder.rb +3 -1
  8. data/lib/templates/default/feature/html/outline.erb +49 -17
  9. data/lib/templates/default/feature/html/scenario.erb +7 -9
  10. data/lib/templates/default/feature/html/steps.erb +17 -17
  11. data/lib/templates/default/feature/setup.rb +1 -1
  12. data/lib/templates/default/featuredirectory/html/directory.erb +76 -0
  13. data/lib/templates/default/featuredirectory/html/setup.rb +36 -0
  14. data/lib/templates/default/fulldoc/html/css/common.css +74 -60
  15. data/lib/templates/default/fulldoc/html/full_list_features.erb +3 -0
  16. data/lib/templates/default/fulldoc/html/full_list_tags.erb +4 -15
  17. data/lib/templates/default/fulldoc/html/js/cucumber.js +29 -7
  18. data/lib/templates/default/fulldoc/html/setup.rb +15 -11
  19. data/lib/templates/default/requirements/html/namespace.erb +76 -0
  20. data/lib/templates/default/requirements/html/setup.rb +35 -0
  21. data/lib/templates/default/scenario/html/scenario.erb +0 -3
  22. data/lib/templates/default/tag/html/feature.erb +28 -47
  23. data/lib/templates/default/tag/html/scenario.erb +28 -42
  24. data/lib/templates/default/tag/html/tag.erb +1 -0
  25. data/lib/templates/default/tag/setup.rb +15 -1
  26. data/lib/templates/default/tags/html/namespace.erb +39 -0
  27. data/lib/templates/default/tags/html/setup.rb +21 -0
  28. data/lib/yard/code_objects/cucumber/namespace_object.rb +16 -6
  29. metadata +16 -25
data/History.txt CHANGED
@@ -1,3 +1,9 @@
1
+ === 1.6.0 / 2010-11-02
2
+
3
+ * Feature directories, subdirectories, and Tags breadcrumb pages are present
4
+ * Scenario Outlines now display each example inline when the example is pressed
5
+ * 'All Features' and 'All Tags' link in the search fields
6
+
1
7
  === 1.5.4 / 2010-10-28
2
8
 
3
9
  * Optimization - Found that for a large test suite that the processing time was
data/README.md CHANGED
@@ -51,6 +51,11 @@ the step definition.
51
51
  Steps highlight the match groups in a different color to show which parts of the step are matched in the step
52
52
  definition.
53
53
 
54
+ **7. Represent instances of scenarios for scenario outlines.**
55
+
56
+ Display all the values that would normally be substituted into a scenario for the scenario outline. To
57
+ make it easier to represent them to product owners. As well as link the instance of the step definitions
58
+ for developers.
54
59
 
55
60
 
56
61
  Installation
@@ -127,26 +132,25 @@ Roadmap
127
132
 
128
133
  **Future Feature Ideas**
129
134
 
130
- **1. Represent instances of scenarios for scenario outlines.**
135
+ **1. Feature/Scenario Tag unions and intersections**
131
136
 
132
- Display all the values that would normally be substituted into a scenario for the scenario outline. To
133
- make it easier to represent them to product owners. As well as link the instance of the step definitions
134
- for developers.
137
+ Create an AJAX interface that would allow the user to specify tags to union, intersect, or exclude to
138
+ produce a list of features and scenarios that would execute. The output could also provide an example
139
+ command line parameter list to produce the feature/scenario execution results.
140
+
141
+ Visualization of this execution with some graphing library for some extra points.
135
142
 
136
- **2. Tag pages provide the ability to exclude other tags that intersect.**
143
+ **2. Performance enhancements**
137
144
 
138
- Adding a list of tags currently used by the features and scenarios in the below list (that are not the
139
- current tag). Allowing the visualization of what the execution of the requirements pass would look like.
140
- Output of a sample generated tag command-line would be displayed to assist with execution. On selection
141
- update of the total features and scenarios affected by the changes in the filtering.
145
+ The current rate of documentation is not dreadfully slow anymore but more performance enhancements could
146
+ always be performed to produce the documentation faster.
142
147
 
143
- I would like to also address some layout and formatting on the page. Scenarios will also link to the scenarios
144
- feature page, show their descriptions, and of course all their other tags.
148
+ **3. Requirements Only Docuementation**
145
149
 
146
- **3. Performance enhancements**
150
+ 'fulldoc' is the default documentation generated but I have this thought that a requirements-only document
151
+ may be useful. Essentially the first draft would be the current documentation minus the class and method
152
+ links/searches and replacing the index.html.
147
153
 
148
- At the current rate the documentation generation is dreadfully slow for the project. After implementing a few
149
- more of these features I will look at addressing the performance to see where this can be optimized.
150
154
 
151
155
  LICENSE
152
156
  -------
data/city.gemspec CHANGED
@@ -7,7 +7,7 @@ def self.show_version_changes(version)
7
7
  changes = []
8
8
  grab_changes = false
9
9
 
10
- File.open("#{File.dirname(__FILE__)}/History.txt",'r') do |file|
10
+ File.open('History.txt','r') do |file|
11
11
  while (line = file.gets) do
12
12
 
13
13
  if line =~ /^===\s*#{version.gsub('.','\.')}\s*\/\s*(.+)\s*$/
@@ -52,6 +52,10 @@ And /^edits their the (biography) to state:$/ do |section,text|
52
52
  pending "text_field not present for #{section} #{bio} for this release"
53
53
  end
54
54
 
55
+ Then /I expect (#{CUSTOMER}) to be a member of the '([^']+)' group/ do |customer,product|
56
+ pending "Customer #{customer} with product #{product}"
57
+ end
58
+
55
59
  #
56
60
  # Complicated step definition with optional parameters
57
61
  #
@@ -0,0 +1,51 @@
1
+ @customer
2
+ Feature: Customer Logout Feature
3
+ As a customer of the product I am able to logout
4
+
5
+ Background:
6
+ Given this undefined step definition
7
+
8
+ @bvt @param2 @param3
9
+ Scenario: Customer that is logged in is able to log out
10
+ Given that a customer is a valid customer
11
+ And a customer logs in as username 'frank' with password 'default'
12
+ And I expect them to have logged in successfully
13
+ When the customer logs out
14
+ Then I expect the customer to be shown the logout page
15
+
16
+ Scenario: Customers with a complete profile are allowed to post
17
+ Given that a customer is a valid customer
18
+ And the customer has the following details:
19
+ | Name | Email | Age |
20
+ | Roger | r@email.com | 22 |
21
+ And the customer has the following details:
22
+ | Name | Email | Age |
23
+ | Roger | r@email.com | 22 |
24
+ When a customer logs in as username 'frank' with password 'default'
25
+ And visits the customer update page
26
+ Then I expect the customer is able able to post to their profile
27
+
28
+ @optional_parameters
29
+ Scenario: Optional Parameter Step Definition
30
+ # This step definition has some optional parameters
31
+ Given a project
32
+ And an inactive project
33
+ And a project with the name 'optional', start date 10/26/2010, nicknamed 'norman'
34
+
35
+ @highlighting
36
+ Scenario: Highlighting
37
+ Given a duck that has a bill
38
+ Then I expect the duck to quack
39
+
40
+ @product
41
+ Scenario Outline: Customers that bought a product are included in their product groups
42
+ Given that <Customer> is a valid customer
43
+ And that the product, named '<Product>', is a valid product
44
+ When the customer has purchased the product
45
+ Then I expect the customer to be a member of the '<Product>' group
46
+
47
+ Examples:
48
+ | Customer | Product |
49
+ | Customer A | Product A |
50
+ | Customer A | Product B |
51
+ | Customer A | Product C |
data/lib/city.rb CHANGED
@@ -6,7 +6,7 @@ require 'gherkin/formatter/tag_count_formatter'
6
6
  require 'yard'
7
7
 
8
8
  module CucumberInTheYARD
9
- VERSION = '1.5.4' unless defined?(CucumberInTheYARD::VERSION)
9
+ VERSION = '1.6.0' unless defined?(CucumberInTheYARD::VERSION)
10
10
  end
11
11
 
12
12
 
@@ -15,8 +15,10 @@ module Cucumber
15
15
  end
16
16
 
17
17
  def find_or_create_namespace(file)
18
+ # TODO: The directory that is added should have the full path
18
19
  file.split('/')[0..-2].each do |directory|
19
- @namespace = @namespace.children.find {|child| child.name == directory } || YARD::CodeObjects::Cucumber::NamespaceObject.new(@namespace,directory)
20
+ @namespace = @namespace.children.find {|child| child.name == directory } ||
21
+ YARD::CodeObjects::Cucumber::FeatureDirectory.new(@namespace,directory) {|dir| dir.add_file(directory)}
20
22
  end
21
23
  end
22
24
 
@@ -1,19 +1,51 @@
1
+ <% @scenario.scenarios.each_with_index do |scenario,example_index| %>
2
+ <div id="<%= "#{@id}Example#{example_index + 1}Steps" %>" style="display: none;" class="steps">
3
+ <% scenario.steps.each_with_index do |step,index| %>
4
+ <% @step = step %>
5
+
6
+
7
+ <div <%= "id='#{@id}Example#{example_index + 1}Step#{index}'" %> class="step <%= (index + 1) % 2 == 0 ? 'even' : 'odd' %>">
8
+ <span class="predicate"><%= step.keyword %></span>
9
+
10
+ <% if step.definition %>
11
+ <span class="defined">
12
+ <%= highlight_matches(step) %>
13
+ <div class="details">
14
+ <a href="<%= url_for step.definition %>">?</a>
15
+ </div>
16
+ </span>
17
+ <% else %>
18
+ <span class="undefined"><%= h step.value %></span>
19
+ <% end %>
20
+
21
+ </div>
22
+
23
+ <%= erb(:table) if step.has_table? %>
24
+ <%= erb(:pystring) if step.has_text? %>
25
+
26
+
27
+ <% end %>
28
+ </div>
29
+ <% end %>
30
+
31
+
1
32
  <div class="outline">
2
- <div class="keyword"> <%= h @scenario.example_keyword %> </div>
3
- <table>
4
- <thead>
5
- <tr>
6
- <% @scenario.example_headers.each_with_index do |header,header_index| %>
7
- <th><%= h(header) %></th>
8
- <% end %>
9
- </tr>
10
- </thead>
11
- <% @scenario.example_data.each_with_index do |row,row_index| %>
12
- <tr class="<%= (row_index + 1) % 2 == 0 ? 'even' : 'odd' %>" >
13
- <% row.each_with_index do |column,column_index| %>
14
- <td><%= h(column.to_s.strip) %></td>
15
- <% end %>
16
- </tr>
17
- <% end %>
18
- </table>
33
+ <div class="keyword"> <%= h @scenario.example_keyword %> </div>
34
+ <table>
35
+ <thead>
36
+ <tr>
37
+ <% @scenario.example_headers.each_with_index do |header,header_index| %>
38
+ <th><%= h(header) %></th>
39
+ <% end %>
40
+ </tr>
41
+ </thead>
42
+ <% @scenario.example_data.each_with_index do |row,row_index| %>
43
+ <tr class="<%= (row_index + 1) % 2 == 0 ? 'even' : 'odd' %>"
44
+ onclick="<%= "toggleScenarioExample('#{@id}',#{row_index + 1});" %>">
45
+ <% row.each_with_index do |column,column_index| %>
46
+ <td><%= h(column.to_s.strip) %></td>
47
+ <% end %>
48
+ </tr>
49
+ <% end %>
50
+ </table>
19
51
  </div>
@@ -29,15 +29,13 @@ $(function() {
29
29
  </div>
30
30
  <% unless @scenario.description.empty? %>
31
31
  <div class="description">
32
- <%= h @scenario.description %>
32
+ <%= h @scenario.description %>
33
33
  </div>
34
34
  <% end %>
35
35
 
36
- <div id="<%= @id %>Steps" class="steps">
37
- <%= @scenario.steps ? erb(:steps) : erb(:no_steps_defined) %>
38
-
39
- </div>
40
-
41
- <%= erb(:outline) if @scenario.outline? %>
42
-
43
- </div>
36
+ <div id="<%= @id %>Steps" class="steps">
37
+ <%= @scenario.steps ? erb(:steps) : erb(:no_steps_defined) %>
38
+ </div>
39
+
40
+ <%= erb(:outline) if @scenario.outline? %>
41
+ </div>
@@ -1,25 +1,25 @@
1
1
  <% @scenario.steps.each_with_index do |step,index| %>
2
- <% @step = step %>
2
+ <% @step = step %>
3
3
 
4
4
 
5
- <div <%= "id='#{@id}Step#{index}'" %> class="step <%= (index + 1) % 2 == 0 ? 'even' : 'odd' %>">
6
- <span class="predicate"><%= step.keyword %></span>
5
+ <div <%= "id='#{@id}Step#{index}'" %> class="step <%= (index + 1) % 2 == 0 ? 'even' : 'odd' %>">
6
+ <span class="predicate"><%= step.keyword %></span>
7
7
 
8
- <% if step.definition %>
9
- <span class="defined">
10
- <%= highlight_matches(step) %>
11
- <div class="details">
12
- <a href="<%= url_for step.definition %>">?</a>
13
- </div>
14
- </span>
15
- <% else %>
16
- <span class="undefined"><%= h step.value %></span>
17
- <% end %>
8
+ <% if step.definition %>
9
+ <span class="defined">
10
+ <%= highlight_matches(step) %>
11
+ <div class="details">
12
+ <a href="<%= url_for step.definition %>">?</a>
13
+ </div>
14
+ </span>
15
+ <% else %>
16
+ <span class="undefined"><%= h step.value %></span>
17
+ <% end %>
18
18
 
19
- </div>
19
+ </div>
20
20
 
21
- <%= erb(:table) if step.has_table? %>
22
- <%= erb(:pystring) if step.has_text? %>
21
+ <%= erb(:table) if step.has_table? %>
22
+ <%= erb(:pystring) if step.has_text? %>
23
23
 
24
24
 
25
- <% end %>
25
+ <% end %>
@@ -5,7 +5,7 @@ def init
5
5
  sections.push :feature
6
6
 
7
7
  sections.push :background if object.background
8
- sections.push :scenarios if object.scenarios
8
+ sections.push :scenarios if object.scenarios
9
9
 
10
10
  end
11
11
 
@@ -0,0 +1,76 @@
1
+ <% if @directory %>
2
+ <div class="requirements">
3
+ <div class="title">
4
+ <span class="pre">Directory:</span>
5
+ <span class="name"><%= h @directory.name.to_s.capitalize %></span>
6
+ </div>
7
+ <div class="meta">
8
+ <div class="file"><%= h(@directory.file) %></div>
9
+ </div>
10
+ <div class="summary">
11
+ <span class="name">Features:</span><span class="value"><%= features.size %></span>
12
+ <span class="name">Scenarios:</span><span class="value"><%= scenarios.size %></span>
13
+ </div>
14
+ <div class="tags"><span class="name">Tags:</span>
15
+ <%= tags.collect {|tag| linkify(tag,tag.value) }.join(",\n") %>
16
+ </div>
17
+
18
+
19
+ <% if @directories_by_letter && !@directories_by_letter.empty? %>
20
+ <div id="directory">
21
+ <div class="title"><span class="name">Subdirectories</span></div>
22
+ </div>
23
+ <% i = 0 %>
24
+ <table>
25
+ <tr>
26
+ <td valign='top' width="33%">
27
+ <% @directories_by_letter.each do |directory| %>
28
+ <% if (i += 1) % 8 == 0 %>
29
+ </td><td valign='top' width="33%">
30
+ <% i = 0 %>
31
+ <% end %>
32
+ <ul>
33
+ <%= linkify directory, directory.name %>
34
+ </ul>
35
+ <% end %>
36
+ </td>
37
+ </tr>
38
+ </table>
39
+
40
+ <% end %>
41
+
42
+ <% if @objects_by_letter && !@objects_by_letter.empty? %>
43
+ <div id="features">
44
+ <div class="title"><span class="name">Features</span></div>
45
+ </div>
46
+ <% i = 0 %>
47
+ <table>
48
+ <tr>
49
+ <td valign='top' width="33%">
50
+ <% @objects_by_letter.sort_by {|l,o| l.to_s }.each do |letter, objects| %>
51
+ <% if (i += 1) % 8 == 0 %>
52
+ </td><td valign='top' width="33%">
53
+ <% i = 0 %>
54
+ <% end %>
55
+ <ul id="alpha_<%= letter %>" class="alpha">
56
+ <li class="letter"><%= letter %></li>
57
+ <ul>
58
+ <% objects.each do |obj| %>
59
+ <li>
60
+ <%= linkify obj, obj.value %>
61
+ <% if !obj.namespace.root? %>
62
+ <small>(<%= obj.namespace.file %>)</small>
63
+ <% end %>
64
+ </li>
65
+ <% end %>
66
+ </ul>
67
+ </ul>
68
+ <% end %>
69
+ </td>
70
+ </tr>
71
+ </table>
72
+ <% end %>
73
+ <% end %>
74
+
75
+ </div>
76
+
@@ -0,0 +1,36 @@
1
+ def init
2
+ super
3
+ sections.push :directory
4
+ @directory = object
5
+ end
6
+
7
+ def directory
8
+ @objects_by_letter = all_types_by_letter(YARD::CodeObjects::Cucumber::Feature)
9
+ @directories_by_letter = @directory.children.find_all {|child| child.is_a?(YARD::CodeObjects::Cucumber::FeatureDirectory) }.sort_by {|dir| dir.name }
10
+ erb(:directory)
11
+ end
12
+
13
+ def all_types_by_letter(type)
14
+ hash = {}
15
+ objects = @directory.children.find_all {|child| child.is_a?(type) }
16
+ objects = run_verifier(objects)
17
+ objects.each {|o| (hash[o.value.to_s[0,1].upcase] ||= []) << o }
18
+ hash
19
+ end
20
+
21
+ def features
22
+ @directory.children.find_all{|child| child.is_a?(YARD::CodeObjects::Cucumber::Feature)}
23
+ end
24
+
25
+ def scenarios
26
+ features.collect {|feature| feature.scenarios }.flatten
27
+ end
28
+
29
+ def steps
30
+ scenarios.collect {|scenario| scenario.steps }.flatten
31
+ end
32
+
33
+ def tags
34
+ (features.collect{|feature| feature.tags } + scenarios.collect {|scenario| scenario.tags }).flatten.uniq
35
+ end
36
+
@@ -1,58 +1,67 @@
1
+ .summary { margin: 20px 20px 10px 20px; padding-left: 0px; }
2
+ .summary * { padding: 5px 0px 5px 10px; }
1
3
  .feature {}
2
4
  .tags { font-family: monospace; font-size: 14px; }
3
- * .title { padding: 10px; font-size: 24px; }
5
+ .title { padding: 10px; font-size: 24px; }
4
6
 
5
- .feature > .title, .tag > .title { margin: 20px 20px 10px 20px; padding-left: 0px; border-bottom: 1px solid #E3E3E3; }
6
- .meta .file { float: right; margin-right: 20px; }
7
- * .title .pre { color: #696969; }
8
- * .title .name { font-weight: bold; color: #3F3F3F; }
7
+ .feature > .title, .tag > .title, .requirements > .title { margin: 20px 20px 10px 20px; padding-left: 0px; border-bottom: 1px solid #E3E3E3; }
8
+ .meta .file { float: right; margin-right: 20px; }
9
+ .title .pre { color: #696969; }
10
+ .title .name { font-weight: bold; color: #3F3F3F; }
9
11
 
10
12
  .meta { margin-left: 30px; color: gray; }
11
13
  .scenario .meta .tags { margin-left: 0px; }
12
14
 
13
- .feature .description {
14
- margin: 10px 20px 0px 30px;
15
- padding: 10px 20px 20px 10px;
16
- color: #343332;
17
- font-family: 'Trebuchet MS', Arial, Helvetica;
15
+ .feature .description, .requirements .summary {
16
+ margin: 10px 20px 0px 30px;
17
+ padding: 10px 20px 20px 10px;
18
+ color: #343332;
19
+ font-family: 'Trebuchet MS', Arial, Helvetica;
18
20
  }
19
21
 
22
+ .summary .name, .tags .name { color: gray; }
23
+ .summary .tags {}
24
+
20
25
  .odd { background-color: #F0F6F9; }
21
26
  .even { background-color: #FFFFFF; }
22
27
 
23
- #background {
24
- margin-top: 10px;
25
- margin-left: 20px;
26
- }
27
-
28
- .scenario {
29
- margin-top: 40px;
30
- margin-left: 20px;
31
- }
28
+ #background, #features { margin-top: 10px; margin-left: 20px; }
32
29
 
30
+ #directory { margin-top: 20px; margin-left: 20px; }
33
31
 
32
+ .scenario { margin-top: 40px; margin-left: 20px; }
34
33
  .scenario .title, #background .title {
35
- font-size: 16px;
36
- padding-left: 0px;
37
- margin: 0px 20px 0px 10px;
38
- border-bottom: 1px solid #E3E3E3;
34
+ font-size: 16px;
35
+ padding-left: 0px;
36
+ margin: 0px 20px 0px 10px;
37
+ border-bottom: 1px solid #E3E3E3;
39
38
  }
40
39
 
41
- #background .title .pre {
42
- color: #346F97;
43
- }
40
+ #directory .title, #features .title { padding-left: 0px; margin-left: 10px; border-bottom: 1px solid #E3E3E3; }
41
+ #directory .title .name, #features .title .name { font-weight: normal; }
42
+
43
+
44
+
45
+ #background .title .pre { color: #346F97; }
46
+ .requirements .tags { margin-left: 50px; margin-right: 30px; }
47
+
48
+ * ul.alpha { font-size: 1.1em; }
49
+ * ul.alpha { padding-bottom: 10px; list-style: none; }
50
+ * ul.alpha li.letter { font-size: 1.4em; padding-bottom: 10px; }
51
+ * ul.alpha ul { padding-left: 15px; }
52
+ * ul small { color: #666; font-size: 0.7em; }
44
53
 
45
54
 
46
55
  .scenario .steps, #background .steps {
47
- margin: 20px 20px 0px 30px;
48
- font-size: 12px;
56
+ margin: 20px 20px 0px 30px;
57
+ font-size: 12px;
49
58
  }
50
59
 
51
60
  .scenario .step, #background .step {
52
- margin-top: 4px;
53
- padding: 4px;
54
- font-size: 14px;
55
- font-weight: bold;
61
+ margin-top: 4px;
62
+ padding: 4px;
63
+ font-size: 14px;
64
+ font-weight: bold;
56
65
  }
57
66
 
58
67
  #background .title .name {}
@@ -61,14 +70,8 @@
61
70
  .scenario .title .name {}
62
71
  .scenario .description {}
63
72
 
64
- .scenario .title .pre {
65
- color: #00AAD2;
66
- }
67
-
68
- .scenario .tags {
69
- margin-left: 30px;
70
- margin-top: 10px;
71
- }
73
+ .scenario .title .pre { color: #00AAD2; }
74
+ .scenario .tags { margin-left: 30px; margin-top: 10px; }
72
75
 
73
76
  .step .predicate { color: #5D5C5B; }
74
77
  .step .undefined { border-bottom: 1px dashed #E99494; }
@@ -80,34 +83,34 @@
80
83
 
81
84
  .multiline, .text { margin-top: 10px; margin-left: 20px; }
82
85
  .text {
83
- padding: 20px;
84
- background-color: #F8F8FF;
85
- color: #444444;
86
- border: 1px solid #DEDEDE;
86
+ padding: 20px;
87
+ background-color: #F8F8FF;
88
+ color: #444444;
89
+ border: 1px solid #DEDEDE;
87
90
  }
88
91
 
89
92
 
90
93
  .outline {
91
- margin-top: 20px;
92
- margin-left: 40px;
94
+ margin-top: 20px;
95
+ margin-left: 40px;
93
96
  }
94
97
  .outline .keyword {
95
- padding: 4px;
96
- font-weight: bold;
97
- font-size: 16px;
98
+ padding: 4px;
99
+ font-weight: bold;
100
+ font-size: 16px;
98
101
  }
99
102
 
100
103
  .multiline table tr, .outline table tr {
101
- padding: 4px;
104
+ padding: 4px;
102
105
  }
103
106
  .multiline table thead tr th, .outline table thead tr th {
104
- text-align: left;
105
- padding: 4px;
106
- background-color: #A8C0A8;
107
+ text-align: left;
108
+ padding: 4px;
109
+ background-color: #A8C0A8;
107
110
  }
108
111
  .multiline table tr td, .outline table tr td {
109
- min-width: 100px;
110
- padding: 4px 10px 4px 10px;
112
+ min-width: 100px;
113
+ padding: 4px 10px 4px 10px;
111
114
  }
112
115
 
113
116
 
@@ -121,15 +124,26 @@
121
124
 
122
125
 
123
126
  .stepdef .title {
124
- font-size: 14px;
125
- margin-top: 30px;
126
- border-bottom: 1px solid #E3E3E3;
127
+ font-size: 14px;
128
+ margin-top: 30px;
129
+ border-bottom: 1px solid #E3E3E3;
127
130
  }
128
131
 
129
132
  .stepdef .steps, .stepdef .method_details_list {
130
- margin: 10px 0px 0px 30px;
133
+ margin: 10px 0px 0px 30px;
131
134
  }
132
135
  .stepdef .steps .step {
133
- padding: 4px;
136
+ padding: 4px;
134
137
  }
135
138
 
139
+ #cukes_links { margin: 10px auto 10px auto;
140
+ border-bottom: 1px solid #E3E3E3;
141
+ width: 762px; text-align: center;
142
+ padding: 10px;
143
+ }
144
+ #cukes_logo {
145
+ margin: 0px auto 10px auto;
146
+ width: 762px;
147
+ height: 190px;
148
+ background: url(%3D) no-repeat center left;
149
+ }