// Copyright (c) 2006-2008 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. #ifndef NET_BASE_TEST_COMPLETION_CALLBACK_H_ #define NET_BASE_TEST_COMPLETION_CALLBACK_H_ #include "base/callback.h" #include "base/message_loop.h" #include "net/base/completion_callback.h" #include "net/base/net_errors.h" //----------------------------------------------------------------------------- // completion callback helper // A helper class for completion callbacks, designed to make it easy to run // tests involving asynchronous operations. Just call WaitForResult to wait // for the asynchronous operation to complete. // // NOTE: Since this runs a message loop to wait for the completion callback, // there could be other side-effects resulting from WaitForResult. For this // reason, this class is probably not ideal for a general application. // class TestCompletionCallback : public CallbackRunner< Tuple1 > { public: TestCompletionCallback() : result_(0), have_result_(false), waiting_for_result_(false) { } int WaitForResult() { DCHECK(!waiting_for_result_); while (!have_result_) { waiting_for_result_ = true; MessageLoop::current()->Run(); waiting_for_result_ = false; } have_result_ = false; // auto-reset for next callback return result_; } int GetResult(int result) { if (net::ERR_IO_PENDING != result) return result; return WaitForResult(); } bool have_result() const { return have_result_; } virtual void RunWithParams(const Tuple1& params) { result_ = params.a; have_result_ = true; if (waiting_for_result_) MessageLoop::current()->Quit(); } private: int result_; bool have_result_; bool waiting_for_result_; }; #endif // NET_BASE_TEST_COMPLETION_CALLBACK_H_