| Index: net/base/mock_file_stream.cc
 | 
| diff --git a/net/base/mock_file_stream.cc b/net/base/mock_file_stream.cc
 | 
| index d160f0c938583e307574fe5c1541ca66a6fe948c..3f05ab46c2d15cfa41fbc4ef72d70d3c081d1634 100644
 | 
| --- a/net/base/mock_file_stream.cc
 | 
| +++ b/net/base/mock_file_stream.cc
 | 
| @@ -4,10 +4,46 @@
 | 
|  
 | 
|  #include "net/base/mock_file_stream.h"
 | 
|  
 | 
| +#include "base/bind.h"
 | 
| +#include "base/message_loop/message_loop.h"
 | 
| +
 | 
|  namespace net {
 | 
|  
 | 
|  namespace testing {
 | 
|  
 | 
| +MockFileStream::MockFileStream(net::NetLog* net_log)
 | 
| +    : net::FileStream(net_log),
 | 
| +      forced_error_(net::OK),
 | 
| +      async_error_(false),
 | 
| +      throttled_(false),
 | 
| +      weak_factory_(this) {
 | 
| +}
 | 
| +
 | 
| +MockFileStream::MockFileStream(base::PlatformFile file,
 | 
| +                               int flags,
 | 
| +                               net::NetLog* net_log)
 | 
| +    : net::FileStream(file, flags, net_log),
 | 
| +      forced_error_(net::OK),
 | 
| +      async_error_(false),
 | 
| +      throttled_(false),
 | 
| +      weak_factory_(this) {
 | 
| +}
 | 
| +
 | 
| +MockFileStream::MockFileStream(
 | 
| +    base::PlatformFile file,
 | 
| +    int flags,
 | 
| +    net::NetLog* net_log,
 | 
| +    const scoped_refptr<base::TaskRunner>& task_runner)
 | 
| +    : net::FileStream(file, flags, net_log, task_runner),
 | 
| +      forced_error_(net::OK),
 | 
| +      async_error_(false),
 | 
| +      throttled_(false),
 | 
| +      weak_factory_(this) {
 | 
| +}
 | 
| +
 | 
| +MockFileStream::~MockFileStream() {
 | 
| +}
 | 
| +
 | 
|  int MockFileStream::OpenSync(const base::FilePath& path, int open_flags) {
 | 
|    path_ = path;
 | 
|    return ReturnError(FileStream::OpenSync(path, open_flags));
 | 
| @@ -15,7 +51,12 @@ int MockFileStream::OpenSync(const base::FilePath& path, int open_flags) {
 | 
|  
 | 
|  int MockFileStream::Seek(Whence whence, int64 offset,
 | 
|                           const Int64CompletionCallback& callback) {
 | 
| -  return ReturnError(FileStream::Seek(whence, offset, callback));
 | 
| +  Int64CompletionCallback wrapped_callback =
 | 
| +      base::Bind(&MockFileStream::DoCallback64,
 | 
| +                 weak_factory_.GetWeakPtr(), callback);
 | 
| +  if (forced_error_ == net::OK)
 | 
| +    return FileStream::Seek(whence, offset, wrapped_callback);
 | 
| +  return ErrorCallback64(wrapped_callback);
 | 
|  }
 | 
|  
 | 
|  int64 MockFileStream::SeekSync(Whence whence, int64 offset) {
 | 
| @@ -29,7 +70,12 @@ int64 MockFileStream::Available() {
 | 
|  int MockFileStream::Read(IOBuffer* buf,
 | 
|                           int buf_len,
 | 
|                           const CompletionCallback& callback) {
 | 
| -  return ReturnError(FileStream::Read(buf, buf_len, callback));
 | 
| +  CompletionCallback wrapped_callback = base::Bind(&MockFileStream::DoCallback,
 | 
| +                                                   weak_factory_.GetWeakPtr(),
 | 
| +                                                   callback);
 | 
| +  if (forced_error_ == net::OK)
 | 
| +    return FileStream::Read(buf, buf_len, wrapped_callback);
 | 
| +  return ErrorCallback(wrapped_callback);
 | 
|  }
 | 
|  
 | 
|  int MockFileStream::ReadSync(char* buf, int buf_len) {
 | 
| @@ -43,7 +89,12 @@ int MockFileStream::ReadUntilComplete(char *buf, int buf_len) {
 | 
|  int MockFileStream::Write(IOBuffer* buf,
 | 
|                            int buf_len,
 | 
|                            const CompletionCallback& callback) {
 | 
| -  return ReturnError(FileStream::Write(buf, buf_len, callback));
 | 
| +  CompletionCallback wrapped_callback = base::Bind(&MockFileStream::DoCallback,
 | 
| +                                                   weak_factory_.GetWeakPtr(),
 | 
| +                                                   callback);
 | 
| +  if (forced_error_ == net::OK)
 | 
| +    return FileStream::Write(buf, buf_len, wrapped_callback);
 | 
| +  return ErrorCallback(wrapped_callback);
 | 
|  }
 | 
|  
 | 
|  int MockFileStream::WriteSync(const char* buf, int buf_len) {
 | 
| @@ -55,13 +106,80 @@ int64 MockFileStream::Truncate(int64 bytes) {
 | 
|  }
 | 
|  
 | 
|  int MockFileStream::Flush(const CompletionCallback& callback) {
 | 
| -  return ReturnError(FileStream::Flush(callback));
 | 
| +  CompletionCallback wrapped_callback = base::Bind(&MockFileStream::DoCallback,
 | 
| +                                                   weak_factory_.GetWeakPtr(),
 | 
| +                                                   callback);
 | 
| +  if (forced_error_ == net::OK)
 | 
| +    return FileStream::Flush(wrapped_callback);
 | 
| +  return ErrorCallback(wrapped_callback);
 | 
|  }
 | 
|  
 | 
|  int MockFileStream::FlushSync() {
 | 
|    return ReturnError(FileStream::FlushSync());
 | 
|  }
 | 
|  
 | 
| +void MockFileStream::ThrottleCallbacks() {
 | 
| +  CHECK(!throttled_);
 | 
| +  throttled_ = true;
 | 
| +}
 | 
| +
 | 
| +void MockFileStream::ReleaseCallbacks() {
 | 
| +  CHECK(throttled_);
 | 
| +  throttled_ = false;
 | 
| +
 | 
| +  if (!throttled_task_.is_null()) {
 | 
| +    base::Closure throttled_task = throttled_task_;
 | 
| +    throttled_task_.Reset();
 | 
| +    base::MessageLoop::current()->PostTask(FROM_HERE, throttled_task);
 | 
| +  }
 | 
| +}
 | 
| +
 | 
| +void MockFileStream::DoCallback(const CompletionCallback& callback,
 | 
| +                                int result) {
 | 
| +  if (!throttled_) {
 | 
| +    callback.Run(result);
 | 
| +    return;
 | 
| +  }
 | 
| +  CHECK(throttled_task_.is_null());
 | 
| +  throttled_task_ = base::Bind(callback, result);
 | 
| +}
 | 
| +
 | 
| +void MockFileStream::DoCallback64(const Int64CompletionCallback& callback,
 | 
| +                                  int64 result) {
 | 
| +  if (!throttled_) {
 | 
| +    callback.Run(result);
 | 
| +    return;
 | 
| +  }
 | 
| +  CHECK(throttled_task_.is_null());
 | 
| +  throttled_task_ = base::Bind(callback, result);
 | 
| +}
 | 
| +
 | 
| +int MockFileStream::ErrorCallback(const CompletionCallback& callback) {
 | 
| +  CHECK_NE(net::OK, forced_error_);
 | 
| +  if (async_error_) {
 | 
| +    base::MessageLoop::current()->PostTask(
 | 
| +        FROM_HERE, base::Bind(callback, forced_error_));
 | 
| +    clear_forced_error();
 | 
| +    return net::ERR_IO_PENDING;
 | 
| +  }
 | 
| +  int ret = forced_error_;
 | 
| +  clear_forced_error();
 | 
| +  return ret;
 | 
| +}
 | 
| +
 | 
| +int64 MockFileStream::ErrorCallback64(const Int64CompletionCallback& callback) {
 | 
| +  CHECK_NE(net::OK, forced_error_);
 | 
| +  if (async_error_) {
 | 
| +    base::MessageLoop::current()->PostTask(
 | 
| +        FROM_HERE, base::Bind(callback, forced_error_));
 | 
| +    clear_forced_error();
 | 
| +    return net::ERR_IO_PENDING;
 | 
| +  }
 | 
| +  int64 ret = forced_error_;
 | 
| +  clear_forced_error();
 | 
| +  return ret;
 | 
| +}
 | 
| +
 | 
|  }  // namespace testing
 | 
|  
 | 
|  }  // namespace net
 | 
| 
 |