PageRenderTime 38ms CodeModel.GetById 11ms RepoModel.GetById 0ms app.codeStats 0ms

/third_party/WebKit/Tools/Scripts/webkitpy/layout_tests/controllers/manager_unittest.py

https://gitlab.com/jonnialva90/iridium-browser
Python | 176 lines | 120 code | 27 blank | 29 comment | 3 complexity | 35b2a130c4b97ea8e6f192d1466202f6 MD5 | raw file
  1. # Copyright (C) 2010 Google Inc. All rights reserved.
  2. # Copyright (C) 2010 Gabor Rapcsanyi (rgabor@inf.u-szeged.hu), University of Szeged
  3. #
  4. # Redistribution and use in source and binary forms, with or without
  5. # modification, are permitted provided that the following conditions are
  6. # met:
  7. #
  8. # * Redistributions of source code must retain the above copyright
  9. # notice, this list of conditions and the following disclaimer.
  10. # * Redistributions in binary form must reproduce the above
  11. # copyright notice, this list of conditions and the following disclaimer
  12. # in the documentation and/or other materials provided with the
  13. # distribution.
  14. # * Neither the name of Google Inc. nor the names of its
  15. # contributors may be used to endorse or promote products derived from
  16. # this software without specific prior written permission.
  17. #
  18. # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  19. # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  20. # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  21. # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  22. # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  23. # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  24. # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  25. # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  26. # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  27. # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  28. # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  29. """Unit tests for manager.py."""
  30. import sys
  31. import time
  32. import unittest
  33. from webkitpy.common.host_mock import MockHost
  34. from webkitpy.layout_tests.controllers.manager import Manager
  35. from webkitpy.layout_tests.models import test_expectations
  36. from webkitpy.layout_tests.models.test_run_results import TestRunResults
  37. from webkitpy.tool.mocktool import MockOptions
  38. class FakePrinter(object):
  39. def write_update(self, s):
  40. pass
  41. class ManagerTest(unittest.TestCase):
  42. def test_needs_servers(self):
  43. def get_manager():
  44. host = MockHost()
  45. port = host.port_factory.get('test-mac-leopard')
  46. manager = Manager(port, options=MockOptions(http=True, max_locked_shards=1), printer=FakePrinter())
  47. return manager
  48. manager = get_manager()
  49. self.assertFalse(manager.needs_servers(['fast/html']))
  50. manager = get_manager()
  51. self.assertTrue(manager.needs_servers(['http/tests/misc']))
  52. def test_servers_started(self):
  53. def get_manager(port):
  54. manager = Manager(port, options=MockOptions(http=True, max_locked_shards=1), printer=FakePrinter())
  55. return manager
  56. def start_http_server(additional_dirs, number_of_drivers):
  57. self.http_started = True
  58. def start_websocket_server():
  59. self.websocket_started = True
  60. def stop_http_server():
  61. self.http_stopped = True
  62. def stop_websocket_server():
  63. self.websocket_stopped = True
  64. host = MockHost()
  65. port = host.port_factory.get('test-mac-leopard')
  66. port.start_http_server = start_http_server
  67. port.start_websocket_server = start_websocket_server
  68. port.stop_http_server = stop_http_server
  69. port.stop_websocket_server = stop_websocket_server
  70. self.http_started = self.http_stopped = self.websocket_started = self.websocket_stopped = False
  71. manager = get_manager(port)
  72. manager._start_servers(['http/tests/foo.html'])
  73. self.assertEqual(self.http_started, True)
  74. self.assertEqual(self.websocket_started, False)
  75. manager._stop_servers()
  76. self.assertEqual(self.http_stopped, True)
  77. self.assertEqual(self.websocket_stopped, False)
  78. self.http_started = self.http_stopped = self.websocket_started = self.websocket_stopped = False
  79. manager._start_servers(['http/tests/websocket/foo.html'])
  80. self.assertEqual(self.http_started, True)
  81. self.assertEqual(self.websocket_started, True)
  82. manager._stop_servers()
  83. self.assertEqual(self.http_stopped, True)
  84. self.assertEqual(self.websocket_stopped, True)
  85. self.http_started = self.http_stopped = self.websocket_started = self.websocket_stopped = False
  86. manager._start_servers(['fast/html/foo.html'])
  87. self.assertEqual(self.http_started, False)
  88. self.assertEqual(self.websocket_started, False)
  89. manager._stop_servers()
  90. self.assertEqual(self.http_stopped, False)
  91. self.assertEqual(self.websocket_stopped, False)
  92. def test_look_for_new_crash_logs(self):
  93. def get_manager():
  94. host = MockHost()
  95. port = host.port_factory.get('test-mac-leopard')
  96. manager = Manager(port, options=MockOptions(test_list=None, http=True, max_locked_shards=1), printer=FakePrinter())
  97. return manager
  98. host = MockHost()
  99. port = host.port_factory.get('test-mac-leopard')
  100. tests = ['failures/expected/crash.html']
  101. expectations = test_expectations.TestExpectations(port, tests)
  102. run_results = TestRunResults(expectations, len(tests))
  103. manager = get_manager()
  104. manager._look_for_new_crash_logs(run_results, time.time())
  105. def _make_fake_test_result(self, host, results_directory):
  106. host.filesystem.maybe_make_directory(results_directory)
  107. host.filesystem.write_binary_file(results_directory + '/results.html', 'This is a test results file')
  108. def test_rename_results_folder(self):
  109. host = MockHost()
  110. port = host.port_factory.get('test-mac-leopard')
  111. def get_manager():
  112. manager = Manager(port, options=MockOptions(max_locked_shards=1), printer=FakePrinter())
  113. return manager
  114. self._make_fake_test_result(port.host, '/tmp/layout-test-results')
  115. self.assertTrue(port.host.filesystem.exists('/tmp/layout-test-results'))
  116. timestamp = time.strftime("%Y-%m-%d-%H-%M-%S", time.localtime(port.host.filesystem.mtime('/tmp/layout-test-results/results.html')))
  117. archived_file_name = '/tmp/layout-test-results' + '_' + timestamp
  118. manager = get_manager()
  119. manager._rename_results_folder()
  120. self.assertFalse(port.host.filesystem.exists('/tmp/layout-test-results'))
  121. self.assertTrue(port.host.filesystem.exists(archived_file_name))
  122. def test_clobber_old_results(self):
  123. host = MockHost()
  124. port = host.port_factory.get('test-mac-leopard')
  125. def get_manager():
  126. manager = Manager(port, options=MockOptions(max_locked_shards=1), printer=FakePrinter())
  127. return manager
  128. self._make_fake_test_result(port.host, '/tmp/layout-test-results')
  129. self.assertTrue(port.host.filesystem.exists('/tmp/layout-test-results'))
  130. manager = get_manager()
  131. manager._clobber_old_results()
  132. self.assertFalse(port.host.filesystem.exists('/tmp/layout-test-results'))
  133. def test_limit_archived_results_count(self):
  134. host = MockHost()
  135. port = host.port_factory.get('test-mac-leopard')
  136. def get_manager():
  137. manager = Manager(port, options=MockOptions(max_locked_shards=1), printer=FakePrinter())
  138. return manager
  139. for x in range(1, 31):
  140. dir_name = '/tmp/layout-test-results' + '_' + str(x)
  141. self._make_fake_test_result(port.host, dir_name)
  142. manager = get_manager()
  143. manager._limit_archived_results_count()
  144. deleted_dir_count = 0
  145. for x in range(1, 31):
  146. dir_name = '/tmp/layout-test-results' + '_' + str(x)
  147. if not port.host.filesystem.exists(dir_name):
  148. deleted_dir_count = deleted_dir_count + 1
  149. self.assertEqual(deleted_dir_count, 5)