Chromium Code Reviews| Index: client/settings_test.cc |
| diff --git a/client/settings_test.cc b/client/settings_test.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..8470c9cde43bf3a3841abc2256aba50499bf42c6 |
| --- /dev/null |
| +++ b/client/settings_test.cc |
| @@ -0,0 +1,128 @@ |
| +// Copyright 2015 The Crashpad Authors. All rights reserved. |
| +// |
| +// Licensed under the Apache License, Version 2.0 (the "License"); |
| +// you may not use this file except in compliance with the License. |
| +// You may obtain a copy of the License at |
| +// |
| +// http://www.apache.org/licenses/LICENSE-2.0 |
| +// |
| +// Unless required by applicable law or agreed to in writing, software |
| +// distributed under the License is distributed on an "AS IS" BASIS, |
| +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| +// See the License for the specific language governing permissions and |
| +// limitations under the License. |
| + |
| +#include "client/settings.h" |
| + |
| +#include "client/crash_report_database.h" |
| +#include "gtest/gtest.h" |
| +#include "util/file/file_io.h" |
| +#include "util/test/scoped_temp_dir.h" |
| + |
| +namespace crashpad { |
| +namespace test { |
| +namespace { |
| + |
| +class SettingsTest : public testing::Test { |
| + public: |
| + SettingsTest() : settings_(settings_path()) {} |
| + |
| + base::FilePath settings_path() { |
| + return temp_dir_.path().Append("settings"); |
| + } |
| + |
| + Settings* settings() { return &settings_; } |
| + |
| + void InitializeBadFile() { |
|
Mark Mentovai
2015/03/09 19:12:36
Also have something that removes settings_path() t
Robert Sesek
2015/03/09 21:16:28
Done.
|
| + ScopedFileHandle handle( |
| + LoggingOpenFileForWrite(settings_path(), |
| + FileWriteMode::kTruncateOrCreate, |
| + FilePermissions::kWorldReadable)); |
| + ASSERT_TRUE(handle.is_valid()); |
| + |
| + const char kBuf[] = "test bad file"; |
| + ASSERT_TRUE(LoggingWriteFile(handle.get(), kBuf, sizeof(kBuf))); |
| + handle.reset(); |
| + } |
| + |
| + protected: |
| + // testing::Test: |
| + void SetUp() override { |
| + ASSERT_TRUE(settings()->Initialize()); |
| + } |
| + |
| + private: |
| + ScopedTempDir temp_dir_; |
| + Settings settings_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(SettingsTest); |
| +}; |
| + |
| +TEST_F(SettingsTest, ClientID) { |
| + UUID client_id; |
| + EXPECT_TRUE(settings()->GetClientID(&client_id)); |
| + EXPECT_NE(UUID(), client_id); |
| + |
| + Settings settings(settings_path()); |
| + UUID actual; |
| + EXPECT_TRUE(settings.GetClientID(&actual)); |
| + EXPECT_EQ(client_id, actual); |
| +} |
| + |
| +TEST_F(SettingsTest, UploadsEnabled) { |
| + bool enabled = true; |
| + // Default value is false. |
| + EXPECT_TRUE(settings()->GetUploadsEnabled(&enabled)); |
| + EXPECT_FALSE(enabled); |
| + |
| + EXPECT_TRUE(settings()->SetUploadsEnabled(true)); |
|
Mark Mentovai
2015/03/09 19:12:36
Make sure that this sticks if you have another Set
Robert Sesek
2015/03/09 21:16:28
Done.
|
| + EXPECT_TRUE(settings()->GetUploadsEnabled(&enabled)); |
| + EXPECT_TRUE(enabled); |
| + |
| + EXPECT_TRUE(settings()->SetUploadsEnabled(false)); |
| + EXPECT_TRUE(settings()->GetUploadsEnabled(&enabled)); |
| + EXPECT_FALSE(enabled); |
| +} |
| + |
| +TEST_F(SettingsTest, LastUploadAttemptTime) { |
| + time_t actual = -1; |
| + EXPECT_TRUE(settings()->GetLastUploadAttemptTime(&actual)); |
| + // Default value is 0. |
| + EXPECT_EQ(0, actual); |
| + |
| + time_t expected = time(nullptr); |
|
Mark Mentovai
2015/03/09 19:12:36
Can be const.
Robert Sesek
2015/03/09 21:16:28
Done.
|
| + EXPECT_TRUE(settings()->SetLastUploadAttemptTime(expected)); |
|
Mark Mentovai
2015/03/09 19:12:36
Same.
Robert Sesek
2015/03/09 21:16:28
Done.
|
| + EXPECT_TRUE(settings()->GetLastUploadAttemptTime(&actual)); |
| + EXPECT_EQ(expected, actual); |
| +} |
| + |
| +// The following tests write a corrupt settings file and test the recovery |
| +// operation. |
| + |
| +TEST_F(SettingsTest, BadFileOnInitialize) { |
| + InitializeBadFile(); |
| + |
| + Settings settings(settings_path()); |
| + EXPECT_TRUE(settings.Initialize()); |
| +} |
| + |
| +TEST_F(SettingsTest, BadFileOnGet) { |
| + InitializeBadFile(); |
| + |
| + UUID client_id; |
| + EXPECT_TRUE(settings()->GetClientID(&client_id)); |
|
Mark Mentovai
2015/03/09 19:12:36
Make sure that this stored the client ID and that
Robert Sesek
2015/03/09 21:16:27
Done.
|
| + EXPECT_NE(UUID(), client_id); |
| +} |
| + |
| +TEST_F(SettingsTest, BadFileOnSet) { |
| + InitializeBadFile(); |
| + |
| + EXPECT_TRUE(settings()->SetUploadsEnabled(true)); |
| + bool enabled = false; |
| + EXPECT_TRUE(settings()->GetUploadsEnabled(&enabled)); |
| + EXPECT_TRUE(enabled); |
| +} |
| + |
| +} // namespace |
| +} // namespace test |
| +} // namespace crashpad |