blob: 31171f13a66f4c59a3a711e81041addccad30d89 [file] [log] [blame]
rspangler@google.com49fdf182009-10-10 00:57:34 +00001// Copyright (c) 2009 The Chromium OS Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
adlr@google.comc98a7ed2009-12-04 18:54:03 +00005#ifndef CHROMEOS_PLATFORM_UPDATE_ENGINE_MOCK_HTTP_FETCHER_H__
6#define CHROMEOS_PLATFORM_UPDATE_ENGINE_MOCK_HTTP_FETCHER_H__
rspangler@google.com49fdf182009-10-10 00:57:34 +00007
8#include <vector>
Andrew de los Reyes45168102010-11-22 11:13:50 -08009
10#include <base/logging.h>
rspangler@google.com49fdf182009-10-10 00:57:34 +000011#include <glib.h>
Andrew de los Reyes45168102010-11-22 11:13:50 -080012
rspangler@google.com49fdf182009-10-10 00:57:34 +000013#include "update_engine/http_fetcher.h"
14
15// This is a mock implementation of HttpFetcher which is useful for testing.
16// All data must be passed into the ctor. When started, MockHttpFetcher will
17// deliver the data in chunks of size kMockHttpFetcherChunkSize. To simulate
18// a network failure, you can call FailTransfer().
19
20namespace chromeos_update_engine {
21
22// MockHttpFetcher will send a chunk of data down in each call to BeginTransfer
23// and Unpause. For the other chunks of data, a callback is put on the run
24// loop and when that's called, another chunk is sent down.
25const size_t kMockHttpFetcherChunkSize(65536);
26
27class MockHttpFetcher : public HttpFetcher {
28 public:
29 // The data passed in here is copied and then passed to the delegate after
30 // the transfer begins.
Andrew de los Reyes45168102010-11-22 11:13:50 -080031 MockHttpFetcher(const char* data,
32 size_t size,
33 ProxyResolver* proxy_resolver)
34 : HttpFetcher(proxy_resolver),
35 sent_size_(0),
Darin Petkovedc522e2010-11-05 09:35:17 -070036 timeout_source_(NULL),
37 timout_tag_(0),
38 paused_(false),
Andrew de los Reyes173e63c2011-04-04 17:19:57 -070039 fail_transfer_(false),
40 never_use_(false) {
rspangler@google.com49fdf182009-10-10 00:57:34 +000041 data_.insert(data_.end(), data, data + size);
rspangler@google.com49fdf182009-10-10 00:57:34 +000042 }
43
44 // Cleans up all internal state. Does not notify delegate
45 ~MockHttpFetcher();
46
Andrew de los Reyes3fd5d302010-10-07 20:07:18 -070047 // Ignores this.
Andrew de los Reyes34e41a12010-10-26 20:07:58 -070048 virtual void SetOffset(off_t offset) {
49 sent_size_ = offset;
50 if (delegate_)
51 delegate_->SeekToOffset(offset);
52 }
Andrew de los Reyes3fd5d302010-10-07 20:07:18 -070053
Gilad Arnolde4ad2502011-12-29 17:08:54 -080054 // Do nothing.
55 virtual void SetLength(size_t length) {}
56 virtual void UnsetLength() {}
57
Gilad Arnold48085ba2011-11-16 09:36:08 -080058 // Dummy: no bytes were downloaded.
59 virtual size_t GetBytesDownloaded() {
60 return sent_size_;
61 }
62
rspangler@google.com49fdf182009-10-10 00:57:34 +000063 // Begins the transfer if it hasn't already begun.
64 virtual void BeginTransfer(const std::string& url);
65
66 // If the transfer is in progress, aborts the transfer early.
67 // The transfer cannot be resumed.
68 virtual void TerminateTransfer();
69
70 // Suspend the mock transfer.
71 virtual void Pause();
72
73 // Resume the mock transfer.
74 virtual void Unpause();
75
76 // Fail the transfer. This simulates a network failure.
Darin Petkovedc522e2010-11-05 09:35:17 -070077 void FailTransfer(int http_response_code);
rspangler@google.com49fdf182009-10-10 00:57:34 +000078
Andrew de los Reyes173e63c2011-04-04 17:19:57 -070079 // If set to true, this will EXPECT fail on BeginTransfer
80 void set_never_use(bool never_use) { never_use_ = never_use; }
81
rspangler@google.com49fdf182009-10-10 00:57:34 +000082 const std::vector<char>& post_data() const {
83 return post_data_;
84 }
adlr@google.comc98a7ed2009-12-04 18:54:03 +000085
rspangler@google.com49fdf182009-10-10 00:57:34 +000086 private:
87 // Sends data to the delegate and sets up a glib timeout callback if needed.
88 // There must be a delegate and there must be data to send. If there is
89 // already a timeout callback, and it should be deleted by the caller,
90 // this will return false; otherwise true is returned.
91 // If skip_delivery is true, no bytes will be delivered, but the callbacks
92 // still still be set if needed
93 bool SendData(bool skip_delivery);
94
95 // Callback for when our glib main loop callback is called
96 bool TimeoutCallback();
97 static gboolean StaticTimeoutCallback(gpointer data) {
98 return reinterpret_cast<MockHttpFetcher*>(data)->TimeoutCallback();
99 }
100
Darin Petkovedc522e2010-11-05 09:35:17 -0700101 // Sets the HTTP response code and signals to the delegate that the transfer
102 // is complete.
103 void SignalTransferComplete();
104
rspangler@google.com49fdf182009-10-10 00:57:34 +0000105 // A full copy of the data we'll return to the delegate
106 std::vector<char> data_;
107
108 // The number of bytes we've sent so far
109 size_t sent_size_;
110
111 // The glib main loop timeout source. After each chunk of data sent, we
112 // time out for 0s just to make sure that run loop services other clients.
113 GSource* timeout_source_;
114
115 // ID of the timeout source, valid only if timeout_source_ != NULL
116 guint timout_tag_;
117
118 // True iff the fetcher is paused.
119 bool paused_;
120
Darin Petkovedc522e2010-11-05 09:35:17 -0700121 // Set to true if the transfer should fail.
122 bool fail_transfer_;
123
Andrew de los Reyes173e63c2011-04-04 17:19:57 -0700124 // Set to true if BeginTransfer should EXPECT fail.
125 bool never_use_;
126
rspangler@google.com49fdf182009-10-10 00:57:34 +0000127 DISALLOW_COPY_AND_ASSIGN(MockHttpFetcher);
128};
129
130} // namespace chromeos_update_engine
131
adlr@google.comc98a7ed2009-12-04 18:54:03 +0000132#endif // CHROMEOS_PLATFORM_UPDATE_ENGINE_MOCK_HTTP_FETCHER_H__