cucumber-in-the-yard 1.5.4 → 1.6.0

Sign up to get free protection for your applications and to get access to all the features.
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
+ }