blob: 2515b0004075b8993ed18f7661f09939e07c82be [file] [log] [blame]
Alex Deymoaea4c1c2015-08-19 20:24:43 -07001//
2// Copyright (C) 2009 The Android Open Source Project
3//
4// Licensed under the Apache License, Version 2.0 (the "License");
5// you may not use this file except in compliance with the License.
6// You may obtain a copy of the License at
7//
8// http://www.apache.org/licenses/LICENSE-2.0
9//
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13// See the License for the specific language governing permissions and
14// limitations under the License.
15//
rspangler@google.com49fdf182009-10-10 00:57:34 +000016
Gilad Arnoldcf175a02014-07-10 16:48:47 -070017#ifndef UPDATE_ENGINE_MOCK_HTTP_FETCHER_H_
18#define UPDATE_ENGINE_MOCK_HTTP_FETCHER_H_
rspangler@google.com49fdf182009-10-10 00:57:34 +000019
Alex Vakulenkod2779df2014-06-16 13:19:00 -070020#include <string>
rspangler@google.com49fdf182009-10-10 00:57:34 +000021#include <vector>
Andrew de los Reyes45168102010-11-22 11:13:50 -080022
23#include <base/logging.h>
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -070024#include <brillo/message_loops/message_loop.h>
Andrew de los Reyes45168102010-11-22 11:13:50 -080025
Gilad Arnold5bb4c902014-04-10 12:32:13 -070026#include "update_engine/fake_system_state.h"
rspangler@google.com49fdf182009-10-10 00:57:34 +000027#include "update_engine/http_fetcher.h"
Jay Srinivasan43488792012-06-19 00:25:31 -070028#include "update_engine/mock_connection_manager.h"
rspangler@google.com49fdf182009-10-10 00:57:34 +000029
30// This is a mock implementation of HttpFetcher which is useful for testing.
31// All data must be passed into the ctor. When started, MockHttpFetcher will
32// deliver the data in chunks of size kMockHttpFetcherChunkSize. To simulate
33// a network failure, you can call FailTransfer().
34
35namespace chromeos_update_engine {
36
37// MockHttpFetcher will send a chunk of data down in each call to BeginTransfer
38// and Unpause. For the other chunks of data, a callback is put on the run
39// loop and when that's called, another chunk is sent down.
40const size_t kMockHttpFetcherChunkSize(65536);
41
42class MockHttpFetcher : public HttpFetcher {
43 public:
44 // The data passed in here is copied and then passed to the delegate after
45 // the transfer begins.
Alex Vakulenkof68bbbc2015-02-09 12:53:18 -080046 MockHttpFetcher(const uint8_t* data,
Andrew de los Reyes45168102010-11-22 11:13:50 -080047 size_t size,
48 ProxyResolver* proxy_resolver)
Gilad Arnold5bb4c902014-04-10 12:32:13 -070049 : HttpFetcher(proxy_resolver, &fake_system_state_),
Andrew de los Reyes45168102010-11-22 11:13:50 -080050 sent_size_(0),
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -070051 timeout_id_(brillo::MessageLoop::kTaskIdNull),
Darin Petkovedc522e2010-11-05 09:35:17 -070052 paused_(false),
Andrew de los Reyes173e63c2011-04-04 17:19:57 -070053 fail_transfer_(false),
Alex Deymof6ee0162015-07-31 12:35:22 -070054 never_use_(false) {
Gilad Arnold5bb4c902014-04-10 12:32:13 -070055 fake_system_state_.set_connection_manager(&mock_connection_manager_);
rspangler@google.com49fdf182009-10-10 00:57:34 +000056 data_.insert(data_.end(), data, data + size);
rspangler@google.com49fdf182009-10-10 00:57:34 +000057 }
58
Alex Vakulenkof68bbbc2015-02-09 12:53:18 -080059 // Constructor overload for string data.
60 MockHttpFetcher(const char* data, size_t size, ProxyResolver* proxy_resolver)
61 : MockHttpFetcher(reinterpret_cast<const uint8_t*>(data), size,
62 proxy_resolver) {}
63
rspangler@google.com49fdf182009-10-10 00:57:34 +000064 // Cleans up all internal state. Does not notify delegate
Alex Deymo610277e2014-11-11 21:18:11 -080065 ~MockHttpFetcher() override;
rspangler@google.com49fdf182009-10-10 00:57:34 +000066
Andrew de los Reyes3fd5d302010-10-07 20:07:18 -070067 // Ignores this.
Alex Deymo610277e2014-11-11 21:18:11 -080068 void SetOffset(off_t offset) override {
Andrew de los Reyes34e41a12010-10-26 20:07:58 -070069 sent_size_ = offset;
70 if (delegate_)
71 delegate_->SeekToOffset(offset);
72 }
Andrew de los Reyes3fd5d302010-10-07 20:07:18 -070073
Gilad Arnolde4ad2502011-12-29 17:08:54 -080074 // Do nothing.
Alex Deymo610277e2014-11-11 21:18:11 -080075 void SetLength(size_t length) override {}
76 void UnsetLength() override {}
77 void set_low_speed_limit(int low_speed_bps, int low_speed_sec) override {}
78 void set_connect_timeout(int connect_timeout_seconds) override {}
79 void set_max_retry_count(int max_retry_count) override {}
Gilad Arnolde4ad2502011-12-29 17:08:54 -080080
Gilad Arnold48085ba2011-11-16 09:36:08 -080081 // Dummy: no bytes were downloaded.
Alex Deymo610277e2014-11-11 21:18:11 -080082 size_t GetBytesDownloaded() override {
Gilad Arnold48085ba2011-11-16 09:36:08 -080083 return sent_size_;
84 }
85
rspangler@google.com49fdf182009-10-10 00:57:34 +000086 // Begins the transfer if it hasn't already begun.
Alex Deymo610277e2014-11-11 21:18:11 -080087 void BeginTransfer(const std::string& url) override;
rspangler@google.com49fdf182009-10-10 00:57:34 +000088
89 // If the transfer is in progress, aborts the transfer early.
90 // The transfer cannot be resumed.
Alex Deymo610277e2014-11-11 21:18:11 -080091 void TerminateTransfer() override;
rspangler@google.com49fdf182009-10-10 00:57:34 +000092
93 // Suspend the mock transfer.
Alex Deymo610277e2014-11-11 21:18:11 -080094 void Pause() override;
rspangler@google.com49fdf182009-10-10 00:57:34 +000095
96 // Resume the mock transfer.
Alex Deymo610277e2014-11-11 21:18:11 -080097 void Unpause() override;
rspangler@google.com49fdf182009-10-10 00:57:34 +000098
99 // Fail the transfer. This simulates a network failure.
Darin Petkovedc522e2010-11-05 09:35:17 -0700100 void FailTransfer(int http_response_code);
rspangler@google.com49fdf182009-10-10 00:57:34 +0000101
Andrew de los Reyes173e63c2011-04-04 17:19:57 -0700102 // If set to true, this will EXPECT fail on BeginTransfer
103 void set_never_use(bool never_use) { never_use_ = never_use; }
104
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -0700105 const brillo::Blob& post_data() const {
rspangler@google.com49fdf182009-10-10 00:57:34 +0000106 return post_data_;
107 }
adlr@google.comc98a7ed2009-12-04 18:54:03 +0000108
rspangler@google.com49fdf182009-10-10 00:57:34 +0000109 private:
Alex Deymo60ca1a72015-06-18 18:19:15 -0700110 // Sends data to the delegate and sets up a timeout callback if needed.
rspangler@google.com49fdf182009-10-10 00:57:34 +0000111 // There must be a delegate and there must be data to send. If there is
112 // already a timeout callback, and it should be deleted by the caller,
113 // this will return false; otherwise true is returned.
114 // If skip_delivery is true, no bytes will be delivered, but the callbacks
Alex Vakulenko072359c2014-07-18 11:41:07 -0700115 // still be set if needed.
rspangler@google.com49fdf182009-10-10 00:57:34 +0000116 bool SendData(bool skip_delivery);
117
Alex Deymo60ca1a72015-06-18 18:19:15 -0700118 // Callback for when our message loop timeout expires.
119 void TimeoutCallback();
rspangler@google.com49fdf182009-10-10 00:57:34 +0000120
Darin Petkovedc522e2010-11-05 09:35:17 -0700121 // Sets the HTTP response code and signals to the delegate that the transfer
122 // is complete.
123 void SignalTransferComplete();
124
rspangler@google.com49fdf182009-10-10 00:57:34 +0000125 // A full copy of the data we'll return to the delegate
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -0700126 brillo::Blob data_;
rspangler@google.com49fdf182009-10-10 00:57:34 +0000127
128 // The number of bytes we've sent so far
129 size_t sent_size_;
130
Alex Deymo60ca1a72015-06-18 18:19:15 -0700131 // The TaskId of the timeout callback. After each chunk of data sent, we
rspangler@google.com49fdf182009-10-10 00:57:34 +0000132 // time out for 0s just to make sure that run loop services other clients.
Alex Vakulenko3f39d5c2015-10-13 09:27:13 -0700133 brillo::MessageLoop::TaskId timeout_id_;
rspangler@google.com49fdf182009-10-10 00:57:34 +0000134
135 // True iff the fetcher is paused.
136 bool paused_;
137
Darin Petkovedc522e2010-11-05 09:35:17 -0700138 // Set to true if the transfer should fail.
139 bool fail_transfer_;
140
Andrew de los Reyes173e63c2011-04-04 17:19:57 -0700141 // Set to true if BeginTransfer should EXPECT fail.
142 bool never_use_;
143
Gilad Arnold5bb4c902014-04-10 12:32:13 -0700144 FakeSystemState fake_system_state_;
Jay Srinivasan43488792012-06-19 00:25:31 -0700145 MockConnectionManager mock_connection_manager_;
146
rspangler@google.com49fdf182009-10-10 00:57:34 +0000147 DISALLOW_COPY_AND_ASSIGN(MockHttpFetcher);
148};
149
150} // namespace chromeos_update_engine
151
Gilad Arnoldcf175a02014-07-10 16:48:47 -0700152#endif // UPDATE_ENGINE_MOCK_HTTP_FETCHER_H_