testability-driver 1.0.3 → 1.0.4
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/lib/tdriver-devtools/behaviour/xml/rdoc_behaviour_xml_generator.rb +2 -2
- data/lib/tdriver-devtools/tdriver-devtools.rb +1 -1
- data/lib/tdriver-devtools/tests/feature_tests/lib/custom_rdoc_generator.rb +3 -3
- data/lib/tdriver/base/behaviour/behaviours/object_behaviour_composition.rb +6 -1
- data/lib/tdriver/base/behaviour/behaviours/object_behaviour_description.rb +5 -3
- data/lib/tdriver/base/behaviour/behaviours/object_composition.rb +1 -1
- data/lib/tdriver/base/behaviour/factory.rb +225 -225
- data/lib/tdriver/base/errors.rb +1 -1
- data/lib/tdriver/base/state_object.rb +227 -179
- data/lib/tdriver/base/sut/controller.rb +2 -2
- data/lib/tdriver/base/sut/factory.rb +190 -182
- data/lib/tdriver/base/sut/generic/behaviours/application.rb +69 -25
- data/lib/tdriver/base/sut/generic/behaviours/controller.rb +1 -1
- data/lib/tdriver/base/sut/generic/behaviours/find.rb +4 -4
- data/lib/tdriver/base/sut/generic/behaviours/flash_behaviour.rb +3 -3
- data/lib/tdriver/base/sut/generic/behaviours/sut.rb +350 -165
- data/lib/tdriver/base/sut/generic/behaviours/switchbox_behaviour.rb +9 -9
- data/lib/tdriver/base/sut/generic/behaviours/verification.rb +191 -103
- data/lib/tdriver/base/sut/generic/commands/application.rb +1 -1
- data/lib/tdriver/base/sut/generic/commands/key_sequence.rb +1 -1
- data/lib/tdriver/base/sut/generic/commands/screen_capture.rb +1 -1
- data/lib/tdriver/base/sut/generic/plugin.rb +1 -1
- data/lib/tdriver/base/sut/sut.rb +5 -1
- data/lib/tdriver/base/test_object/abstract.rb +136 -151
- data/lib/tdriver/base/test_object/adapter.rb +293 -82
- data/lib/tdriver/base/test_object/behaviours/syncronization.rb +20 -17
- data/lib/tdriver/base/test_object/behaviours/test_object.rb +159 -532
- data/lib/tdriver/base/test_object/cache.rb +1 -1
- data/lib/tdriver/base/test_object/factory.rb +254 -605
- data/lib/tdriver/base/test_object/identificator.rb +1 -1
- data/lib/tdriver/base/test_object/loader.rb +1 -1
- data/lib/tdriver/base/test_object/verification.rb +17 -17
- data/lib/tdriver/loader.rb +20 -9
- data/lib/tdriver/report/report.rb +5 -0
- data/lib/tdriver/report/report_creator.rb +2 -2
- data/lib/tdriver/report/report_cucumber_listener.rb +4 -4
- data/lib/tdriver/report/report_cucumber_reporter.rb +4 -4
- data/lib/tdriver/report/report_execution_statistics.rb +22 -22
- data/lib/tdriver/report/report_grouping.rb +2 -2
- data/lib/tdriver/report/report_javascript.rb +11 -4
- data/lib/tdriver/report/report_test_case_run.rb +2 -2
- data/lib/tdriver/report/report_test_run.rb +5 -5
- data/lib/tdriver/report/report_test_unit.rb +74 -26
- data/lib/tdriver/report/report_writer.rb +70 -13
- data/lib/tdriver/tdriver.rb +17 -8
- data/lib/tdriver/util/common/array.rb +1 -1
- data/lib/tdriver/util/common/crc16.rb +1 -1
- data/lib/tdriver/util/common/environment.rb +1 -1
- data/lib/tdriver/util/common/file.rb +18 -9
- data/lib/tdriver/util/common/gem.rb +1 -1
- data/lib/tdriver/util/common/hash.rb +21 -0
- data/lib/tdriver/util/common/kernel.rb +1 -1
- data/lib/tdriver/util/common/loader.rb +5 -2
- data/lib/tdriver/util/common/numeric.rb +54 -3
- data/lib/tdriver/util/common/retryable.rb +30 -12
- data/lib/tdriver/util/common/stackable.rb +185 -0
- data/lib/tdriver/util/common/string.rb +21 -5
- data/lib/tdriver/util/{dbaccess/dbaccess.rb → database/access.rb} +4 -1
- data/lib/tdriver/util/{dbaccess/dbconnection.rb → database/connection.rb} +3 -0
- data/lib/tdriver/util/{dbaccess → database}/error.rb +0 -1
- data/lib/tdriver/util/{dbaccess → database}/loader.rb +5 -6
- data/lib/tdriver/util/{dynamic_attribute_filter.rb → filters/dynamic_attributes.rb} +1 -1
- data/lib/tdriver/util/hooking/hooking.rb +477 -0
- data/lib/tdriver/util/loader.rb +35 -29
- data/lib/tdriver/util/localisation/error.rb +0 -1
- data/lib/tdriver/util/localisation/loader.rb +1 -4
- data/lib/tdriver/util/localisation/localisation.rb +30 -27
- data/lib/tdriver/util/{common.rb → logger/loader.rb} +2 -4
- data/lib/tdriver/util/logger/logger.rb +574 -0
- data/lib/tdriver/util/operator_data/loader.rb +4 -3
- data/lib/tdriver/util/operator_data/operator_data.rb +5 -5
- data/lib/tdriver/util/parameter/parameter.rb +7 -1
- data/lib/tdriver/util/parameter/parameter_hash.rb +1 -1
- data/lib/tdriver/util/parameter/parameter_template.rb +1 -1
- data/lib/tdriver/util/parameter/parameter_user_api.rb +28 -20
- data/lib/tdriver/util/parameter/parameter_xml.rb +1 -1
- data/lib/tdriver/util/plugin/abstract.rb +1 -1
- data/lib/tdriver/util/plugin/service.rb +1 -1
- data/lib/tdriver/util/{localisation.rb → recorder/loader.rb} +4 -3
- data/lib/tdriver/util/recorder/recorder.rb +66 -0
- data/lib/tdriver/util/recorder/scripter.rb +258 -0
- data/lib/tdriver/util/{stats.rb → statistics/statistics.rb} +7 -8
- data/lib/tdriver/util/user_data/error.rb +0 -1
- data/lib/tdriver/util/user_data/loader.rb +1 -2
- data/lib/tdriver/util/user_data/user_data.rb +6 -6
- data/lib/tdriver/util/video/camera.rb +67 -0
- data/lib/tdriver/util/video/camera_linux.rb +139 -0
- data/lib/tdriver/util/video/camera_windows.rb +174 -0
- data/lib/tdriver/util/video/loader.rb +31 -0
- data/lib/tdriver/util/video/video_utils.rb +139 -0
- data/lib/tdriver/util/xml/abstraction.rb +56 -5
- data/lib/tdriver/util/xml/builder.rb +2 -5
- data/lib/tdriver/util/{parameter.rb → xml/comment.rb} +10 -2
- data/lib/tdriver/util/xml/loader.rb +32 -22
- data/lib/tdriver/util/xml/nil_node.rb +2 -2
- data/lib/tdriver/util/xml/parsers/loader.rb +0 -1
- data/lib/tdriver/util/xml/parsers/nokogiri/abstraction.rb +18 -44
- data/lib/tdriver/util/xml/parsers/nokogiri/attribute.rb +9 -13
- data/lib/tdriver/util/xml/parsers/nokogiri/builder.rb +9 -3
- data/lib/tdriver/util/xml/parsers/nokogiri/comment.rb +39 -0
- data/lib/tdriver/util/xml/parsers/nokogiri/document.rb +6 -11
- data/lib/tdriver/util/xml/parsers/nokogiri/element.rb +2 -122
- data/lib/tdriver/util/xml/parsers/nokogiri/loader.rb +26 -16
- data/lib/tdriver/util/xml/parsers/nokogiri/node.rb +203 -0
- data/lib/tdriver/util/xml/parsers/nokogiri/nodeset.rb +1 -2
- data/lib/tdriver/util/xml/parsers/nokogiri/text.rb +2 -20
- data/lib/tdriver/util/xml/xml.rb +52 -20
- data/lib/tdriver/verify/verify.rb +238 -81
- data/xml/behaviours/generic.xml +12 -10
- metadata +156 -180
- data/lib/tdriver/base/test_object/factory_new.rb +0 -202
- data/lib/tdriver/util/hooking.rb +0 -434
- data/lib/tdriver/util/logger.rb +0 -506
- data/lib/tdriver/util/recorder.rb +0 -297
- data/lib/tdriver/util/video_utils.rb +0 -384
- data/lib/tdriver/util/xml/nil_element.rb +0 -89
|
@@ -17,13 +17,6 @@
|
|
|
17
17
|
##
|
|
18
18
|
############################################################################
|
|
19
19
|
|
|
20
|
-
|
|
21
|
-
require 'rubygems'
|
|
22
|
-
require 'net/http'
|
|
23
|
-
require 'socket'
|
|
24
|
-
require 'uri'
|
|
25
|
-
require 'date'
|
|
26
|
-
|
|
27
20
|
# Utility for storing statistics regarding TDriver usage
|
|
28
21
|
#
|
|
29
22
|
#
|
|
@@ -50,6 +43,12 @@ module MobyUtil
|
|
|
50
43
|
|
|
51
44
|
return nil if defined?( $_TDRIVER_DISABLE_STATS_REPORTING )
|
|
52
45
|
|
|
46
|
+
require 'rubygems'
|
|
47
|
+
require 'uri'
|
|
48
|
+
require 'socket'
|
|
49
|
+
require 'net/http'
|
|
50
|
+
require 'date'
|
|
51
|
+
|
|
53
52
|
report_thread = Thread.new{
|
|
54
53
|
|
|
55
54
|
begin
|
|
@@ -83,7 +82,7 @@ module MobyUtil
|
|
|
83
82
|
|
|
84
83
|
end
|
|
85
84
|
|
|
86
|
-
|
|
85
|
+
TDriver::Hooking.hook_methods( self ) if defined?( TDriver::Hooking )
|
|
87
86
|
|
|
88
87
|
end # Stats
|
|
89
88
|
|
|
@@ -17,10 +17,9 @@
|
|
|
17
17
|
##
|
|
18
18
|
############################################################################
|
|
19
19
|
|
|
20
|
-
|
|
21
20
|
# user data inputs related errors
|
|
22
21
|
require File.expand_path( File.join( File.dirname( __FILE__ ), 'error.rb' ) )
|
|
23
22
|
|
|
24
|
-
# user data inputs
|
|
23
|
+
# user data inputs module implementation
|
|
25
24
|
require File.expand_path( File.join( File.dirname( __FILE__ ), 'user_data.rb' ) )
|
|
26
25
|
|
|
@@ -64,12 +64,12 @@ module MobyUtil
|
|
|
64
64
|
Kernel::raise UserDataNotFoundError.new( "User data logical name can't be empty" ) if user_data_lname == nil
|
|
65
65
|
|
|
66
66
|
# Get Localization parameters for DB Connection
|
|
67
|
-
db_type =
|
|
68
|
-
host =
|
|
69
|
-
username =
|
|
70
|
-
password =
|
|
71
|
-
database_name =
|
|
72
|
-
table_name =
|
|
67
|
+
db_type = $parameters[ :user_data_db_type, nil ].to_s.downcase
|
|
68
|
+
host = $parameters[ :user_data_server_ip ]
|
|
69
|
+
username = $parameters[ :user_data_server_username ]
|
|
70
|
+
password = $parameters[ :user_data_server_password ]
|
|
71
|
+
database_name = $parameters[ :user_data_server_database_name ]
|
|
72
|
+
table_name = $parameters[:user_data_server_database_tablename] if table_name.nil? or table_name.empty?
|
|
73
73
|
|
|
74
74
|
db_connection = DBConnection.new( db_type, host, database_name, username, password )
|
|
75
75
|
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
############################################################################
|
|
2
|
+
##
|
|
3
|
+
## Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
|
|
4
|
+
## All rights reserved.
|
|
5
|
+
## Contact: Nokia Corporation (testabilitydriver@nokia.com)
|
|
6
|
+
##
|
|
7
|
+
## This file is part of Testability Driver.
|
|
8
|
+
##
|
|
9
|
+
## If you have questions regarding the use of this file, please contact
|
|
10
|
+
## Nokia at testabilitydriver@nokia.com .
|
|
11
|
+
##
|
|
12
|
+
## This library is free software; you can redistribute it and/or
|
|
13
|
+
## modify it under the terms of the GNU Lesser General Public
|
|
14
|
+
## License version 2.1 as published by the Free Software Foundation
|
|
15
|
+
## and appearing in the file LICENSE.LGPL included in the packaging
|
|
16
|
+
## of this file.
|
|
17
|
+
##
|
|
18
|
+
############################################################################
|
|
19
|
+
|
|
20
|
+
module MobyUtil
|
|
21
|
+
|
|
22
|
+
# Base class and interface for camera recorders in TDriver
|
|
23
|
+
class TDriverCam
|
|
24
|
+
|
|
25
|
+
# Automatically select the right kind of camera implementation for the detected platform.
|
|
26
|
+
def self.new_cam( *args )
|
|
27
|
+
|
|
28
|
+
if EnvironmentHelper.windows?
|
|
29
|
+
|
|
30
|
+
MobyUtil::TDriverWinCam.new( *args )
|
|
31
|
+
|
|
32
|
+
elsif EnvironmentHelper.linux?
|
|
33
|
+
|
|
34
|
+
MobyUtil::TDriverLinuxCam.new( *args )
|
|
35
|
+
|
|
36
|
+
else
|
|
37
|
+
|
|
38
|
+
raise RuntimeError.new("Unidentified platform type, unable to select platform specific camera. Supported platform types: Linux, Windows.")
|
|
39
|
+
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
end
|
|
43
|
+
|
|
44
|
+
def initialize
|
|
45
|
+
|
|
46
|
+
raise RuntimeError.new("TDriverCam abstract class")
|
|
47
|
+
|
|
48
|
+
end
|
|
49
|
+
|
|
50
|
+
def start_recording
|
|
51
|
+
|
|
52
|
+
raise RuntimeError.new("TDriverCam abstract class")
|
|
53
|
+
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
def stop_recording
|
|
57
|
+
|
|
58
|
+
raise RuntimeError.new("TDriverCam abstract class")
|
|
59
|
+
|
|
60
|
+
end
|
|
61
|
+
|
|
62
|
+
# enable hooking for performance measurement & debug logging
|
|
63
|
+
TDriver::Hooking.hook_methods( self ) if defined?( TDriver::Hooking )
|
|
64
|
+
|
|
65
|
+
end # TDriverCam
|
|
66
|
+
|
|
67
|
+
end # MobyUtil
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
############################################################################
|
|
2
|
+
##
|
|
3
|
+
## Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
|
|
4
|
+
## All rights reserved.
|
|
5
|
+
## Contact: Nokia Corporation (testabilitydriver@nokia.com)
|
|
6
|
+
##
|
|
7
|
+
## This file is part of Testability Driver.
|
|
8
|
+
##
|
|
9
|
+
## If you have questions regarding the use of this file, please contact
|
|
10
|
+
## Nokia at testabilitydriver@nokia.com .
|
|
11
|
+
##
|
|
12
|
+
## This library is free software; you can redistribute it and/or
|
|
13
|
+
## modify it under the terms of the GNU Lesser General Public
|
|
14
|
+
## License version 2.1 as published by the Free Software Foundation
|
|
15
|
+
## and appearing in the file LICENSE.LGPL included in the packaging
|
|
16
|
+
## of this file.
|
|
17
|
+
##
|
|
18
|
+
############################################################################
|
|
19
|
+
|
|
20
|
+
module MobyUtil
|
|
21
|
+
|
|
22
|
+
# Linux streamer webcam implementation
|
|
23
|
+
# Requires that the streamer application is installed
|
|
24
|
+
class TDriverLinuxCam
|
|
25
|
+
|
|
26
|
+
STARTUP_TIMEOUT = 60
|
|
27
|
+
|
|
28
|
+
DEFAULT_OPTIONS = { :device => '/dev/video0', :width => 320, :height => 240, :fps => 5 }
|
|
29
|
+
|
|
30
|
+
# TODO: document me
|
|
31
|
+
def self.new_cam( *args )
|
|
32
|
+
|
|
33
|
+
MobyUtil::TDriverLinuxCam.new( *args )
|
|
34
|
+
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
# Creates a new recroding object witdh the given recording options
|
|
38
|
+
# === params
|
|
39
|
+
# video_file: String, path and name of file where the recorded video is stored
|
|
40
|
+
# user_options: (optional) Hash, keys :fps, :width, :height can be used to overwrite defaults
|
|
41
|
+
def initialize( video_file, user_options = {} )
|
|
42
|
+
|
|
43
|
+
@_device = nil
|
|
44
|
+
@_video_file = nil
|
|
45
|
+
@_recording = false
|
|
46
|
+
@_rec_options = nil
|
|
47
|
+
@_owcc_startex = nil
|
|
48
|
+
@_owcc_stop = nil
|
|
49
|
+
|
|
50
|
+
@_control_id = nil
|
|
51
|
+
@_video_file = video_file
|
|
52
|
+
@_rec_options = DEFAULT_OPTIONS.merge user_options
|
|
53
|
+
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
# Starts recording based on options given during initialization
|
|
57
|
+
# === raises
|
|
58
|
+
# RuntimeError: No filename has been defined or recording initialization failed due to timeout.
|
|
59
|
+
def start_recording
|
|
60
|
+
|
|
61
|
+
raise RuntimeError.new( "No video file defined, unable to start recording." ) if @_video_file.nil?
|
|
62
|
+
|
|
63
|
+
if File.exists?( @_video_file )
|
|
64
|
+
begin
|
|
65
|
+
File.delete( @_video_file )
|
|
66
|
+
rescue
|
|
67
|
+
# no reaction to failed file ops, unless recording fails
|
|
68
|
+
end
|
|
69
|
+
end
|
|
70
|
+
|
|
71
|
+
rec_command = 'streamer -q -c ' + @_rec_options[ :device ].to_s + ' -f rgb24 -r ' + @_rec_options[ :fps ].to_s + ' -t 99:00:00 -o ' + @_video_file.to_s + ' -s ' + @_rec_options[ :width ].to_s + 'x' + @_rec_options[ :height ].to_s
|
|
72
|
+
|
|
73
|
+
@_streamer_pid = fork do
|
|
74
|
+
begin
|
|
75
|
+
Kernel::exec( rec_command )
|
|
76
|
+
rescue Exception => e
|
|
77
|
+
raise RuntimeError.new( "An error was encountered while launching streamer:\n" << e.inspect )
|
|
78
|
+
end
|
|
79
|
+
end
|
|
80
|
+
|
|
81
|
+
file_timed_out = false
|
|
82
|
+
|
|
83
|
+
file_timeout = Time.now + STARTUP_TIMEOUT
|
|
84
|
+
|
|
85
|
+
while File.size?( @_video_file ).nil? && !file_timed_out do
|
|
86
|
+
|
|
87
|
+
#wait for recording to start, ie. filesize > 0
|
|
88
|
+
sleep 0.1
|
|
89
|
+
|
|
90
|
+
file_timed_out = true if Time.now > file_timeout
|
|
91
|
+
|
|
92
|
+
end
|
|
93
|
+
|
|
94
|
+
if file_timed_out
|
|
95
|
+
|
|
96
|
+
# make sure recording is not initializing, clean up any failed file
|
|
97
|
+
begin
|
|
98
|
+
Process.kill( 9, @_streamer_pid.to_i )
|
|
99
|
+
rescue
|
|
100
|
+
end
|
|
101
|
+
|
|
102
|
+
if File.exists?( @_video_file )
|
|
103
|
+
begin
|
|
104
|
+
File.delete( @_video_file )
|
|
105
|
+
rescue
|
|
106
|
+
end
|
|
107
|
+
end
|
|
108
|
+
|
|
109
|
+
raise RuntimeError.new( "Failed to start recording. Timeout: #{STARTUP_TIMEOUT} second(s). File: \"#{@_video_file}\" " )
|
|
110
|
+
|
|
111
|
+
end
|
|
112
|
+
|
|
113
|
+
@_recording = true
|
|
114
|
+
|
|
115
|
+
nil
|
|
116
|
+
|
|
117
|
+
end
|
|
118
|
+
|
|
119
|
+
# Stops ongoing recording
|
|
120
|
+
def stop_recording
|
|
121
|
+
|
|
122
|
+
if @_recording
|
|
123
|
+
|
|
124
|
+
@_recording = false
|
|
125
|
+
|
|
126
|
+
Process.kill( 9, @_streamer_pid.to_i )
|
|
127
|
+
|
|
128
|
+
end
|
|
129
|
+
|
|
130
|
+
nil
|
|
131
|
+
|
|
132
|
+
end
|
|
133
|
+
|
|
134
|
+
# enable hooking for performance measurement & debug logging
|
|
135
|
+
TDriver::Hooking.hook_methods( self ) if defined?( TDriver::Hooking )
|
|
136
|
+
|
|
137
|
+
end #TDriverLinuxCam
|
|
138
|
+
|
|
139
|
+
end # MobyUtil
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
############################################################################
|
|
2
|
+
##
|
|
3
|
+
## Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
|
|
4
|
+
## All rights reserved.
|
|
5
|
+
## Contact: Nokia Corporation (testabilitydriver@nokia.com)
|
|
6
|
+
##
|
|
7
|
+
## This file is part of Testability Driver.
|
|
8
|
+
##
|
|
9
|
+
## If you have questions regarding the use of this file, please contact
|
|
10
|
+
## Nokia at testabilitydriver@nokia.com .
|
|
11
|
+
##
|
|
12
|
+
## This library is free software; you can redistribute it and/or
|
|
13
|
+
## modify it under the terms of the GNU Lesser General Public
|
|
14
|
+
## License version 2.1 as published by the Free Software Foundation
|
|
15
|
+
## and appearing in the file LICENSE.LGPL included in the packaging
|
|
16
|
+
## of this file.
|
|
17
|
+
##
|
|
18
|
+
############################################################################
|
|
19
|
+
|
|
20
|
+
module MobyUtil
|
|
21
|
+
|
|
22
|
+
# Windows DirectShow webcam implementation
|
|
23
|
+
class TDriverWinCam
|
|
24
|
+
|
|
25
|
+
STARTUP_TIMEOUT = 60
|
|
26
|
+
|
|
27
|
+
DEFAULT_OPTIONS = { :device => nil, :width => 640, :height => 480, :fps => 30 }
|
|
28
|
+
|
|
29
|
+
# TODO: document me
|
|
30
|
+
def self.new_cam( *args )
|
|
31
|
+
|
|
32
|
+
MobyUtil::TDriverWinCam.new( *args )
|
|
33
|
+
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
# Creates a new recroding object witdh the given recording options
|
|
37
|
+
# === params
|
|
38
|
+
# video_file: String, path and name of file where the recorded video is stored
|
|
39
|
+
# user_options: (optional) Hash, keys :fps, :width, :height can be used to overwrite defaults
|
|
40
|
+
def initialize( video_file, user_options = {} )
|
|
41
|
+
|
|
42
|
+
@_device = nil
|
|
43
|
+
@_video_file = nil
|
|
44
|
+
@_recording = false
|
|
45
|
+
@_rec_options = nil
|
|
46
|
+
@_owcc_startex = nil
|
|
47
|
+
@_owcc_stop = nil
|
|
48
|
+
|
|
49
|
+
require 'Win32API'
|
|
50
|
+
|
|
51
|
+
begin
|
|
52
|
+
|
|
53
|
+
@_owcc_startex = Win32API.new( 'TDriverWebCamControl', 'OscarWebCamControlStartEx', [ 'P', 'N', 'N', 'N', 'L', 'L', 'L', 'I', 'I' ], 'L' )
|
|
54
|
+
@_owcc_stop = Win32API.new( 'TDriverWebCamControl', 'OscarWebCamControlStop', [ 'L' ], 'V' )
|
|
55
|
+
|
|
56
|
+
rescue Exception => e
|
|
57
|
+
|
|
58
|
+
begin
|
|
59
|
+
|
|
60
|
+
#OSCARWEBCAMCONTROL_API long OscarWebCamControlStartEx(char* captureFile, double compQuality, DWORD dwBitsPerSec, long lFramesPerSec, long lCapWidth, long lCapHeight, bool bFlipV, bool bFlipH)
|
|
61
|
+
@_owcc_startex = Win32API.new( 'OscarWebCamControl', 'OscarWebCamControlStartEx', [ 'P', 'N', 'N', 'N', 'L', 'L', 'L', 'I', 'I' ], 'L' )
|
|
62
|
+
#OSCARWEBCAMCONTROL_API void OscarWebCamControlStop(long pTargetMediaControl)
|
|
63
|
+
@_owcc_stop = Win32API.new( 'OscarWebCamControl', 'OscarWebCamControlStop', [ 'L' ], 'V' )
|
|
64
|
+
|
|
65
|
+
rescue Exception => ee
|
|
66
|
+
raise RuntimeError.new( "Failed to connect to video recording DLL file (TDriverWebCamControl.dll or OscarWebCamControl.dll). Details:\n" + ee.message )
|
|
67
|
+
end
|
|
68
|
+
|
|
69
|
+
end
|
|
70
|
+
|
|
71
|
+
if user_options.has_key? :device
|
|
72
|
+
|
|
73
|
+
puts "WARNING: TDriverWinCam does not support the :device option. This setting is ignored."
|
|
74
|
+
|
|
75
|
+
end
|
|
76
|
+
|
|
77
|
+
@_control_id = nil
|
|
78
|
+
@_video_file = video_file
|
|
79
|
+
@_rec_options = DEFAULT_OPTIONS.merge user_options
|
|
80
|
+
|
|
81
|
+
end
|
|
82
|
+
|
|
83
|
+
# Starts recording based on options given during initialization
|
|
84
|
+
# === raises
|
|
85
|
+
# RuntimeError: No filename has been defined or recording initialization failed due to timeout.
|
|
86
|
+
def start_recording
|
|
87
|
+
|
|
88
|
+
raise RuntimeError.new("No video file defined, unable to start recording.") if @_video_file.nil?
|
|
89
|
+
|
|
90
|
+
if File.exists?( @_video_file )
|
|
91
|
+
begin
|
|
92
|
+
File.delete( @_video_file )
|
|
93
|
+
rescue
|
|
94
|
+
# no reaction to failed file ops, unless recording fails
|
|
95
|
+
end
|
|
96
|
+
end
|
|
97
|
+
|
|
98
|
+
@_control_id = @_owcc_startex.call( @_video_file, 0, 0, 0, @_rec_options[ :fps ].to_i, @_rec_options[ :width ].to_i, @_rec_options[ :height ].to_i, 0, 0 )
|
|
99
|
+
|
|
100
|
+
if @_control_id == 0
|
|
101
|
+
|
|
102
|
+
Kernel::raise RuntimeError.new( "Failed to start video recording.\nFile: " + @_video_file + "\nFPS: " + @_rec_options[ :fps ].to_s + "\nWidth: " + @_rec_options[ :width ].to_s + "\nHeight: " + @_rec_options[ :height ].to_s )
|
|
103
|
+
|
|
104
|
+
end
|
|
105
|
+
|
|
106
|
+
file_timed_out = false
|
|
107
|
+
|
|
108
|
+
file_timeout = Time.now + STARTUP_TIMEOUT
|
|
109
|
+
|
|
110
|
+
while File.size?( @_video_file ).nil? && !file_timed_out do
|
|
111
|
+
|
|
112
|
+
#wait for recording to start, ie. filesize > 0
|
|
113
|
+
sleep 1
|
|
114
|
+
|
|
115
|
+
# force refresh file size
|
|
116
|
+
begin
|
|
117
|
+
|
|
118
|
+
if File.exists?( @_video_file )
|
|
119
|
+
File.open( @_video_file, 'r' ) do
|
|
120
|
+
end
|
|
121
|
+
end
|
|
122
|
+
|
|
123
|
+
rescue
|
|
124
|
+
|
|
125
|
+
end
|
|
126
|
+
|
|
127
|
+
if Time.now > file_timeout
|
|
128
|
+
file_timed_out = true
|
|
129
|
+
end
|
|
130
|
+
|
|
131
|
+
end
|
|
132
|
+
|
|
133
|
+
if file_timed_out
|
|
134
|
+
|
|
135
|
+
# make sure recording is not initializing, clean up any failed file
|
|
136
|
+
begin
|
|
137
|
+
@_owcc_stop.call( @_control_id )
|
|
138
|
+
rescue
|
|
139
|
+
end
|
|
140
|
+
|
|
141
|
+
if File.exists?( @_video_file )
|
|
142
|
+
begin
|
|
143
|
+
File.delete( @_video_file )
|
|
144
|
+
rescue
|
|
145
|
+
end
|
|
146
|
+
end
|
|
147
|
+
|
|
148
|
+
raise RuntimeError.new( "Failed to start recording. Timeout: #{STARTUP_TIMEOUT} File: \"#{@_video_file}\" " )
|
|
149
|
+
end
|
|
150
|
+
|
|
151
|
+
@_recording = true
|
|
152
|
+
|
|
153
|
+
nil
|
|
154
|
+
|
|
155
|
+
end
|
|
156
|
+
|
|
157
|
+
# Stops ongoing recording
|
|
158
|
+
def stop_recording
|
|
159
|
+
|
|
160
|
+
if @_recording
|
|
161
|
+
@_recording = false
|
|
162
|
+
@_owcc_stop.call( @_control_id )
|
|
163
|
+
end
|
|
164
|
+
|
|
165
|
+
nil
|
|
166
|
+
|
|
167
|
+
end
|
|
168
|
+
|
|
169
|
+
# enable hooking for performance measurement & debug logging
|
|
170
|
+
TDriver::Hooking.hook_methods( self ) if defined?( TDriver::Hooking )
|
|
171
|
+
|
|
172
|
+
end #TDriverWinCam
|
|
173
|
+
|
|
174
|
+
end # MobyUtil
|