Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(813)

Unified Diff: base/thread_pool_unittest.cc

Issue 624713003: Keep only base/extractor.[cc|h]. (Closed) Base URL: https://chromium.googlesource.com/external/omaha.git@master
Patch Set: Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « base/thread_pool_callback.h ('k') | base/time.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: base/thread_pool_unittest.cc
diff --git a/base/thread_pool_unittest.cc b/base/thread_pool_unittest.cc
deleted file mode 100644
index 389c883978a0ba9040171751a73c6ac23921c192..0000000000000000000000000000000000000000
--- a/base/thread_pool_unittest.cc
+++ /dev/null
@@ -1,118 +0,0 @@
-// Copyright 2004-2009 Google Inc.
-//
-// 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 "base/basictypes.h"
-#include "base/scoped_ptr.h"
-#include "omaha/base/thread_pool.h"
-#include "omaha/base/timer.h"
-#include "omaha/testing/unit_test.h"
-
-namespace omaha {
-
-namespace {
-
-volatile LONG g_completed_count = 0;
-
-// Increments the global count by 1.
-class MyJob1 : public UserWorkItem {
- public:
- MyJob1() {}
-
- private:
- virtual void DoProcess() { ::InterlockedExchangeAdd(&g_completed_count, 1); }
-
- DISALLOW_EVIL_CONSTRUCTORS(MyJob1);
-};
-
-// Increments the global count by 2.
-class MyJob2 : public UserWorkItem {
- public:
- MyJob2() {}
-
- private:
- virtual void DoProcess() { ::InterlockedExchangeAdd(&g_completed_count, 2); }
-
- DISALLOW_EVIL_CONSTRUCTORS(MyJob2);
-};
-
-// Increments the global count by 3.
-class MyJob3 : public UserWorkItem {
- public:
- MyJob3() {}
-
- private:
- virtual void DoProcess() { ::InterlockedExchangeAdd(&g_completed_count, 3); }
-
- DISALLOW_EVIL_CONSTRUCTORS(MyJob3);
-};
-
-HRESULT QueueMyJob1(ThreadPool* thread_pool) {
- scoped_ptr<MyJob1> job(new MyJob1);
- HRESULT hr = thread_pool->QueueUserWorkItem(job.get(), WT_EXECUTEDEFAULT);
- if (FAILED(hr)) {
- return hr;
- }
- job.release();
- return S_OK;
-}
-
-HRESULT QueueMyJob2(ThreadPool* thread_pool) {
- scoped_ptr<MyJob2> job(new MyJob2);
- HRESULT hr = thread_pool->QueueUserWorkItem(job.get(), WT_EXECUTEDEFAULT);
- if (FAILED(hr)) {
- return hr;
- }
- job.release();
- return S_OK;
-}
-
-HRESULT QueueMyJob3(ThreadPool* thread_pool) {
- scoped_ptr<MyJob3> job(new MyJob3);
- HRESULT hr = thread_pool->QueueUserWorkItem(job.get(), WT_EXECUTEDEFAULT);
- if (FAILED(hr)) {
- return hr;
- }
- job.release();
- return S_OK;
-}
-
-} // namespace
-
-// Creates several jobs to increment a global counter by different values and
-// then it checks the value is correct.
-TEST(ThreadPoolTest, ThreadPool) {
- const int kShutdownDelayMs = 0;
- const int kNumJobsEachType = 100;
-
- ThreadPool thread_pool;
- ASSERT_HRESULT_SUCCEEDED(thread_pool.Initialize(kShutdownDelayMs));
-
- for (int i = 0; i != kNumJobsEachType; ++i) {
- EXPECT_HRESULT_SUCCEEDED(QueueMyJob1(&thread_pool));
- EXPECT_HRESULT_SUCCEEDED(QueueMyJob2(&thread_pool));
- EXPECT_HRESULT_SUCCEEDED(QueueMyJob3(&thread_pool));
- }
-
- const int kMaxWaitForJobsMs = 2000;
- LowResTimer t(true);
- while (thread_pool.HasWorkItems() &&
- t.GetMilliseconds() < kMaxWaitForJobsMs) {
- ::Sleep(100);
- }
- EXPECT_EQ(g_completed_count, 6 * kNumJobsEachType);
-}
-
-} // namespace omaha
-
« no previous file with comments | « base/thread_pool_callback.h ('k') | base/time.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698