Module: Repla::Test
- Defined in:
- lib/repla/test.rb,
lib/repla/test/lib/helper.rb,
lib/repla/test/lib/view_helper.rb,
lib/repla/logger/test/lib/log_helper.rb,
lib/repla/logger/test/lib/log_tester.rb
Overview
Test
Defined Under Namespace
Modules: Helper, ViewHelper Classes: LogHelper
Constant Summary collapse
- TEST_PAUSE_TIME =
General
2.00- TEST_TIMEOUT_TIME =
4.00- POLLING_INTERVAL =
0.5
- REPLA_FILE =
Ruby
File.join(__dir__, '../repla')
- TEST_DIRECTORY =
File.join(__dir__, 'test')
- LIB_DIRECTORY =
File.join(TEST_DIRECTORY, 'lib')
- HELPER_FILE =
File.join(LIB_DIRECTORY, 'helper')
- VIEW_HELPER_FILE =
File.join(LIB_DIRECTORY, 'view_helper')
- LOG_HELPER_FILE =
File.join(__dir__, 'logger/test/lib/log_helper')
- TEST_HTML_DIRECTORY =
HTML
File.join(TEST_DIRECTORY, 'html')
- INDEX_HTML_FILENAME =
'index.html'.freeze
- INDEXJQUERY_HTML_FILENAME =
'indexjquery.html'.freeze
- INDEX_HTML_FILE =
html_file(INDEX_HTML_FILENAME)
- INDEXJQUERY_HTML_FILE =
html_file(INDEXJQUERY_HTML_FILENAME)
- INDEX_HTML_TITLE =
'Index'.freeze
- INDEXJQUERY_HTML_TITLE =
'Index JQuery'.freeze
- TEST_ASSETS_JAVASCRIPT_DIRECTORY =
JavaScript
File.join(TEST_DIRECTORY, 'js')
- TITLE_JAVASCRIPT_FILE =
File.join(TEST_ASSETS_JAVASCRIPT_DIRECTORY, 'title.js')
- BODY_JAVASCRIPT_FILE =
File.join(TEST_ASSETS_JAVASCRIPT_DIRECTORY, 'body.js')
- TEST_PLUGIN_DIRECTORY =
Plugins
File.join(TEST_DIRECTORY, 'packages')
- TEST_HELLOWORLD_PLUGIN_FILE =
File.join(TEST_PLUGIN_DIRECTORY, 'HelloWorld.replaplugin')
- TEST_HELLOWORLD_PLUGIN_NAME =
'HelloWorld'.freeze
- TEST_SERVER_PLUGIN_NAME =
'TestServer'.freeze
- TEST_SERVER_PLUGIN_FILE =
File.join(TEST_PLUGIN_DIRECTORY, 'TestServer.replaplugin')
- INDEX_HTML_URL =
html_server_url(INDEX_HTML_FILENAME)
- INDEXJQUERY_HTML_URL =
html_server_url( INDEXJQUERY_HTML_FILENAME )
- NO_SERVER_URL =
'NoServer'.freeze
- PRINT_PLUGIN_FILE =
File.join(TEST_PLUGIN_DIRECTORY, 'Print.replaplugin')
- PRINT_PLUGIN_NAME =
'Print'.freeze
- TEST_LOG_PLUGIN_FILE =
File.join(TEST_PLUGIN_DIRECTORY, 'TestLog.replaplugin')
- TEST_LOG_PLUGIN_NAME =
'TestLog'.freeze
- INVALID_PLUGIN_FILE =
File.join(TEST_PLUGIN_DIRECTORY, 'Invalid.replaplugin')
- INVALID_PLUGIN_NAME =
'Invalid'.freeze
- TEST_ENVIRONMENT_PLUGIN_FILE =
File.join(TEST_PLUGIN_DIRECTORY, 'TestEnvironment.replaplugin')
- TEST_ENVIRONMENT_PLUGIN_NAME =
'TestEnvironment'.freeze
- TEST_JAVASCRIPT_DIRECTORY =
JavaScript
File.join(LIB_DIRECTORY, '../js')
- LASTCODE_JAVASCRIPT_FILE =
File.join(TEST_JAVASCRIPT_DIRECTORY, 'lastcode.js')
- FIRSTCODE_JAVASCRIPT_FILE =
File.join(TEST_JAVASCRIPT_DIRECTORY, 'firstcode.js')
- NODOM_JAVASCRIPT_FILE =
File.join(TEST_JAVASCRIPT_DIRECTORY, 'nodom.js')
- TEXT_JAVASCRIPT_FILE =
File.join(TEST_JAVASCRIPT_DIRECTORY, 'text.js')
- TEXTJQUERY_JAVASCRIPT_FILE =
File.join(TEST_JAVASCRIPT_DIRECTORY, 'textjquery.js')
- MESSAGES =
[ 'Testing log error', 'Testing log message', 'ERROR', 'MESSAGE', 'Done' ].freeze
- CLASSES =
%w[ error message message message message ].freeze
Class Method Summary collapse
- .block_until(&block) ⇒ Object
- .block_until_with_timeout(timeout) ⇒ Object
-
.html_file(filename) ⇒ Object
Test Assets.
- .html_server_url(filename) ⇒ Object
- .test_log(window) ⇒ Object
Class Method Details
.block_until(&block) ⇒ Object
36 37 38 |
# File 'lib/repla/test.rb', line 36 def self.block_until(&block) block_until_with_timeout(TEST_TIMEOUT_TIME, &block) end |
.block_until_with_timeout(timeout) ⇒ Object
27 28 29 30 31 32 33 34 |
# File 'lib/repla/test.rb', line 27 def self.block_until_with_timeout(timeout) cycles = [timeout / POLLING_INTERVAL, 1].max count = 0 until yield || count >= cycles sleep(POLLING_INTERVAL) count += 1 end end |
.html_file(filename) ⇒ Object
Test Assets
19 20 21 |
# File 'lib/repla/test.rb', line 19 def self.html_file(filename) File.join(TEST_HTML_DIRECTORY, filename) end |
.html_server_url(filename) ⇒ Object
23 24 25 |
# File 'lib/repla/test.rb', line 23 def self.html_server_url(filename) 'http://127.0.0.1:5000/' + filename end |
.test_log(window) ⇒ Object
18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/repla/logger/test/lib/log_tester.rb', line 18 def self.test_log(window) = 'Done' test_log_helper = Repla::Test::LogHelper.new(window.window_id) = nil Repla::Test.block_until do = test_log_helper. == end (0..MESSAGES.count).each do |i| result = test_log_helper.(i) = MESSAGES[i] if result != STDERR.puts "Expected #{message} instead of #{result}" return false end type = CLASSES[i] type_result = test_log_helper.log_class_at(i) if type_result != type STDERR.puts "Expected #{type_result} instead of #{type}" return false end end expected = MESSAGES.count result = test_log_helper. if expected != result STDERR.puts "Expected #{expected} instead of #{result}" return false end true end |