| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include <fcntl.h> | 5 #include <fcntl.h> |
| 6 #include <stdlib.h> | 6 #include <stdlib.h> |
| 7 #include <sys/file.h> | 7 #include <sys/file.h> |
| 8 #include <sys/stat.h> // mkdir | 8 #include <sys/stat.h> // mkdir |
| 9 #include <sys/types.h> // | 9 #include <sys/types.h> // |
| 10 #include <stdio.h> // perror | 10 #include <stdio.h> // perror |
| 11 #include <time.h> | 11 #include <time.h> |
| 12 | 12 |
| 13 #include <fstream> | 13 #include <fstream> |
| 14 | 14 |
| 15 #include "base/base_paths.h" | 15 #include "base/base_paths.h" |
| 16 #include "base/bind.h" | 16 #include "base/bind.h" |
| 17 #include "base/files/file.h" | 17 #include "base/files/file.h" |
| 18 #include "base/files/file_util.h" | 18 #include "base/files/file_util.h" |
| 19 #include "base/memory/scoped_ptr.h" | 19 #include "base/memory/scoped_ptr.h" |
| 20 #include "base/memory/scoped_vector.h" | 20 #include "base/memory/scoped_vector.h" |
| 21 #include "base/process/launch.h" | 21 #include "base/process/launch.h" |
| 22 #include "base/test/scoped_path_override.h" | 22 #include "base/test/scoped_path_override.h" |
| 23 #include "base/threading/platform_thread.h" | 23 #include "base/threading/platform_thread.h" |
| 24 #include "base/threading/thread.h" | 24 #include "base/threading/thread.h" |
| 25 #include "chromecast/base/serializers.h" | 25 #include "chromecast/crash/linux/crash_testing_utils.h" |
| 26 #include "chromecast/crash/linux/dump_info.h" | 26 #include "chromecast/crash/linux/dump_info.h" |
| 27 #include "chromecast/crash/linux/synchronized_minidump_manager.h" | 27 #include "chromecast/crash/linux/synchronized_minidump_manager.h" |
| 28 #include "testing/gtest/include/gtest/gtest.h" | 28 #include "testing/gtest/include/gtest/gtest.h" |
| 29 | 29 |
| 30 namespace chromecast { | 30 namespace chromecast { |
| 31 namespace { | 31 namespace { |
| 32 | 32 |
| 33 const char kLockfileName[] = "lockfile"; | 33 const char kLockfileName[] = "lockfile"; |
| 34 const char kMinidumpSubdir[] = "minidumps"; | 34 const char kMinidumpSubdir[] = "minidumps"; |
| 35 const char kDumpsKey[] = "dumps"; | |
| 36 | 35 |
| 37 // A trivial implementation of SynchronizedMinidumpManager, which does no work | 36 // A trivial implementation of SynchronizedMinidumpManager, which does no work |
| 38 // to the | 37 // to the |
| 39 // minidump and exposes its protected members for testing. | 38 // minidump and exposes its protected members for testing. |
| 40 class SynchronizedMinidumpManagerSimple : public SynchronizedMinidumpManager { | 39 class SynchronizedMinidumpManagerSimple : public SynchronizedMinidumpManager { |
| 41 public: | 40 public: |
| 42 SynchronizedMinidumpManagerSimple() | 41 SynchronizedMinidumpManagerSimple() |
| 43 : SynchronizedMinidumpManager(), | 42 : SynchronizedMinidumpManager(), |
| 44 work_done_(false), | 43 work_done_(false), |
| 45 add_entry_return_code_(-1), | 44 add_entry_return_code_(-1), |
| (...skipping 20 matching lines...) Expand all Loading... |
| 66 bool work_done() { return work_done_; } | 65 bool work_done() { return work_done_; } |
| 67 int add_entry_return_code() { return add_entry_return_code_; } | 66 int add_entry_return_code() { return add_entry_return_code_; } |
| 68 | 67 |
| 69 private: | 68 private: |
| 70 bool work_done_; | 69 bool work_done_; |
| 71 int add_entry_return_code_; | 70 int add_entry_return_code_; |
| 72 std::string lockfile_path_; | 71 std::string lockfile_path_; |
| 73 scoped_ptr<DumpInfo> dump_info_; | 72 scoped_ptr<DumpInfo> dump_info_; |
| 74 }; | 73 }; |
| 75 | 74 |
| 76 bool FetchDumps(const std::string& lockfile_path, | |
| 77 ScopedVector<DumpInfo>* dumps) { | |
| 78 if (!dumps) { | |
| 79 return false; | |
| 80 } | |
| 81 dumps->clear(); | |
| 82 | |
| 83 base::FilePath path(lockfile_path); | |
| 84 scoped_ptr<base::Value> contents(DeserializeJsonFromFile(path)); | |
| 85 | |
| 86 base::DictionaryValue* dict; | |
| 87 base::ListValue* dump_list; | |
| 88 if (!contents || !contents->GetAsDictionary(&dict) || | |
| 89 !dict->GetList(kDumpsKey, &dump_list) || !dump_list) { | |
| 90 return false; | |
| 91 } | |
| 92 | |
| 93 for (base::Value* elem : *dump_list) { | |
| 94 scoped_ptr<DumpInfo> dump = make_scoped_ptr(new DumpInfo(elem)); | |
| 95 if (!dump->valid()) { | |
| 96 return false; | |
| 97 } | |
| 98 dumps->push_back(dump.Pass()); | |
| 99 } | |
| 100 | |
| 101 return true; | |
| 102 } | |
| 103 | |
| 104 bool CreateLockFile(const std::string& lockfile_path) { | |
| 105 scoped_ptr<base::DictionaryValue> output = | |
| 106 make_scoped_ptr(new base::DictionaryValue()); | |
| 107 output->Set("dumps", make_scoped_ptr(new base::ListValue())); | |
| 108 | |
| 109 base::FilePath path(lockfile_path); | |
| 110 | |
| 111 const base::Value* val = output.get(); | |
| 112 return SerializeJsonToFile(path, *val); | |
| 113 } | |
| 114 | |
| 115 void DoWorkLockedTask(SynchronizedMinidumpManagerSimple* manager) { | 75 void DoWorkLockedTask(SynchronizedMinidumpManagerSimple* manager) { |
| 116 manager->DoWorkLocked(); | 76 manager->DoWorkLocked(); |
| 117 } | 77 } |
| 118 | 78 |
| 119 class SleepySynchronizedMinidumpManagerSimple | 79 class SleepySynchronizedMinidumpManagerSimple |
| 120 : public SynchronizedMinidumpManagerSimple { | 80 : public SynchronizedMinidumpManagerSimple { |
| 121 public: | 81 public: |
| 122 SleepySynchronizedMinidumpManagerSimple(int sleep_duration_ms) | 82 SleepySynchronizedMinidumpManagerSimple(int sleep_duration_ms) |
| 123 : SynchronizedMinidumpManagerSimple(), | 83 : SynchronizedMinidumpManagerSimple(), |
| 124 sleep_duration_ms_(sleep_duration_ms) {} | 84 sleep_duration_ms_(sleep_duration_ms) {} |
| (...skipping 289 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 414 EXPECT_EQ(0, manager.add_entry_return_code()); | 374 EXPECT_EQ(0, manager.add_entry_return_code()); |
| 415 EXPECT_TRUE(manager.work_done()); | 375 EXPECT_TRUE(manager.work_done()); |
| 416 | 376 |
| 417 // Test that both entries were logged. | 377 // Test that both entries were logged. |
| 418 ScopedVector<DumpInfo> dumps; | 378 ScopedVector<DumpInfo> dumps; |
| 419 ASSERT_TRUE(FetchDumps(lockfile_.value(), &dumps)); | 379 ASSERT_TRUE(FetchDumps(lockfile_.value(), &dumps)); |
| 420 EXPECT_EQ(2u, dumps.size()); | 380 EXPECT_EQ(2u, dumps.size()); |
| 421 } | 381 } |
| 422 | 382 |
| 423 } // namespace chromecast | 383 } // namespace chromecast |
| OLD | NEW |