| OLD | NEW |
| 1 # Copyright (C) 2013 Google Inc. All rights reserved. | 1 # Copyright (C) 2013 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 are | 4 # modification, are permitted provided that the following conditions are |
| 5 # met: | 5 # met: |
| 6 # | 6 # |
| 7 # * Redistributions of source code must retain the above copyright | 7 # * 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 # * Redistributions in binary form must reproduce the above | 9 # * Redistributions in binary form must reproduce the above |
| 10 # copyright notice, this list of conditions and the following disclaimer | 10 # copyright notice, this list of conditions and the following disclaimer |
| (...skipping 12 matching lines...) Expand all Loading... |
| 23 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 23 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| 24 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 24 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| 25 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 25 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 26 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 26 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 27 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 27 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 28 | 28 |
| 29 import unittest | 29 import unittest |
| 30 | 30 |
| 31 import cgi | 31 import cgi |
| 32 | 32 |
| 33 from webkitpy.common.host import Host |
| 33 from webkitpy.common.host_mock import MockHost | 34 from webkitpy.common.host_mock import MockHost |
| 34 from webkitpy.common.system.executive_mock import MockExecutive | 35 from webkitpy.common.system.executive_mock import MockExecutive |
| 35 from webkitpy.layout_tests.breakpad.dump_reader_multipart import DumpReaderMulti
part | 36 from webkitpy.layout_tests.breakpad.dump_reader_multipart import DumpReaderMulti
part |
| 36 | 37 |
| 37 | 38 |
| 38 class TestDumpReaderMultipart(unittest.TestCase): | 39 class TestDumpReaderMultipart(unittest.TestCase): |
| 39 _MULTIPART_DUMP = [ | 40 _MULTIPART_DUMP = [ |
| 40 '--boundary', | 41 '--boundary', |
| 41 'Content-Disposition: form-data; name="prod"', | 42 'Content-Disposition: form-data; name="prod"', |
| 42 '', | 43 '', |
| 43 'content_shell', | 44 'content_shell', |
| 44 '--boundary', | 45 '--boundary', |
| 45 'Content-Disposition: form-data; name="pid"', | 46 'Content-Disposition: form-data; name="pid"', |
| 46 '', | 47 '', |
| 47 '4711', | 48 '4711', |
| 48 '--boundary', | 49 '--boundary', |
| 49 'Content-Disposition: form-data; name="upload_file_minidump"; filename="
dump"', | 50 'Content-Disposition: form-data; name="upload_file_minidump"; filename="
dump"', |
| 50 'Content-Type: application/octet-stream', | 51 'Content-Type: application/octet-stream', |
| 51 '', | 52 '', |
| 52 'MDMP', | 53 'MDMP', |
| 53 '--boundary--', | 54 '--boundary--', |
| 54 ] | 55 ] |
| 55 | 56 |
| 57 def test_check_generate_breakpad_symbols_actually_exists(self): |
| 58 host = Host() |
| 59 dump_reader = DumpReaderMultipart(host, build_dir=None) |
| 60 self.assertTrue(host.filesystem.exists(dump_reader._path_to_generate_bre
akpad_symbols())) |
| 61 |
| 56 def test_check_is_functional_breakpad_tools_not_found(self): | 62 def test_check_is_functional_breakpad_tools_not_found(self): |
| 57 host = MockHost() | 63 host = MockHost() |
| 58 | 64 |
| 59 build_dir = "/mock-checkout/out/Debug" | 65 build_dir = "/mock-checkout/out/Debug" |
| 60 host.filesystem.maybe_make_directory(build_dir) | 66 host.filesystem.maybe_make_directory(build_dir) |
| 61 dump_reader = DumpReaderMultipart(host, build_dir) | 67 dump_reader = DumpReaderMultipart(host, build_dir) |
| 62 dump_reader._file_extension = lambda: 'dmp' | 68 dump_reader._file_extension = lambda: 'dmp' |
| 63 dump_reader._binaries_to_symbolize = lambda: ['content_shell'] | 69 dump_reader._binaries_to_symbolize = lambda: ['content_shell'] |
| 64 | 70 |
| 65 self.assertFalse(dump_reader.check_is_functional()) | 71 self.assertFalse(dump_reader.check_is_functional()) |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 100 dump_reader._file_extension = lambda: 'dmp' | 106 dump_reader._file_extension = lambda: 'dmp' |
| 101 dump_reader._binaries_to_symbolize = lambda: ['content_shell'] | 107 dump_reader._binaries_to_symbolize = lambda: ['content_shell'] |
| 102 | 108 |
| 103 self.assertTrue(dump_reader.check_is_functional()) | 109 self.assertTrue(dump_reader.check_is_functional()) |
| 104 self.assertEqual("MOCK output of child process", dump_reader._get_stack_
from_dump(dump_file)) | 110 self.assertEqual("MOCK output of child process", dump_reader._get_stack_
from_dump(dump_file)) |
| 105 self.assertEqual(2, len(host.executive.calls)) | 111 self.assertEqual(2, len(host.executive.calls)) |
| 106 cmd_line = " ".join(host.executive.calls[0]) | 112 cmd_line = " ".join(host.executive.calls[0]) |
| 107 self.assertIn('generate_breakpad_symbols.py', cmd_line) | 113 self.assertIn('generate_breakpad_symbols.py', cmd_line) |
| 108 cmd_line = " ".join(host.executive.calls[1]) | 114 cmd_line = " ".join(host.executive.calls[1]) |
| 109 self.assertIn('minidump_stackwalk', cmd_line) | 115 self.assertIn('minidump_stackwalk', cmd_line) |
| OLD | NEW |