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.
- data/History.txt +6 -0
- data/README.md +18 -14
- data/city.gemspec +1 -1
- data/example/step_definitions/example.step.rb +4 -0
- data/example/sub_features/second_example.feature +51 -0
- data/lib/city.rb +1 -1
- data/lib/cucumber/city_builder.rb +3 -1
- data/lib/templates/default/feature/html/outline.erb +49 -17
- data/lib/templates/default/feature/html/scenario.erb +7 -9
- data/lib/templates/default/feature/html/steps.erb +17 -17
- data/lib/templates/default/feature/setup.rb +1 -1
- data/lib/templates/default/featuredirectory/html/directory.erb +76 -0
- data/lib/templates/default/featuredirectory/html/setup.rb +36 -0
- data/lib/templates/default/fulldoc/html/css/common.css +74 -60
- data/lib/templates/default/fulldoc/html/full_list_features.erb +3 -0
- data/lib/templates/default/fulldoc/html/full_list_tags.erb +4 -15
- data/lib/templates/default/fulldoc/html/js/cucumber.js +29 -7
- data/lib/templates/default/fulldoc/html/setup.rb +15 -11
- data/lib/templates/default/requirements/html/namespace.erb +76 -0
- data/lib/templates/default/requirements/html/setup.rb +35 -0
- data/lib/templates/default/scenario/html/scenario.erb +0 -3
- data/lib/templates/default/tag/html/feature.erb +28 -47
- data/lib/templates/default/tag/html/scenario.erb +28 -42
- data/lib/templates/default/tag/html/tag.erb +1 -0
- data/lib/templates/default/tag/setup.rb +15 -1
- data/lib/templates/default/tags/html/namespace.erb +39 -0
- data/lib/templates/default/tags/html/setup.rb +21 -0
- data/lib/yard/code_objects/cucumber/namespace_object.rb +16 -6
- 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.
|
135
|
+
**1. Feature/Scenario Tag unions and intersections**
|
131
136
|
|
132
|
-
|
133
|
-
|
134
|
-
|
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.
|
143
|
+
**2. Performance enhancements**
|
137
144
|
|
138
|
-
|
139
|
-
|
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
|
-
|
144
|
-
feature page, show their descriptions, and of course all their other tags.
|
148
|
+
**3. Requirements Only Docuementation**
|
145
149
|
|
146
|
-
|
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(
|
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
@@ -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 } ||
|
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
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
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
|
-
|
32
|
+
<%= h @scenario.description %>
|
33
33
|
</div>
|
34
34
|
<% end %>
|
35
35
|
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
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
|
-
|
2
|
+
<% @step = step %>
|
3
3
|
|
4
4
|
|
5
|
-
|
6
|
-
|
5
|
+
<div <%= "id='#{@id}Step#{index}'" %> class="step <%= (index + 1) % 2 == 0 ? 'even' : 'odd' %>">
|
6
|
+
<span class="predicate"><%= step.keyword %></span>
|
7
7
|
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
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
|
-
|
19
|
+
</div>
|
20
20
|
|
21
|
-
|
22
|
-
|
21
|
+
<%= erb(:table) if step.has_table? %>
|
22
|
+
<%= erb(:pystring) if step.has_text? %>
|
23
23
|
|
24
24
|
|
25
|
-
|
25
|
+
<% end %>
|
@@ -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
|
-
|
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;
|
7
|
-
|
8
|
-
|
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
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
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
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
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
|
-
#
|
42
|
-
|
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
|
-
|
48
|
-
|
56
|
+
margin: 20px 20px 0px 30px;
|
57
|
+
font-size: 12px;
|
49
58
|
}
|
50
59
|
|
51
60
|
.scenario .step, #background .step {
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
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
|
-
|
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
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
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
|
-
|
92
|
-
|
94
|
+
margin-top: 20px;
|
95
|
+
margin-left: 40px;
|
93
96
|
}
|
94
97
|
.outline .keyword {
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
+
padding: 4px;
|
99
|
+
font-weight: bold;
|
100
|
+
font-size: 16px;
|
98
101
|
}
|
99
102
|
|
100
103
|
.multiline table tr, .outline table tr {
|
101
|
-
|
104
|
+
padding: 4px;
|
102
105
|
}
|
103
106
|
.multiline table thead tr th, .outline table thead tr th {
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
+
text-align: left;
|
108
|
+
padding: 4px;
|
109
|
+
background-color: #A8C0A8;
|
107
110
|
}
|
108
111
|
.multiline table tr td, .outline table tr td {
|
109
|
-
|
110
|
-
|
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
|
-
|
125
|
-
|
126
|
-
|
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
|
-
|
133
|
+
margin: 10px 0px 0px 30px;
|
131
134
|
}
|
132
135
|
.stepdef .steps .step {
|
133
|
-
|
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
|
+
}
|