Index: chrome/browser/chromeos/policy/system_log_upload_job_unittest.cc |
diff --git a/chrome/browser/chromeos/policy/system_log_upload_job_unittest.cc b/chrome/browser/chromeos/policy/system_log_upload_job_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..56246cad418a3aef46dc7f84ec1a4086d7d72e36 |
--- /dev/null |
+++ b/chrome/browser/chromeos/policy/system_log_upload_job_unittest.cc |
@@ -0,0 +1,182 @@ |
+// Copyright 2015 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "ash/test/ash_test_base.h" |
+#include "base/run_loop.h" |
+#include "base/test/test_mock_time_task_runner.h" |
+#include "base/thread_task_runner_handle.h" |
+#include "base/time/time.h" |
+#include "chrome/browser/chromeos/policy/system_log_upload_job.h" |
+#include "chrome/browser/chromeos/policy/upload_job.h" |
+ |
+namespace policy { |
+ |
+namespace { |
+ |
+const char* const kMockUploadUrl = "http://example.com/upload"; |
+ |
+const char* const kTestSystemLogFileNames[] = {"my_system_log_file.txt"}; |
+ |
+class MockUploadJob : public policy::UploadJob { |
+ public: |
+ // If |error_code| is a null pointer OnSuccess() will be invoked when the |
+ // Start() method is called, otherwise OnFailure() will be invoked with the |
+ // respective |error_code|. |
+ MockUploadJob(const GURL& upload_url, |
+ UploadJob::Delegate* delegate, |
+ scoped_ptr<UploadJob::ErrorCode> error_code); |
+ ~MockUploadJob() override; |
+ |
+ // policy::UploadJob: |
+ void AddDataSegment(const std::string& name, |
+ const std::string& filename, |
+ const std::map<std::string, std::string>& header_entries, |
+ scoped_ptr<std::string> data) override; |
+ void Start() override; |
+ |
+ protected: |
+ const GURL upload_url_; |
+ UploadJob::Delegate* delegate_; |
+ scoped_ptr<UploadJob::ErrorCode> error_code_; |
+}; |
+ |
+MockUploadJob::MockUploadJob(const GURL& upload_url, |
+ UploadJob::Delegate* delegate, |
+ scoped_ptr<UploadJob::ErrorCode> error_code) |
+ : upload_url_(upload_url), |
+ delegate_(delegate), |
+ error_code_(error_code.Pass()) { |
+} |
+ |
+MockUploadJob::~MockUploadJob() { |
+} |
+ |
+void MockUploadJob::AddDataSegment( |
+ const std::string& name, |
+ const std::string& filename, |
+ const std::map<std::string, std::string>& header_entries, |
+ scoped_ptr<std::string> data) { |
+} |
+ |
+void MockUploadJob::Start() { |
+ DCHECK(delegate_); |
+ EXPECT_EQ(kMockUploadUrl, upload_url_.spec()); |
Andrew T Wilson (Slow)
2015/07/03 16:19:59
What is this testing, exactly? And why are we test
Polina Bondarenko
2015/07/10 13:24:22
Yes, removed.
|
+ if (error_code_) { |
+ base::ThreadTaskRunnerHandle::Get()->PostTask( |
+ FROM_HERE, base::Bind(&UploadJob::Delegate::OnFailure, |
+ base::Unretained(delegate_), *error_code_)); |
+ return; |
Andrew T Wilson (Slow)
2015/07/03 16:20:00
This is OK as is, but usually I prefer:
if (error
Polina Bondarenko
2015/07/10 13:24:22
Done.
|
+ } |
+ base::ThreadTaskRunnerHandle::Get()->PostTask( |
+ FROM_HERE, |
+ base::Bind(&UploadJob::Delegate::OnSuccess, base::Unretained(delegate_))); |
+} |
+ |
+// Generate the fake system log files. |
+scoped_ptr<SystemLogUploadJob::SystemLogs> GenerateTestSystemLogFiles() { |
+ scoped_ptr<SystemLogUploadJob::SystemLogs> system_logs( |
+ new SystemLogUploadJob::SystemLogs()); |
+ for (auto const file_path : kTestSystemLogFileNames) { |
+ system_logs->push_back(std::make_pair(file_path, file_path)); |
Andrew T Wilson (Slow)
2015/07/03 16:20:00
Is there any code that tests that this file data i
Polina Bondarenko
2015/07/10 13:24:21
Added.
|
+ } |
+ return system_logs; |
+} |
+ |
+class MockSystemLogDelegate : public SystemLogUploadJob::Delegate { |
+ public: |
+ explicit MockSystemLogDelegate( |
+ scoped_ptr<UploadJob::ErrorCode> upload_job_error_code); |
+ ~MockSystemLogDelegate() override; |
+ |
+ void LoadSystemLogs( |
+ const SystemLogUploadJob::LogUploadCallback& upload_callback) override; |
+ scoped_ptr<UploadJob> CreateUploadJob(const GURL&, |
+ UploadJob::Delegate*) override; |
+ |
+ private: |
+ scoped_ptr<UploadJob::ErrorCode> upload_job_error_code_; |
+}; |
+ |
+MockSystemLogDelegate::MockSystemLogDelegate( |
+ scoped_ptr<UploadJob::ErrorCode> upload_job_error_code) |
+ : upload_job_error_code_(upload_job_error_code.Pass()) { |
+} |
+ |
+MockSystemLogDelegate::~MockSystemLogDelegate() { |
+} |
+ |
+void MockSystemLogDelegate::LoadSystemLogs( |
+ const SystemLogUploadJob::LogUploadCallback& upload_callback) { |
+ scoped_ptr<SystemLogUploadJob::SystemLogs> test_files = |
+ GenerateTestSystemLogFiles(); |
+ base::ThreadTaskRunnerHandle::Get()->PostTask( |
+ FROM_HERE, |
+ base::Bind(upload_callback, base::Owned(test_files.release()))); |
+} |
+ |
+scoped_ptr<UploadJob> MockSystemLogDelegate::CreateUploadJob( |
+ const GURL& upload_url, |
+ UploadJob::Delegate* delegate) { |
+ return make_scoped_ptr(new MockUploadJob(GURL(kMockUploadUrl), delegate, |
+ upload_job_error_code_.Pass())); |
+} |
+ |
+} // namespace |
+ |
+class SystemLogUploadTest : public ash::test::AshTestBase { |
Andrew T Wilson (Slow)
2015/07/03 16:19:59
Why are we deriving from AshTestBase? I don't thin
Polina Bondarenko
2015/07/10 13:24:21
Done.
|
+ public: |
+ void VerifyResults(SystemLogUploadJob* job, |
+ SystemLogUploadJob::Status expected_status); |
+ |
+ protected: |
+ SystemLogUploadTest(); |
+ |
+ base::RunLoop run_loop_; |
+ |
+ private: |
+ scoped_refptr<base::TestMockTimeTaskRunner> task_runner_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(SystemLogUploadTest); |
+}; |
+ |
+SystemLogUploadTest::SystemLogUploadTest() |
+ : task_runner_(new base::TestMockTimeTaskRunner()) { |
+} |
+ |
+void SystemLogUploadTest::VerifyResults( |
+ SystemLogUploadJob* job, |
+ SystemLogUploadJob::Status expected_status) { |
+ EXPECT_EQ(expected_status, job->status()); |
+ |
+ run_loop_.Quit(); |
+} |
+ |
+TEST_F(SystemLogUploadTest, Success) { |
+ scoped_ptr<SystemLogUploadJob> job(new SystemLogUploadJob( |
+ make_scoped_ptr(new MockSystemLogDelegate(nullptr)))); |
+ |
+ job->Run( |
+ base::Bind(&SystemLogUploadTest::VerifyResults, base::Unretained(this), |
+ base::Unretained(job.get()), SystemLogUploadJob::SUCCEEDED), |
+ base::Bind(&SystemLogUploadTest::VerifyResults, base::Unretained(this), |
Andrew T Wilson (Slow)
2015/07/03 16:19:59
Seems like it should be an error for this second c
Polina Bondarenko
2015/07/10 13:24:22
Done.
|
+ base::Unretained(job.get()), SystemLogUploadJob::SUCCEEDED)); |
+ run_loop_.Run(); |
+} |
+ |
+TEST_F(SystemLogUploadTest, Failure) { |
+ using ErrorCode = UploadJob::ErrorCode; |
+ scoped_ptr<ErrorCode> error_code( |
+ new ErrorCode(UploadJob::AUTHENTICATION_ERROR)); |
+ scoped_ptr<SystemLogUploadJob> job(new SystemLogUploadJob( |
+ make_scoped_ptr(new MockSystemLogDelegate(error_code.Pass())))); |
+ |
+ job->Run( |
+ base::Bind(&SystemLogUploadTest::VerifyResults, base::Unretained(this), |
+ base::Unretained(job.get()), SystemLogUploadJob::FAILED), |
+ base::Bind(&SystemLogUploadTest::VerifyResults, base::Unretained(this), |
Andrew T Wilson (Slow)
2015/07/03 16:20:00
ditto here, success callback shouldn't be called,
Polina Bondarenko
2015/07/10 13:24:21
Done.
|
+ base::Unretained(job.get()), SystemLogUploadJob::FAILED)); |
+ run_loop_.Run(); |
+} |
+ |
+} // namespace policy |