friendly-cukes 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (90) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +14 -0
  3. data/DETAILED_DESCRIPTION.md +235 -0
  4. data/Gemfile +17 -0
  5. data/LICENSE.txt +22 -0
  6. data/README.md +108 -0
  7. data/Rakefile +2 -0
  8. data/bin/build-extractor +69 -0
  9. data/bin/friendly-cukes +48 -0
  10. data/friendly-cukes.gemspec +41 -0
  11. data/lib/friendly/build_extractor.rb +647 -0
  12. data/lib/friendly/cukes.rb +29 -0
  13. data/lib/friendly/cukes/framework/Gemfile +16 -0
  14. data/lib/friendly/cukes/framework/Gemfile.lock +113 -0
  15. data/lib/friendly/cukes/framework/Rakefile.rb +19 -0
  16. data/lib/friendly/cukes/framework/config/config.yml +87 -0
  17. data/lib/friendly/cukes/framework/config/cucumber.yml +49 -0
  18. data/lib/friendly/cukes/framework/coverage/.last_run.json +5 -0
  19. data/lib/friendly/cukes/framework/coverage/.resultset.json +3519 -0
  20. data/lib/friendly/cukes/framework/coverage/.resultset.json.lock +0 -0
  21. data/lib/friendly/cukes/framework/coverage/rcov/assets/0.2.3/jquery-1.3.2.min.js +19 -0
  22. data/lib/friendly/cukes/framework/coverage/rcov/assets/0.2.3/jquery.tablesorter.min.js +15 -0
  23. data/lib/friendly/cukes/framework/coverage/rcov/assets/0.2.3/print.css +12 -0
  24. data/lib/friendly/cukes/framework/coverage/rcov/assets/0.2.3/rcov.js +42 -0
  25. data/lib/friendly/cukes/framework/coverage/rcov/assets/0.2.3/screen.css +270 -0
  26. data/lib/friendly/cukes/framework/coverage/rcov/index.html +392 -0
  27. data/lib/friendly/cukes/framework/coverage/rcov/library-app_init-app_driver_rb.html +98 -0
  28. data/lib/friendly/cukes/framework/coverage/rcov/library-app_utils-data_file_names_rb.html +65 -0
  29. data/lib/friendly/cukes/framework/coverage/rcov/library-app_utils-page_utils_rb.html +533 -0
  30. data/lib/friendly/cukes/framework/coverage/rcov/library-generic-create_log_rb.html +521 -0
  31. data/lib/friendly/cukes/framework/coverage/rcov/library-generic-custom_html_report_rb.html +2522 -0
  32. data/lib/friendly/cukes/framework/coverage/rcov/library-generic-datetime_library_rb.html +296 -0
  33. data/lib/friendly/cukes/framework/coverage/rcov/library-generic-file_library_rb.html +995 -0
  34. data/lib/friendly/cukes/framework/coverage/rcov/library-generic-performance_report_rb.html +1613 -0
  35. data/lib/friendly/cukes/framework/coverage/rcov/library-generic-read_from_yml_rb.html +944 -0
  36. data/lib/friendly/cukes/framework/coverage/rcov/object_repository-desktop-gem_search_rb.html +773 -0
  37. data/lib/friendly/cukes/framework/coverage/rcov/object_repository-desktop-google_search_rb.html +230 -0
  38. data/lib/friendly/cukes/framework/coverage/rcov/object_repository-mobile-mobile_google_search_rb.html +230 -0
  39. data/lib/friendly/cukes/framework/coverage/rcov/step_definitions-desktop-gem_search_rb.html +188 -0
  40. data/lib/friendly/cukes/framework/coverage/rcov/step_definitions-desktop-google_search_steps_rb.html +167 -0
  41. data/lib/friendly/cukes/framework/coverage/rcov/step_definitions-mobile-mobile_google_search_steps_rb.html +167 -0
  42. data/lib/friendly/cukes/framework/coverage/rcov/support-browser_settings_rb.html +851 -0
  43. data/lib/friendly/cukes/framework/coverage/rcov/support-env_rb.html +242 -0
  44. data/lib/friendly/cukes/framework/coverage/rcov/support-hooks_rb.html +878 -0
  45. data/lib/friendly/cukes/framework/coverage/rcov/support-html_formatter_rb.html +230 -0
  46. data/lib/friendly/cukes/framework/features/desktop/google_search/google_search.feature +19 -0
  47. data/lib/friendly/cukes/framework/features/desktop/rubygems_search/gem_name_tc_04.yml +2 -0
  48. data/lib/friendly/cukes/framework/features/desktop/rubygems_search/gem_search.feature +37 -0
  49. data/lib/friendly/cukes/framework/features/desktop/test_data/gem_name.yml +2 -0
  50. data/lib/friendly/cukes/framework/features/mobile/google_search/mobile_google_search.feature +19 -0
  51. data/lib/friendly/cukes/framework/library/app_init/app_init.rb +13 -0
  52. data/lib/friendly/cukes/framework/library/app_utils/data_file_names.rb +2 -0
  53. data/lib/friendly/cukes/framework/library/app_utils/page_utils.rb +157 -0
  54. data/lib/friendly/cukes/framework/library/generic/app_logo_1.png +0 -0
  55. data/lib/friendly/cukes/framework/library/generic/create_log.rb +154 -0
  56. data/lib/friendly/cukes/framework/library/generic/custom_html_report.rb +852 -0
  57. data/lib/friendly/cukes/framework/library/generic/datetime_library.rb +79 -0
  58. data/lib/friendly/cukes/framework/library/generic/file_library.rb +311 -0
  59. data/lib/friendly/cukes/framework/library/generic/performance_report.rb +518 -0
  60. data/lib/friendly/cukes/framework/library/generic/read_from_yml.rb +294 -0
  61. data/lib/friendly/cukes/framework/object_repository/desktop/desktop_web_object_repo.rb +50 -0
  62. data/lib/friendly/cukes/framework/object_repository/mobile/mobile_web_object_repo.rb +22 -0
  63. data/lib/friendly/cukes/framework/page_objects/desktop/gem_search.rb +213 -0
  64. data/lib/friendly/cukes/framework/page_objects/desktop/google_search.rb +53 -0
  65. data/lib/friendly/cukes/framework/page_objects/mobile/mobile_google_search.rb +53 -0
  66. data/lib/friendly/cukes/framework/step_definitions/desktop/gem_search.rb +43 -0
  67. data/lib/friendly/cukes/framework/step_definitions/desktop/google_search_steps.rb +36 -0
  68. data/lib/friendly/cukes/framework/step_definitions/mobile/mobile_google_search_steps.rb +36 -0
  69. data/lib/friendly/cukes/framework/support/browser_settings.rb +264 -0
  70. data/lib/friendly/cukes/framework/support/env.rb +65 -0
  71. data/lib/friendly/cukes/framework/support/hooks.rb +274 -0
  72. data/lib/friendly/cukes/framework/support/html_formatter.rb +57 -0
  73. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_33/app_env.log +15 -0
  74. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_33/custom_report/detailed_report/app_logo_1.png +0 -0
  75. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_33/custom_report/detailed_report/desktop_gem_search.html +647 -0
  76. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_33/custom_report/detailed_report/desktop_google_search.html +590 -0
  77. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_33/custom_report/report_home.html +593 -0
  78. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_33/desktop_rubygems_search.log +84 -0
  79. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_33/report_21_05_2015-11_04_54.html +472 -0
  80. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_33/report_21_05_2015-11_04_54.json +299 -0
  81. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_37/app_env.log +15 -0
  82. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_37/desktop_google_search.log +22 -0
  83. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_37/report_21_05_2015-11_03_49.html +472 -0
  84. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-11_03_37/report_21_05_2015-11_03_49.json +155 -0
  85. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-17_28_10/app_env.log +15 -0
  86. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-17_28_10/mobile_google_search.log +22 -0
  87. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-17_28_10/report_21_05_2015-17_29_26.html +472 -0
  88. data/lib/friendly/cukes/framework/test_result/test_report_21_05_2015-17_28_10/report_21_05_2015-17_29_26.json +143 -0
  89. data/lib/friendly/cukes/version.rb +61 -0
  90. metadata +309 -0
@@ -0,0 +1,851 @@
1
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2
+ <html lang='en' xml:lang='en' xmlns='http://www.w3.org/1999/xhtml'>
3
+ <head>
4
+ <title>support/browser_settings.rb</title>
5
+ <link href="./assets/0.2.3/screen.css" media="all" rel="stylesheet" type="text/css" />
6
+ <link href="./assets/0.2.3/print.css" media="print" rel="stylesheet" type="text/css" />
7
+ <meta http-equiv="Content-type" content="text/html;charset=UTF-8" />
8
+ <script type="text/javascript" src="./assets/0.2.3/rcov.js"></script>
9
+ </head>
10
+ <body>
11
+ <h1>Cukes C0 Coverage Information - Simploco - RCov</h1>
12
+ <h2>support/browser_settings.rb</h2>
13
+
14
+ <div class="report_table_wrapper">
15
+ <table class='report' id='report_table'>
16
+ <thead>
17
+ <tr>
18
+ <th class="left_align">Name</th>
19
+ <th class="right_align">Total Lines</th>
20
+ <th class="right_align">Lines of Code</th>
21
+ <th class="left_align">Total Coverage</th>
22
+ <th class="left_align">Code Coverage</th>
23
+ </tr>
24
+ </thead>
25
+ <tbody>
26
+ <tr>
27
+ <td class="left_align"><a href="support-browser_settings_rb.html">support/browser_settings.rb</a></td>
28
+ <td class='right_align'><tt>264</tt></td>
29
+ <td class='right_align'><tt>111</tt></td>
30
+ <td class="left_align"><div class="percent_graph_legend"><tt class=''>70.45%</tt></div>
31
+ <div class="percent_graph">
32
+ <div class="covered" style="width:70px"></div>
33
+ <div class="uncovered" style="width:30px"></div>
34
+ </div></td>
35
+ <td class="left_align"><div class="percent_graph_legend"><tt class=''>29.73%</tt></div>
36
+ <div class="percent_graph">
37
+ <div class="covered" style="width:30px"></div>
38
+ <div class="uncovered" style="width:70px"></div>
39
+ </div></td>
40
+ </tr>
41
+ </tbody>
42
+ </table>
43
+ </div>
44
+
45
+ <h3>Key</h3>
46
+
47
+ <div class="key"><pre><span class='marked'>Code reported as executed by Ruby looks like this...</span><span class='marked1'>and this: this line is also marked as covered.</span><span class='inferred'>Lines considered as run by rcov, but not reported by Ruby, look like this,</span><span class='inferred1'>and this: these lines were inferred by rcov (using simple heuristics).</span><span class='uncovered'>Finally, here's a line marked as not executed.</span></pre></div>
48
+
49
+ <h3>Coverage Details</h3>
50
+
51
+ <table class="details">
52
+ <tbody>
53
+ <tr class="inferred">
54
+ <td><pre><a name="line2">2</a> =begin</pre></td>
55
+ </tr>
56
+ <tr class="inferred">
57
+ <td><pre><a name="line3">3</a> *Name : BrowserSettings</pre></td>
58
+ </tr>
59
+ <tr class="inferred">
60
+ <td><pre><a name="line4">4</a> *Description : Browser settings definition for different web and mobile browsers</pre></td>
61
+ </tr>
62
+ <tr class="inferred">
63
+ <td><pre><a name="line5">5</a> *Author : Chandra sekaran</pre></td>
64
+ </tr>
65
+ <tr class="inferred">
66
+ <td><pre><a name="line6">6</a> *Creation Date : 24/04/2015</pre></td>
67
+ </tr>
68
+ <tr class="inferred">
69
+ <td><pre><a name="line7">7</a> *Updation Date :</pre></td>
70
+ </tr>
71
+ <tr class="inferred">
72
+ <td><pre><a name="line8">8</a> =end</pre></td>
73
+ </tr>
74
+ <tr class="inferred">
75
+ <td><pre><a name="line9">9</a> </pre></td>
76
+ </tr>
77
+ <tr class="marked">
78
+ <td><pre><a name="line10">10</a> module CUKES</pre></td>
79
+ </tr>
80
+ <tr class="marked">
81
+ <td><pre><a name="line11">11</a> module BrowserSettings</pre></td>
82
+ </tr>
83
+ <tr class="marked">
84
+ <td><pre><a name="line12">12</a> include FileLibrary # module that defines all file related manipulations</pre></td>
85
+ </tr>
86
+ <tr class="marked">
87
+ <td><pre><a name="line13">13</a> include DateTimeLibrary # module that defines all date time manipulations</pre></td>
88
+ </tr>
89
+ <tr class="inferred">
90
+ <td><pre><a name="line14">14</a> </pre></td>
91
+ </tr>
92
+ <tr class="inferred">
93
+ <td><pre><a name="line15">15</a> # Description : launches a browser and returns the browser object</pre></td>
94
+ </tr>
95
+ <tr class="inferred">
96
+ <td><pre><a name="line16">16</a> # Author : Chandra sekaran</pre></td>
97
+ </tr>
98
+ <tr class="inferred">
99
+ <td><pre><a name="line17">17</a> # Arguments :</pre></td>
100
+ </tr>
101
+ <tr class="inferred">
102
+ <td><pre><a name="line18">18</a> # str_browser_name: name of the browser</pre></td>
103
+ </tr>
104
+ <tr class="inferred">
105
+ <td><pre><a name="line19">19</a> # Return values :</pre></td>
106
+ </tr>
107
+ <tr class="inferred">
108
+ <td><pre><a name="line20">20</a> # @browser : browser object</pre></td>
109
+ </tr>
110
+ <tr class="inferred">
111
+ <td><pre><a name="line21">21</a> #</pre></td>
112
+ </tr>
113
+ <tr class="marked">
114
+ <td><pre><a name="line22">22</a> def self.browser_setup(str_browser_name)</pre></td>
115
+ </tr>
116
+ <tr class="marked">
117
+ <td><pre><a name="line23">23</a> @browser_name = str_browser_name</pre></td>
118
+ </tr>
119
+ <tr class="marked">
120
+ <td><pre><a name="line24">24</a> @browser = start_browser(@browser_name)</pre></td>
121
+ </tr>
122
+ <tr class="marked">
123
+ <td><pre><a name="line25">25</a> raise &quot;Nil class error : No valid browser object found for #{str_browser_name}&quot; if @browser.nil?</pre></td>
124
+ </tr>
125
+ <tr class="marked">
126
+ <td><pre><a name="line26">26</a> return @browser</pre></td>
127
+ </tr>
128
+ <tr class="inferred">
129
+ <td><pre><a name="line27">27</a> rescue Exception =&gt; ex</pre></td>
130
+ </tr>
131
+ <tr class="uncovered">
132
+ <td><pre><a name="line28">28</a> $log.error(&quot;Error in launching browser #{str_browser_name} : #{ex}&quot;)</pre></td>
133
+ </tr>
134
+ <tr class="uncovered">
135
+ <td><pre><a name="line29">29</a> exit</pre></td>
136
+ </tr>
137
+ <tr class="inferred">
138
+ <td><pre><a name="line30">30</a> end</pre></td>
139
+ </tr>
140
+ <tr class="inferred">
141
+ <td><pre><a name="line31">31</a> </pre></td>
142
+ </tr>
143
+ <tr class="inferred">
144
+ <td><pre><a name="line32">32</a> # Description : deletes all cookies from the current browser</pre></td>
145
+ </tr>
146
+ <tr class="inferred">
147
+ <td><pre><a name="line33">33</a> # Author : Chandra sekaran</pre></td>
148
+ </tr>
149
+ <tr class="inferred">
150
+ <td><pre><a name="line34">34</a> #</pre></td>
151
+ </tr>
152
+ <tr class="marked">
153
+ <td><pre><a name="line35">35</a> def self.delete_cookies</pre></td>
154
+ </tr>
155
+ <tr class="uncovered">
156
+ <td><pre><a name="line36">36</a> @browser.manage.delete_all_cookies</pre></td>
157
+ </tr>
158
+ <tr class="uncovered">
159
+ <td><pre><a name="line37">37</a> $log.success(&quot;#{@browser_name} browser cookies deleted successfully&quot;)</pre></td>
160
+ </tr>
161
+ <tr class="inferred">
162
+ <td><pre><a name="line38">38</a> rescue Exception =&gt; ex</pre></td>
163
+ </tr>
164
+ <tr class="uncovered">
165
+ <td><pre><a name="line39">39</a> $log.error(&quot;Error while deleting the &quot; + @browser_name + &quot; browser cookies - #{ex}&quot;)</pre></td>
166
+ </tr>
167
+ <tr class="uncovered">
168
+ <td><pre><a name="line40">40</a> exit</pre></td>
169
+ </tr>
170
+ <tr class="inferred">
171
+ <td><pre><a name="line41">41</a> end</pre></td>
172
+ </tr>
173
+ <tr class="inferred">
174
+ <td><pre><a name="line42">42</a> </pre></td>
175
+ </tr>
176
+ <tr class="inferred">
177
+ <td><pre><a name="line43">43</a> # Description : launches the given URL in the current browser</pre></td>
178
+ </tr>
179
+ <tr class="inferred">
180
+ <td><pre><a name="line44">44</a> # Author : Chandra sekaran</pre></td>
181
+ </tr>
182
+ <tr class="inferred">
183
+ <td><pre><a name="line45">45</a> # Arguments :</pre></td>
184
+ </tr>
185
+ <tr class="inferred">
186
+ <td><pre><a name="line46">46</a> # str_url : url of the web site to be launched</pre></td>
187
+ </tr>
188
+ <tr class="inferred">
189
+ <td><pre><a name="line47">47</a> #</pre></td>
190
+ </tr>
191
+ <tr class="marked">
192
+ <td><pre><a name="line48">48</a> def self.launch_url(str_url)</pre></td>
193
+ </tr>
194
+ <tr class="inferred">
195
+ <td><pre><a name="line49">49</a> # delete_cookies</pre></td>
196
+ </tr>
197
+ <tr class="uncovered">
198
+ <td><pre><a name="line50">50</a> @browser.navigate.to(str_url)</pre></td>
199
+ </tr>
200
+ <tr class="uncovered">
201
+ <td><pre><a name="line51">51</a> $log.info(&quot;#{str_url} launched successfully&quot;)</pre></td>
202
+ </tr>
203
+ <tr class="inferred">
204
+ <td><pre><a name="line52">52</a> rescue Exception =&gt; ex</pre></td>
205
+ </tr>
206
+ <tr class="uncovered">
207
+ <td><pre><a name="line53">53</a> $log.error(&quot;Error in launching URL - #{str_url}&quot;)</pre></td>
208
+ </tr>
209
+ <tr class="uncovered">
210
+ <td><pre><a name="line54">54</a> exit</pre></td>
211
+ </tr>
212
+ <tr class="inferred">
213
+ <td><pre><a name="line55">55</a> end</pre></td>
214
+ </tr>
215
+ <tr class="inferred">
216
+ <td><pre><a name="line56">56</a> </pre></td>
217
+ </tr>
218
+ <tr class="inferred">
219
+ <td><pre><a name="line57">57</a> # Description : sets the timeout limit to find elements</pre></td>
220
+ </tr>
221
+ <tr class="inferred">
222
+ <td><pre><a name="line58">58</a> # Author : Chandra sekaran</pre></td>
223
+ </tr>
224
+ <tr class="inferred">
225
+ <td><pre><a name="line59">59</a> # Arguments :</pre></td>
226
+ </tr>
227
+ <tr class="inferred">
228
+ <td><pre><a name="line60">60</a> # num_timeout : numeric timeout value</pre></td>
229
+ </tr>
230
+ <tr class="inferred">
231
+ <td><pre><a name="line61">61</a> #</pre></td>
232
+ </tr>
233
+ <tr class="marked">
234
+ <td><pre><a name="line62">62</a> def self.set_timeout(num_timeout)</pre></td>
235
+ </tr>
236
+ <tr class="uncovered">
237
+ <td><pre><a name="line63">63</a> @browser.manage.timeouts.implicit_wait = num_timeout</pre></td>
238
+ </tr>
239
+ <tr class="uncovered">
240
+ <td><pre><a name="line64">64</a> $log.success(&quot;Selenium timeout set to &quot; + num_timeout.to_s)</pre></td>
241
+ </tr>
242
+ <tr class="inferred">
243
+ <td><pre><a name="line65">65</a> rescue Exception =&gt; ex</pre></td>
244
+ </tr>
245
+ <tr class="uncovered">
246
+ <td><pre><a name="line66">66</a> $log.error(&quot;Error in setting the selenium timeout to: &quot; + num_timeout.to_s)</pre></td>
247
+ </tr>
248
+ <tr class="uncovered">
249
+ <td><pre><a name="line67">67</a> exit</pre></td>
250
+ </tr>
251
+ <tr class="inferred">
252
+ <td><pre><a name="line68">68</a> end</pre></td>
253
+ </tr>
254
+ <tr class="inferred">
255
+ <td><pre><a name="line69">69</a> </pre></td>
256
+ </tr>
257
+ <tr class="inferred">
258
+ <td><pre><a name="line70">70</a> # Description : starts the browser and returns the browser object</pre></td>
259
+ </tr>
260
+ <tr class="inferred">
261
+ <td><pre><a name="line71">71</a> # Author : Chandra sekaran</pre></td>
262
+ </tr>
263
+ <tr class="inferred">
264
+ <td><pre><a name="line72">72</a> # Arguments :</pre></td>
265
+ </tr>
266
+ <tr class="inferred">
267
+ <td><pre><a name="line73">73</a> # str_browser : browser name</pre></td>
268
+ </tr>
269
+ <tr class="inferred">
270
+ <td><pre><a name="line74">74</a> # Return values :</pre></td>
271
+ </tr>
272
+ <tr class="inferred">
273
+ <td><pre><a name="line75">75</a> # @browser : browser object of the launched browser</pre></td>
274
+ </tr>
275
+ <tr class="inferred">
276
+ <td><pre><a name="line76">76</a> #</pre></td>
277
+ </tr>
278
+ <tr class="marked">
279
+ <td><pre><a name="line77">77</a> def self.start_browser(str_browser)</pre></td>
280
+ </tr>
281
+ <tr class="marked">
282
+ <td><pre><a name="line78">78</a> @browser = &#39;&#39;</pre></td>
283
+ </tr>
284
+ <tr class="marked">
285
+ <td><pre><a name="line79">79</a> if PLATFORM == &quot;desktop&quot;</pre></td>
286
+ </tr>
287
+ <tr class="marked">
288
+ <td><pre><a name="line80">80</a> @browser = setup_desktop_browser(str_browser)</pre></td>
289
+ </tr>
290
+ <tr class="marked">
291
+ <td><pre><a name="line81">81</a> @browser.manage.window.maximize if !@browser.nil?</pre></td>
292
+ </tr>
293
+ <tr class="inferred">
294
+ <td><pre><a name="line82">82</a> else</pre></td>
295
+ </tr>
296
+ <tr class="uncovered">
297
+ <td><pre><a name="line83">83</a> @browser = setup_mobile_browser</pre></td>
298
+ </tr>
299
+ <tr class="inferred">
300
+ <td><pre><a name="line84">84</a> end</pre></td>
301
+ </tr>
302
+ <tr class="marked">
303
+ <td><pre><a name="line85">85</a> return @browser</pre></td>
304
+ </tr>
305
+ <tr class="inferred">
306
+ <td><pre><a name="line86">86</a> end</pre></td>
307
+ </tr>
308
+ <tr class="inferred">
309
+ <td><pre><a name="line87">87</a> </pre></td>
310
+ </tr>
311
+ <tr class="inferred">
312
+ <td><pre><a name="line88">88</a> # Description : closes the current browser</pre></td>
313
+ </tr>
314
+ <tr class="inferred">
315
+ <td><pre><a name="line89">89</a> # Author : Chandra sekaran</pre></td>
316
+ </tr>
317
+ <tr class="inferred">
318
+ <td><pre><a name="line90">90</a> #</pre></td>
319
+ </tr>
320
+ <tr class="marked">
321
+ <td><pre><a name="line91">91</a> def self.close_browser</pre></td>
322
+ </tr>
323
+ <tr class="uncovered">
324
+ <td><pre><a name="line92">92</a> @browser.close</pre></td>
325
+ </tr>
326
+ <tr class="uncovered">
327
+ <td><pre><a name="line93">93</a> $log.success(&quot;Current browser closed successfully&quot;)</pre></td>
328
+ </tr>
329
+ <tr class="uncovered">
330
+ <td><pre><a name="line94">94</a> $log_env.success(&quot;Current browser closed successfully&quot;)</pre></td>
331
+ </tr>
332
+ <tr class="inferred">
333
+ <td><pre><a name="line95">95</a> rescue Exception =&gt; ex</pre></td>
334
+ </tr>
335
+ <tr class="uncovered">
336
+ <td><pre><a name="line96">96</a> $log.error(&quot;Error while closing the current browser - #{ex}&quot;)</pre></td>
337
+ </tr>
338
+ <tr class="uncovered">
339
+ <td><pre><a name="line97">97</a> exit</pre></td>
340
+ </tr>
341
+ <tr class="inferred">
342
+ <td><pre><a name="line98">98</a> end</pre></td>
343
+ </tr>
344
+ <tr class="inferred">
345
+ <td><pre><a name="line99">99</a> </pre></td>
346
+ </tr>
347
+ <tr class="inferred">
348
+ <td><pre><a name="line100">100</a> # Description : closes the current browser</pre></td>
349
+ </tr>
350
+ <tr class="inferred">
351
+ <td><pre><a name="line101">101</a> # Author : Chandra sekaran</pre></td>
352
+ </tr>
353
+ <tr class="inferred">
354
+ <td><pre><a name="line102">102</a> #</pre></td>
355
+ </tr>
356
+ <tr class="marked">
357
+ <td><pre><a name="line103">103</a> def self.quit_browser</pre></td>
358
+ </tr>
359
+ <tr class="marked">
360
+ <td><pre><a name="line104">104</a> @browser.quit</pre></td>
361
+ </tr>
362
+ <tr class="marked">
363
+ <td><pre><a name="line105">105</a> $log_env.success(&quot;Current browser closed successfully&quot;)</pre></td>
364
+ </tr>
365
+ <tr class="inferred">
366
+ <td><pre><a name="line106">106</a> rescue Exception =&gt; ex</pre></td>
367
+ </tr>
368
+ <tr class="uncovered">
369
+ <td><pre><a name="line107">107</a> $log.error(&quot;Error while closing the current browser - #{ex}&quot;)</pre></td>
370
+ </tr>
371
+ <tr class="uncovered">
372
+ <td><pre><a name="line108">108</a> exit</pre></td>
373
+ </tr>
374
+ <tr class="inferred">
375
+ <td><pre><a name="line109">109</a> end</pre></td>
376
+ </tr>
377
+ <tr class="inferred">
378
+ <td><pre><a name="line110">110</a> </pre></td>
379
+ </tr>
380
+ <tr class="inferred">
381
+ <td><pre><a name="line111">111</a> # Description : restarts the current browser</pre></td>
382
+ </tr>
383
+ <tr class="inferred">
384
+ <td><pre><a name="line112">112</a> # Author : Chandra sekaran</pre></td>
385
+ </tr>
386
+ <tr class="inferred">
387
+ <td><pre><a name="line113">113</a> # Return value :</pre></td>
388
+ </tr>
389
+ <tr class="inferred">
390
+ <td><pre><a name="line114">114</a> # @browser : browser object of the new browser</pre></td>
391
+ </tr>
392
+ <tr class="inferred">
393
+ <td><pre><a name="line115">115</a> #</pre></td>
394
+ </tr>
395
+ <tr class="marked">
396
+ <td><pre><a name="line116">116</a> def self.restart_browser</pre></td>
397
+ </tr>
398
+ <tr class="uncovered">
399
+ <td><pre><a name="line117">117</a> quit_browser</pre></td>
400
+ </tr>
401
+ <tr class="uncovered">
402
+ <td><pre><a name="line118">118</a> @browser_name = BROWSER</pre></td>
403
+ </tr>
404
+ <tr class="uncovered">
405
+ <td><pre><a name="line119">119</a> $log.info(&quot;Restarting the browser (#{@browser_name})&quot;)</pre></td>
406
+ </tr>
407
+ <tr class="uncovered">
408
+ <td><pre><a name="line120">120</a> @browser = browser_setup(@browser_name)</pre></td>
409
+ </tr>
410
+ <tr class="uncovered">
411
+ <td><pre><a name="line121">121</a> @browser</pre></td>
412
+ </tr>
413
+ <tr class="inferred">
414
+ <td><pre><a name="line122">122</a> rescue Exception =&gt; ex</pre></td>
415
+ </tr>
416
+ <tr class="uncovered">
417
+ <td><pre><a name="line123">123</a> $log.error(&quot;Error while restarting browser - #{ex}&quot;)</pre></td>
418
+ </tr>
419
+ <tr class="uncovered">
420
+ <td><pre><a name="line124">124</a> exit</pre></td>
421
+ </tr>
422
+ <tr class="inferred">
423
+ <td><pre><a name="line125">125</a> end</pre></td>
424
+ </tr>
425
+ <tr class="inferred">
426
+ <td><pre><a name="line126">126</a> </pre></td>
427
+ </tr>
428
+ <tr class="inferred">
429
+ <td><pre><a name="line127">127</a> # Description : launches the desktop browser</pre></td>
430
+ </tr>
431
+ <tr class="inferred">
432
+ <td><pre><a name="line128">128</a> # Author : Chandra sekaran</pre></td>
433
+ </tr>
434
+ <tr class="inferred">
435
+ <td><pre><a name="line129">129</a> # Arguments :</pre></td>
436
+ </tr>
437
+ <tr class="inferred">
438
+ <td><pre><a name="line130">130</a> # str_browser : browser name</pre></td>
439
+ </tr>
440
+ <tr class="inferred">
441
+ <td><pre><a name="line131">131</a> # Return value :</pre></td>
442
+ </tr>
443
+ <tr class="inferred">
444
+ <td><pre><a name="line132">132</a> # @browser : browser object of the new browser</pre></td>
445
+ </tr>
446
+ <tr class="inferred">
447
+ <td><pre><a name="line133">133</a> #</pre></td>
448
+ </tr>
449
+ <tr class="marked">
450
+ <td><pre><a name="line134">134</a> def self.setup_desktop_browser(str_browser)</pre></td>
451
+ </tr>
452
+ <tr class="marked">
453
+ <td><pre><a name="line135">135</a> @browser = nil</pre></td>
454
+ </tr>
455
+ <tr class="marked">
456
+ <td><pre><a name="line136">136</a> case str_browser.downcase</pre></td>
457
+ </tr>
458
+ <tr class="inferred">
459
+ <td><pre><a name="line137">137</a> when &quot;internet_explorer&quot;</pre></td>
460
+ </tr>
461
+ <tr class="uncovered">
462
+ <td><pre><a name="line138">138</a> @browser = Selenium::WebDriver.for :internet_explorer</pre></td>
463
+ </tr>
464
+ <tr class="inferred">
465
+ <td><pre><a name="line139">139</a> </pre></td>
466
+ </tr>
467
+ <tr class="inferred">
468
+ <td><pre><a name="line140">140</a> when &quot;firefox&quot;</pre></td>
469
+ </tr>
470
+ <tr class="uncovered">
471
+ <td><pre><a name="line141">141</a> @browser = Selenium::WebDriver.for :firefox</pre></td>
472
+ </tr>
473
+ <tr class="inferred">
474
+ <td><pre><a name="line142">142</a> </pre></td>
475
+ </tr>
476
+ <tr class="inferred">
477
+ <td><pre><a name="line143">143</a> when &quot;chrome&quot;</pre></td>
478
+ </tr>
479
+ <tr class="marked">
480
+ <td><pre><a name="line144">144</a> caps = Selenium::WebDriver::Remote::Capabilities.chrome(&quot;chromeOptions&quot; =&gt; {&quot;args&quot; =&gt; [&quot;test-type&quot;]})</pre></td>
481
+ </tr>
482
+ <tr class="marked">
483
+ <td><pre><a name="line145">145</a> @browser = Selenium::WebDriver.for :chrome, desired_capabilities: caps</pre></td>
484
+ </tr>
485
+ <tr class="inferred">
486
+ <td><pre><a name="line146">146</a> </pre></td>
487
+ </tr>
488
+ <tr class="inferred">
489
+ <td><pre><a name="line147">147</a> # if you want to set the download path to your local framework directory, then you can use the below</pre></td>
490
+ </tr>
491
+ <tr class="inferred">
492
+ <td><pre><a name="line148">148</a> # selenium capabilities, which will set the current download directory to your current test result directory</pre></td>
493
+ </tr>
494
+ <tr class="inferred">
495
+ <td><pre><a name="line149">149</a> #caps = Selenium::WebDriver::Remote::Capabilities.chrome(&quot;chromeOptions&quot; =&gt; {&quot;args&quot; =&gt; [&quot;test-type&quot; ]})</pre></td>
496
+ </tr>
497
+ <tr class="inferred">
498
+ <td><pre><a name="line150">150</a> #prefs = {</pre></td>
499
+ </tr>
500
+ <tr class="inferred">
501
+ <td><pre><a name="line151">151</a> # :download =&gt; {</pre></td>
502
+ </tr>
503
+ <tr class="inferred">
504
+ <td><pre><a name="line152">152</a> # :prompt_for_download =&gt; false,</pre></td>
505
+ </tr>
506
+ <tr class="inferred">
507
+ <td><pre><a name="line153">153</a> # :default_directory =&gt; File.expand_path($current_log_dir)</pre></td>
508
+ </tr>
509
+ <tr class="inferred">
510
+ <td><pre><a name="line154">154</a> # }</pre></td>
511
+ </tr>
512
+ <tr class="inferred">
513
+ <td><pre><a name="line155">155</a> #}</pre></td>
514
+ </tr>
515
+ <tr class="inferred">
516
+ <td><pre><a name="line156">156</a> #@browser = Selenium::WebDriver.for :chrome, :prefs =&gt; prefs, desired_capabilities: caps</pre></td>
517
+ </tr>
518
+ <tr class="inferred">
519
+ <td><pre><a name="line157">157</a> </pre></td>
520
+ </tr>
521
+ <tr class="inferred">
522
+ <td><pre><a name="line158">158</a> when &quot;safari&quot;</pre></td>
523
+ </tr>
524
+ <tr class="uncovered">
525
+ <td><pre><a name="line159">159</a> @browser = Selenium::WebDriver.for :safari</pre></td>
526
+ </tr>
527
+ <tr class="inferred">
528
+ <td><pre><a name="line160">160</a> </pre></td>
529
+ </tr>
530
+ <tr class="inferred">
531
+ <td><pre><a name="line161">161</a> when &quot;ios&quot;</pre></td>
532
+ </tr>
533
+ <tr class="uncovered">
534
+ <td><pre><a name="line162">162</a> if RUBY_PLATFORM.downcase.include?(&quot;darwin&quot;)</pre></td>
535
+ </tr>
536
+ <tr class="uncovered">
537
+ <td><pre><a name="line163">163</a> @browser = Selenium::WebDriver.for :iphone</pre></td>
538
+ </tr>
539
+ <tr class="inferred">
540
+ <td><pre><a name="line164">164</a> else</pre></td>
541
+ </tr>
542
+ <tr class="uncovered">
543
+ <td><pre><a name="line165">165</a> raise &quot;You can&#39;t run IOS tests on non-mac machine&quot;</pre></td>
544
+ </tr>
545
+ <tr class="inferred">
546
+ <td><pre><a name="line166">166</a> end</pre></td>
547
+ </tr>
548
+ <tr class="inferred">
549
+ <td><pre><a name="line167">167</a> else</pre></td>
550
+ </tr>
551
+ <tr class="uncovered">
552
+ <td><pre><a name="line168">168</a> raise &quot;Could not determine the browser - #{str_browser}&quot;</pre></td>
553
+ </tr>
554
+ <tr class="inferred">
555
+ <td><pre><a name="line169">169</a> end</pre></td>
556
+ </tr>
557
+ <tr class="marked">
558
+ <td><pre><a name="line170">170</a> $log.success(&quot;Successfully launched desktop #{str_browser} browser (Version : #{@browser.capabilities[:version]}, Resolution : &#39;#{@browser.execute_script(&#39;return screen.width&#39;)}x#{@browser.execute_script(&#39;return screen.height&#39;)}&#39;)&quot;)</pre></td>
559
+ </tr>
560
+ <tr class="marked">
561
+ <td><pre><a name="line171">171</a> return @browser</pre></td>
562
+ </tr>
563
+ <tr class="inferred">
564
+ <td><pre><a name="line172">172</a> rescue Exception =&gt; ex</pre></td>
565
+ </tr>
566
+ <tr class="uncovered">
567
+ <td><pre><a name="line173">173</a> $log.error(&quot;Error in starting desktop browser #{str_browser} : &quot; + ex)</pre></td>
568
+ </tr>
569
+ <tr class="uncovered">
570
+ <td><pre><a name="line174">174</a> exit</pre></td>
571
+ </tr>
572
+ <tr class="inferred">
573
+ <td><pre><a name="line175">175</a> end</pre></td>
574
+ </tr>
575
+ <tr class="inferred">
576
+ <td><pre><a name="line176">176</a> </pre></td>
577
+ </tr>
578
+ <tr class="inferred">
579
+ <td><pre><a name="line177">177</a> # Description : saves the screenshot of the webpage as png file</pre></td>
580
+ </tr>
581
+ <tr class="inferred">
582
+ <td><pre><a name="line178">178</a> # Author : Chandra sekaran</pre></td>
583
+ </tr>
584
+ <tr class="inferred">
585
+ <td><pre><a name="line179">179</a> # Arguments :</pre></td>
586
+ </tr>
587
+ <tr class="inferred">
588
+ <td><pre><a name="line180">180</a> # str_module_name : module name under features directory</pre></td>
589
+ </tr>
590
+ <tr class="inferred">
591
+ <td><pre><a name="line181">181</a> #</pre></td>
592
+ </tr>
593
+ <tr class="marked">
594
+ <td><pre><a name="line182">182</a> def self.capture_screenshot(str_module_name)</pre></td>
595
+ </tr>
596
+ <tr class="uncovered">
597
+ <td><pre><a name="line183">183</a> str_imgdir_path = &quot;#{$current_log_dir}/screenshot&quot;</pre></td>
598
+ </tr>
599
+ <tr class="uncovered">
600
+ <td><pre><a name="line184">184</a> unless File.directory?(str_imgdir_path) # creates a new directory</pre></td>
601
+ </tr>
602
+ <tr class="uncovered">
603
+ <td><pre><a name="line185">185</a> FileUtils.mkdir_p(str_imgdir_path)</pre></td>
604
+ </tr>
605
+ <tr class="inferred">
606
+ <td><pre><a name="line186">186</a> end</pre></td>
607
+ </tr>
608
+ <tr class="uncovered">
609
+ <td><pre><a name="line187">187</a> str_image = &quot;/#{str_module_name}_#{Time.now.strftime(DATETIME_FORMAT)}.png&quot;</pre></td>
610
+ </tr>
611
+ <tr class="uncovered">
612
+ <td><pre><a name="line188">188</a> str_imgdir_path &lt;&lt; str_image # adds image file name to the directory</pre></td>
613
+ </tr>
614
+ <tr class="uncovered">
615
+ <td><pre><a name="line189">189</a> @browser.save_screenshot(str_imgdir_path) # saves the screenshot image to the directory</pre></td>
616
+ </tr>
617
+ <tr class="uncovered">
618
+ <td><pre><a name="line190">190</a> $log.info(&quot;Screenshot is saved in #{str_imgdir_path}&quot;)</pre></td>
619
+ </tr>
620
+ <tr class="uncovered">
621
+ <td><pre><a name="line191">191</a> return &quot;screenshot#{str_image}&quot;</pre></td>
622
+ </tr>
623
+ <tr class="inferred">
624
+ <td><pre><a name="line192">192</a> rescue Exception =&gt; ex</pre></td>
625
+ </tr>
626
+ <tr class="uncovered">
627
+ <td><pre><a name="line193">193</a> $log.error(&quot;Error in taking screenshot for #{str_imgdir_path} : #{ex}&quot;)</pre></td>
628
+ </tr>
629
+ <tr class="uncovered">
630
+ <td><pre><a name="line194">194</a> exit</pre></td>
631
+ </tr>
632
+ <tr class="inferred">
633
+ <td><pre><a name="line195">195</a> end</pre></td>
634
+ </tr>
635
+ <tr class="inferred">
636
+ <td><pre><a name="line196">196</a> </pre></td>
637
+ </tr>
638
+ <tr class="inferred">
639
+ <td><pre><a name="line197">197</a> # Description : launches the mobile browser</pre></td>
640
+ </tr>
641
+ <tr class="inferred">
642
+ <td><pre><a name="line198">198</a> # Author : Chandra sekaran</pre></td>
643
+ </tr>
644
+ <tr class="inferred">
645
+ <td><pre><a name="line199">199</a> # Arguments :</pre></td>
646
+ </tr>
647
+ <tr class="inferred">
648
+ <td><pre><a name="line200">200</a> # @browser : browser object of the mobile browser</pre></td>
649
+ </tr>
650
+ <tr class="inferred">
651
+ <td><pre><a name="line201">201</a> #</pre></td>
652
+ </tr>
653
+ <tr class="marked">
654
+ <td><pre><a name="line202">202</a> def self.setup_mobile_browser</pre></td>
655
+ </tr>
656
+ <tr class="uncovered">
657
+ <td><pre><a name="line203">203</a> bool_device_enabled = DEVICE.nil? ? false : (DEVICE.downcase.eql?(&quot;true&quot;)? true : false)</pre></td>
658
+ </tr>
659
+ <tr class="uncovered">
660
+ <td><pre><a name="line204">204</a> case(BROWSER.downcase)</pre></td>
661
+ </tr>
662
+ <tr class="inferred">
663
+ <td><pre><a name="line205">205</a> when &quot;android&quot;, &quot;chrome&quot;, &quot;browser&quot;</pre></td>
664
+ </tr>
665
+ <tr class="uncovered">
666
+ <td><pre><a name="line206">206</a> @browser = setup_android(bool_device_enabled, BROWSER)</pre></td>
667
+ </tr>
668
+ <tr class="inferred">
669
+ <td><pre><a name="line207">207</a> when &quot;safari&quot;</pre></td>
670
+ </tr>
671
+ <tr class="uncovered">
672
+ <td><pre><a name="line208">208</a> if is_emulator_enabled</pre></td>
673
+ </tr>
674
+ <tr class="uncovered">
675
+ <td><pre><a name="line209">209</a> caps = {</pre></td>
676
+ </tr>
677
+ <tr class="inferred">
678
+ <td><pre><a name="line210">210</a> :platform =&gt; &#39;Mac&#39;,</pre></td>
679
+ </tr>
680
+ <tr class="inferred">
681
+ <td><pre><a name="line211">211</a> :device =&gt; &#39;iPhone Simulator&#39;,</pre></td>
682
+ </tr>
683
+ <tr class="inferred">
684
+ <td><pre><a name="line212">212</a> :browser_name =&gt; &#39;iOS&#39;,</pre></td>
685
+ </tr>
686
+ <tr class="inferred">
687
+ <td><pre><a name="line213">213</a> :version =&gt; &#39;7.1&#39;,</pre></td>
688
+ </tr>
689
+ <tr class="inferred">
690
+ <td><pre><a name="line214">214</a> :app =&gt; &#39;safari&#39;,</pre></td>
691
+ </tr>
692
+ <tr class="inferred">
693
+ <td><pre><a name="line215">215</a> :newCommandTimeout =&gt; 60000,</pre></td>
694
+ </tr>
695
+ <tr class="inferred">
696
+ <td><pre><a name="line216">216</a> :javascript_enabled =&gt; true</pre></td>
697
+ </tr>
698
+ <tr class="inferred">
699
+ <td><pre><a name="line217">217</a> }</pre></td>
700
+ </tr>
701
+ <tr class="uncovered">
702
+ <td><pre><a name="line218">218</a> client = Selenium::WebDriver::Remote::Http::Default.new</pre></td>
703
+ </tr>
704
+ <tr class="uncovered">
705
+ <td><pre><a name="line219">219</a> client.timeout = 1000 # seconds</pre></td>
706
+ </tr>
707
+ <tr class="uncovered">
708
+ <td><pre><a name="line220">220</a> @browser = Selenium::WebDriver.for :remote, :url =&gt; app_url , :desired_capabilities =&gt; caps , :http_client =&gt; client</pre></td>
709
+ </tr>
710
+ <tr class="inferred">
711
+ <td><pre><a name="line221">221</a> end</pre></td>
712
+ </tr>
713
+ <tr class="inferred">
714
+ <td><pre><a name="line222">222</a> else</pre></td>
715
+ </tr>
716
+ <tr class="uncovered">
717
+ <td><pre><a name="line223">223</a> raise &quot;Invalid browser name : #{BROWSER}&quot;</pre></td>
718
+ </tr>
719
+ <tr class="inferred">
720
+ <td><pre><a name="line224">224</a> end</pre></td>
721
+ </tr>
722
+ <tr class="uncovered">
723
+ <td><pre><a name="line225">225</a> return @browser</pre></td>
724
+ </tr>
725
+ <tr class="inferred">
726
+ <td><pre><a name="line226">226</a> rescue Exception =&gt; ex</pre></td>
727
+ </tr>
728
+ <tr class="uncovered">
729
+ <td><pre><a name="line227">227</a> $log.error(&quot;Error while setting up mobile browser : #{ex}&quot;)</pre></td>
730
+ </tr>
731
+ <tr class="uncovered">
732
+ <td><pre><a name="line228">228</a> exit</pre></td>
733
+ </tr>
734
+ <tr class="inferred">
735
+ <td><pre><a name="line229">229</a> end</pre></td>
736
+ </tr>
737
+ <tr class="inferred">
738
+ <td><pre><a name="line230">230</a> </pre></td>
739
+ </tr>
740
+ <tr class="inferred">
741
+ <td><pre><a name="line231">231</a> # Description : launches mobile browser</pre></td>
742
+ </tr>
743
+ <tr class="inferred">
744
+ <td><pre><a name="line232">232</a> # Author : Chandra sekaran</pre></td>
745
+ </tr>
746
+ <tr class="inferred">
747
+ <td><pre><a name="line233">233</a> # Arguments :</pre></td>
748
+ </tr>
749
+ <tr class="inferred">
750
+ <td><pre><a name="line234">234</a> # str_module_name : module name under features directory</pre></td>
751
+ </tr>
752
+ <tr class="inferred">
753
+ <td><pre><a name="line235">235</a> #</pre></td>
754
+ </tr>
755
+ <tr class="marked">
756
+ <td><pre><a name="line236">236</a> def self.setup_android(bool_device_enabled, str_browser_name)</pre></td>
757
+ </tr>
758
+ <tr class="uncovered">
759
+ <td><pre><a name="line237">237</a> browser = &quot;&quot;</pre></td>
760
+ </tr>
761
+ <tr class="uncovered">
762
+ <td><pre><a name="line238">238</a> if str_browser_name.downcase == &quot;chrome&quot;</pre></td>
763
+ </tr>
764
+ <tr class="uncovered">
765
+ <td><pre><a name="line239">239</a> browser_name = &quot;Chrome&quot;</pre></td>
766
+ </tr>
767
+ <tr class="inferred">
768
+ <td><pre><a name="line240">240</a> elsif str_browser_name.downcase == &quot;browser&quot; || str_browser_name.downcase == &quot;android&quot;</pre></td>
769
+ </tr>
770
+ <tr class="uncovered">
771
+ <td><pre><a name="line241">241</a> browser_name = &quot;Browser&quot;</pre></td>
772
+ </tr>
773
+ <tr class="inferred">
774
+ <td><pre><a name="line242">242</a> else</pre></td>
775
+ </tr>
776
+ <tr class="uncovered">
777
+ <td><pre><a name="line243">243</a> raise &quot;Profile for &#39;#{str_browser_name}&#39; browser does not exists&quot;</pre></td>
778
+ </tr>
779
+ <tr class="inferred">
780
+ <td><pre><a name="line244">244</a> end</pre></td>
781
+ </tr>
782
+ <tr class="inferred">
783
+ <td><pre><a name="line245">245</a> </pre></td>
784
+ </tr>
785
+ <tr class="uncovered">
786
+ <td><pre><a name="line246">246</a> if bool_device_enabled</pre></td>
787
+ </tr>
788
+ <tr class="uncovered">
789
+ <td><pre><a name="line247">247</a> caps = { :browserName =&gt; browser_name, :platformName =&gt; &quot;Android&quot;, :newCommandTimeout =&gt; 60000, :deviceName =&gt; &quot;4D00C0124B174161&quot; }</pre></td>
790
+ </tr>
791
+ <tr class="uncovered">
792
+ <td><pre><a name="line248">248</a> client = Selenium::WebDriver::Remote::Http::Default.new</pre></td>
793
+ </tr>
794
+ <tr class="uncovered">
795
+ <td><pre><a name="line249">249</a> client.timeout = 5000</pre></td>
796
+ </tr>
797
+ <tr class="uncovered">
798
+ <td><pre><a name="line250">250</a> browser = Selenium::WebDriver.for(:remote, :url =&gt; &quot;http://localhost:4723/wd/hub/&quot;, :http_client =&gt; client, :desired_capabilities =&gt; caps)</pre></td>
799
+ </tr>
800
+ <tr class="inferred">
801
+ <td><pre><a name="line251">251</a> else</pre></td>
802
+ </tr>
803
+ <tr class="uncovered">
804
+ <td><pre><a name="line252">252</a> caps = { :browserName =&gt; browser_name, :platformName =&gt; &quot;Android&quot;, :Version =&gt; &quot;4.4.2&quot;, :deviceName =&gt; &quot;EMULATOR-5554&quot; }</pre></td>
805
+ </tr>
806
+ <tr class="uncovered">
807
+ <td><pre><a name="line253">253</a> client = Selenium::WebDriver::Remote::Http::Default.new</pre></td>
808
+ </tr>
809
+ <tr class="uncovered">
810
+ <td><pre><a name="line254">254</a> client.timeout = 5000</pre></td>
811
+ </tr>
812
+ <tr class="uncovered">
813
+ <td><pre><a name="line255">255</a> browser = Selenium::WebDriver.for(:remote, :url =&gt; &quot;http://localhost:4723/wd/hub/&quot;, :http_client =&gt; client, :desired_capabilities =&gt; caps)</pre></td>
814
+ </tr>
815
+ <tr class="inferred">
816
+ <td><pre><a name="line256">256</a> end</pre></td>
817
+ </tr>
818
+ <tr class="uncovered">
819
+ <td><pre><a name="line257">257</a> $log.success(&quot;Launched #{str_browser_name} in Android #{bool_device_enabled ? &#39;device&#39; : &#39;emulator&#39;} successfully&quot;)</pre></td>
820
+ </tr>
821
+ <tr class="uncovered">
822
+ <td><pre><a name="line258">258</a> browser</pre></td>
823
+ </tr>
824
+ <tr class="inferred">
825
+ <td><pre><a name="line259">259</a> rescue Exception =&gt; ex</pre></td>
826
+ </tr>
827
+ <tr class="uncovered">
828
+ <td><pre><a name="line260">260</a> $log.error(&quot;Error while setting Android browser profile for &#39;#{str_browser_name}&#39; : #{ex}&quot;)</pre></td>
829
+ </tr>
830
+ <tr class="uncovered">
831
+ <td><pre><a name="line261">261</a> exit</pre></td>
832
+ </tr>
833
+ <tr class="inferred">
834
+ <td><pre><a name="line262">262</a> end</pre></td>
835
+ </tr>
836
+ <tr class="inferred">
837
+ <td><pre><a name="line263">263</a> </pre></td>
838
+ </tr>
839
+ <tr class="inferred">
840
+ <td><pre><a name="line264">264</a> end</pre></td>
841
+ </tr>
842
+ <tr class="inferred">
843
+ <td><pre><a name="line265">265</a> end</pre></td>
844
+ </tr>
845
+ </tbody>
846
+ </table>
847
+
848
+ <p>Generated on 2015-05-08 10:40:30 +0530 with <a href="https://github.com/fguillen/simplecov-rcov">SimpleCov-RCov 0.2.3</a></p>
849
+
850
+ </body>
851
+ </html>