awetestlib 0.1.5-x86-mingw32 → 0.1.6-x86-mingw32
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.
- data/README.md +55 -0
- data/awetestlib.windows.gemspec +2 -1
- data/awetestlib_osx.gemspec +1 -0
- data/lib/awetestlib/logging.rb +4 -4
- data/lib/awetestlib/regression/runner.rb +8 -2
- data/lib/awetestlib/regression/tables.rb +30 -5
- data/lib/awetestlib/regression/user_input.rb +550 -633
- data/lib/awetestlib/regression/utilities.rb +7 -0
- data/lib/version.rb +2 -2
- data/tmp/placeholder.html +71 -0
- metadata +20 -4
data/README.md
ADDED
@@ -0,0 +1,55 @@
|
|
1
|
+
Awetestlib
|
2
|
+
==========
|
3
|
+
|
4
|
+
Run automated regression and mobile tests
|
5
|
+
|
6
|
+
After completing this guide you will be able to run tests locally from command line or from an IDE
|
7
|
+
|
8
|
+
------------
|
9
|
+
|
10
|
+
### Prerequisites
|
11
|
+
|
12
|
+
You need to have Ruby 1.8.7 installed. You can download Ruby 1.8.7
|
13
|
+
[here](http://http://rubyinstaller.org/downloads/)
|
14
|
+
|
15
|
+
Additionally, you will need to install DevKit to compile a few dependent gems. You can download DevKit
|
16
|
+
[here](http://http://rubyinstaller.org/downloads/)
|
17
|
+
|
18
|
+
### Install
|
19
|
+
|
20
|
+
1. In a terminal or command prompt, install the awetestlib gem
|
21
|
+
- `gem install awetestlib --no-ri --no-rdoc`
|
22
|
+
|
23
|
+
|
24
|
+
2. To setup the regression module, run the following command and verify the step
|
25
|
+
- `awetestlib regression_setup`
|
26
|
+
|
27
|
+
### Usage
|
28
|
+
|
29
|
+
1. Run the following command to see the different usages
|
30
|
+
- `awetestlib`
|
31
|
+
|
32
|
+
2. To setup the awetestlib gem with Netbeans or Rubymine, run either of the commands
|
33
|
+
- `awetestlib rubymine_setup`
|
34
|
+
|
35
|
+
or
|
36
|
+
- `awetestlib netbeans_setup`
|
37
|
+
|
38
|
+
You can now start your scripts within the IDE. Use the Run Configuration button.
|
39
|
+
|
40
|
+
3. If you prefer to run your tests from command line, you can use the following command
|
41
|
+
- `awetestlib <script_file> [parameters]`
|
42
|
+
|
43
|
+
For example: To run a script named demo.rb in Firefox, your command will look like.
|
44
|
+
- `awetestlib demo.rb -b FF`
|
45
|
+
|
46
|
+
The full list of parameters for the command line currently are:
|
47
|
+
|
48
|
+
Usage: awetestlib <script_file> [parameters] [options]
|
49
|
+
-b, --browser BROWSER Specify a browser (IE, FF, S, C)
|
50
|
+
-l, --library LIBRARY Specify a library to be loaded
|
51
|
+
-r, --root_path ROOT_PATH Specify the root path
|
52
|
+
-x, --excel EXCEL_FILE Specify an excel file containing variables to be loaded
|
53
|
+
-v, --version VERSION Specify a browser version
|
54
|
+
|
55
|
+
|
data/awetestlib.windows.gemspec
CHANGED
@@ -31,8 +31,9 @@ Gem::Specification.new do |s|
|
|
31
31
|
s.add_dependency('selenium-webdriver')
|
32
32
|
s.add_dependency('pry')
|
33
33
|
s.add_dependency('rdoc', '~> 3.11')
|
34
|
+
s.add_dependency('yard')
|
34
35
|
|
35
|
-
|
36
|
+
s.has_rdoc = 'yard'
|
36
37
|
s.require_paths = ["lib"]
|
37
38
|
s.files = `git ls-files`.split("\n")
|
38
39
|
s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
|
data/awetestlib_osx.gemspec
CHANGED
@@ -32,6 +32,7 @@ Gem::Specification.new do |s|
|
|
32
32
|
s.add_dependency('nokogiri')
|
33
33
|
s.add_dependency('i18n')
|
34
34
|
s.add_dependency('rb-appscript')
|
35
|
+
s.add_dependency('json', '1.4.6') #for safari support
|
35
36
|
|
36
37
|
s.require_paths = ["lib"] #,"ext"]
|
37
38
|
s.files = `git ls-files`.split("\n")
|
data/lib/awetestlib/logging.rb
CHANGED
@@ -330,16 +330,16 @@ tags: log, begin, error, reference, validation, pass, fail, tallies, tag
|
|
330
330
|
def finish_run(ts = nil)
|
331
331
|
timestamp = Time.now unless ts
|
332
332
|
|
333
|
-
mark_testlevel(">>
|
333
|
+
mark_testlevel(">> Duration: #{sec2hms(timestamp - @start_timestamp)}", 0)
|
334
334
|
|
335
|
-
mark_testlevel(">>
|
336
|
-
"
|
335
|
+
mark_testlevel(">> Validations: #{@my_passed_count + @my_failed_count} | "+
|
336
|
+
"Fails: #{@my_failed_count}", 0) if @my_passed_count and @my_failed_count
|
337
337
|
|
338
338
|
tally_error_references
|
339
339
|
|
340
340
|
utc_ts = timestamp.getutc
|
341
341
|
loc_tm = "#{timestamp.strftime("%H:%M:%S")} #{timestamp.zone}"
|
342
|
-
|
342
|
+
debug_to_log(">> End #{@myName.titleize}")
|
343
343
|
|
344
344
|
end
|
345
345
|
|
@@ -44,7 +44,11 @@ module Awetestlib
|
|
44
44
|
::PASS = '-PASS'
|
45
45
|
::FAIL = '-FAIL'
|
46
46
|
|
47
|
-
|
47
|
+
# @return [Watir::Browser] the browser referenced by the attribute browser
|
48
|
+
attr_accessor :browser
|
49
|
+
# @return [String] abbreviation for the targeted browser (e.g., IE, FF, GC)
|
50
|
+
attr_accessor :browser_abbrev
|
51
|
+
attr_accessor :version, :env,
|
48
52
|
:library, :script_type, :script_file,
|
49
53
|
:log_properties, :log_queue, :log_class,
|
50
54
|
:notify_queue, :notify_class, :notify_id,
|
@@ -160,6 +164,7 @@ module Awetestlib
|
|
160
164
|
options.each_pair do |k, v|
|
161
165
|
self.send("#{k}=", v)
|
162
166
|
end
|
167
|
+
script_file = options[:script_file]
|
163
168
|
load script_file
|
164
169
|
setup_global_test_vars(options)
|
165
170
|
|
@@ -275,9 +280,10 @@ module Awetestlib
|
|
275
280
|
end
|
276
281
|
|
277
282
|
def after_run
|
283
|
+
finish_run
|
278
284
|
@report_class.finish_report(@html_report_file)
|
279
285
|
open_report_file
|
280
|
-
finish_run
|
286
|
+
#finish_run
|
281
287
|
@myLog.close if @myLog
|
282
288
|
end
|
283
289
|
|
@@ -2,19 +2,44 @@ module Awetestlib
|
|
2
2
|
module Regression
|
3
3
|
module Tables
|
4
4
|
|
5
|
-
def get_index_for_column_head(panel, table_index, strg)
|
5
|
+
def get_index_for_column_head(panel, table_index, strg, desc = '')
|
6
|
+
table = panel.tables[table_index]
|
7
|
+
get_column_index(table, strg, desc, true)
|
8
|
+
end
|
9
|
+
|
10
|
+
def get_column_index(table, strg, desc = '', header = false)
|
11
|
+
msg = "Get index of "
|
12
|
+
msg << " header" if header
|
13
|
+
msg << " column containing #{strg}. "
|
14
|
+
msg << " #{desc}" if desc.length > 0
|
6
15
|
rgx = Regexp.new(strg)
|
7
|
-
|
16
|
+
row_idx = 0
|
17
|
+
index = -1
|
18
|
+
found = false
|
19
|
+
table.each do |row|
|
20
|
+
row_idx += 1
|
8
21
|
if row.text =~ rgx
|
9
|
-
|
22
|
+
col_idx = 1
|
10
23
|
row.each do |cell|
|
11
24
|
if cell.text =~ rgx
|
12
|
-
|
25
|
+
index = col_idx
|
26
|
+
found = true
|
27
|
+
break
|
13
28
|
end
|
14
|
-
|
29
|
+
col_idx += 1
|
15
30
|
end
|
16
31
|
end
|
32
|
+
break if found or header
|
33
|
+
end
|
34
|
+
if found
|
35
|
+
passed_to_log("#{msg} at index #{index}.")
|
36
|
+
index
|
37
|
+
else
|
38
|
+
failed_to_log("#{msg}")
|
39
|
+
nil
|
17
40
|
end
|
41
|
+
rescue
|
42
|
+
failed_to_log("Unable to #{msg} '#{$!}'")
|
18
43
|
end
|
19
44
|
|
20
45
|
def get_index_of_last_row(table, pad = 2, every = 1)
|