OLD | NEW |
1 # Copyright (C) 2011 Google Inc. All rights reserved. | 1 # Copyright (C) 2011 Google Inc. All rights reserved. |
2 # | 2 # |
3 # Redistribution and use in source and binary forms, with or without | 3 # Redistribution and use in source and binary forms, with or without |
4 # modification, are permitted provided that the following conditions | 4 # modification, are permitted provided that the following conditions |
5 # are met: | 5 # are met: |
6 # | 6 # |
7 # 1. Redistributions of source code must retain the above copyright | 7 # 1. Redistributions of source code must retain the above copyright |
8 # notice, this list of conditions and the following disclaimer. | 8 # notice, this list of conditions and the following disclaimer. |
9 # 2. Redistributions in binary form must reproduce the above copyright | 9 # 2. Redistributions in binary form must reproduce the above copyright |
10 # notice, this list of conditions and the following disclaimer in the | 10 # notice, this list of conditions and the following disclaimer in the |
11 # documentation and/or other materials provided with the distribution. | 11 # documentation and/or other materials provided with the distribution. |
12 # | 12 # |
13 # THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY | 13 # THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY |
14 # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | 14 # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
15 # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | 15 # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
16 # DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY | 16 # DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY |
17 # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | 17 # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
18 # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | 18 # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
19 # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | 19 # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
20 # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 20 # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
21 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | 21 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF |
22 # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 22 # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
23 | 23 |
24 import unittest | 24 import unittest |
25 | 25 |
26 from webkitpy.common.system.crashlogs import CrashLogs | 26 from webkitpy.common.system.crash_logs import CrashLogs |
27 from webkitpy.common.system.filesystem_mock import MockFileSystem | 27 from webkitpy.common.system.filesystem_mock import MockFileSystem |
28 from webkitpy.common.system.systemhost import SystemHost | 28 from webkitpy.common.system.system_host import SystemHost |
29 from webkitpy.common.system.systemhost_mock import MockSystemHost | 29 from webkitpy.common.system.system_host_mock import MockSystemHost |
30 | 30 |
31 | 31 |
32 def make_mock_crash_report_darwin(process_name, pid): | 32 def make_mock_crash_report_darwin(process_name, pid): |
33 return """Process: {process_name} [{pid}] | 33 return """Process: {process_name} [{pid}] |
34 Path: /Volumes/Data/slave/x-release-tests/build/WebKitBuild/Release/{
process_name} | 34 Path: /Volumes/Data/slave/x-release-tests/build/WebKitBuild/Release/{
process_name} |
35 Identifier: {process_name} | 35 Identifier: {process_name} |
36 Version: ??? (???) | 36 Version: ??? (???) |
37 Code Type: X86-64 (Native) | 37 Code Type: X86-64 (Native) |
38 Parent Process: Python [2578] | 38 Parent Process: Python [2578] |
39 | 39 |
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
96 self.assertMultiLineEqual(log, newer_mock_crash_report) | 96 self.assertMultiLineEqual(log, newer_mock_crash_report) |
97 log = crash_logs.find_newest_log("DumpRenderTree", 28529) | 97 log = crash_logs.find_newest_log("DumpRenderTree", 28529) |
98 self.assertMultiLineEqual(log, newer_mock_crash_report) | 98 self.assertMultiLineEqual(log, newer_mock_crash_report) |
99 log = crash_logs.find_newest_log("DumpRenderTree", 28530) | 99 log = crash_logs.find_newest_log("DumpRenderTree", 28530) |
100 self.assertMultiLineEqual(log, mock_crash_report) | 100 self.assertMultiLineEqual(log, mock_crash_report) |
101 log = crash_logs.find_newest_log("DumpRenderTree", 28531) | 101 log = crash_logs.find_newest_log("DumpRenderTree", 28531) |
102 self.assertIsNone(log) | 102 self.assertIsNone(log) |
103 log = crash_logs.find_newest_log("DumpRenderTree", newer_than=1.0) | 103 log = crash_logs.find_newest_log("DumpRenderTree", newer_than=1.0) |
104 self.assertIsNone(log) | 104 self.assertIsNone(log) |
105 | 105 |
106 def bad_read(path): | 106 def bad_read(_): |
107 raise IOError('IOError: No such file or directory') | 107 raise IOError('IOError: No such file or directory') |
108 | 108 |
109 def bad_mtime(path): | 109 def bad_mtime(_): |
110 raise OSError('OSError: No such file or directory') | 110 raise OSError('OSError: No such file or directory') |
111 | 111 |
112 filesystem.read_text_file = bad_read | 112 filesystem.read_text_file = bad_read |
113 log = crash_logs.find_newest_log("DumpRenderTree", 28531, include_errors
=True) | 113 log = crash_logs.find_newest_log("DumpRenderTree", 28531, include_errors
=True) |
114 self.assertIn('IOError: No such file or directory', log) | 114 self.assertIn('IOError: No such file or directory', log) |
115 | 115 |
116 filesystem = MockFileSystem(files) | 116 filesystem = MockFileSystem(files) |
117 crash_logs = CrashLogs(MockSystemHost(filesystem=filesystem)) | 117 crash_logs = CrashLogs(MockSystemHost(filesystem=filesystem)) |
118 filesystem.mtime = bad_mtime | 118 filesystem.mtime = bad_mtime |
119 log = crash_logs.find_newest_log("DumpRenderTree", newer_than=1.0, inclu
de_errors=True) | 119 log = crash_logs.find_newest_log("DumpRenderTree", newer_than=1.0, inclu
de_errors=True) |
120 self.assertIn('OSError: No such file or directory', log) | 120 self.assertIn('OSError: No such file or directory', log) |
OLD | NEW |