1 // Copyright 2013 The Chromium 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 5 #ifndef WEBKIT_BROWSER_QUOTA_MOCK_QUOTA_MANAGER_H_ 6 #define WEBKIT_BROWSER_QUOTA_MOCK_QUOTA_MANAGER_H_ 7 8 #include <string> 9 #include <vector> 10 11 #include "base/memory/scoped_ptr.h" 12 #include "url/gurl.h" 13 #include "webkit/browser/quota/quota_client.h" 14 #include "webkit/browser/quota/quota_manager.h" 15 #include "webkit/browser/quota/quota_task.h" 16 #include "webkit/common/quota/quota_types.h" 17 18 namespace quota { 19 20 // Mocks the pieces of QuotaManager's interface. 21 // 22 // For usage/quota tracking test: 23 // Usage and quota information can be updated by following private helper 24 // methods: SetQuota() and UpdateUsage(). 25 // 26 // For time-based deletion test: 27 // Origins can be added to the mock by calling AddOrigin, and that list of 28 // origins is then searched through in GetOriginsModifiedSince. 29 // Neither GetOriginsModifiedSince nor DeleteOriginData touches the actual 30 // origin data stored in the profile. 31 class MockQuotaManager : public QuotaManager { 32 public: 33 MockQuotaManager(bool is_incognito, 34 const base::FilePath& profile_path, 35 base::SingleThreadTaskRunner* io_thread, 36 base::SequencedTaskRunner* db_thread, 37 SpecialStoragePolicy* special_storage_policy); 38 39 // Overrides QuotaManager's implementation. The internal usage data is 40 // updated when MockQuotaManagerProxy::NotifyStorageModified() is 41 // called. The internal quota value can be updated by calling 42 // a helper method MockQuotaManagerProxy::SetQuota(). 43 virtual void GetUsageAndQuota( 44 const GURL& origin, 45 quota::StorageType type, 46 const GetUsageAndQuotaCallback& callback) OVERRIDE; 47 48 // Overrides QuotaManager's implementation with a canned implementation that 49 // allows clients to set up the origin database that should be queried. This 50 // method will only search through the origins added explicitly via AddOrigin. 51 virtual void GetOriginsModifiedSince( 52 StorageType type, 53 base::Time modified_since, 54 const GetOriginsCallback& callback) OVERRIDE; 55 56 // Removes an origin from the canned list of origins, but doesn't touch 57 // anything on disk. The caller must provide |quota_client_mask| which 58 // specifies the types of QuotaClients which should be removed from this 59 // origin as a bitmask built from QuotaClient::IDs. Setting the mask to 60 // QuotaClient::kAllClientsMask will remove all clients from the origin, 61 // regardless of type. 62 virtual void DeleteOriginData(const GURL& origin, 63 StorageType type, 64 int quota_client_mask, 65 const StatusCallback& callback) OVERRIDE; 66 67 // Helper method for updating internal quota info. 68 void SetQuota(const GURL& origin, StorageType type, int64 quota); 69 70 // Helper methods for timed-deletion testing: 71 // Adds an origin to the canned list that will be searched through via 72 // GetOriginsModifiedSince. The caller must provide |quota_client_mask| 73 // which specifies the types of QuotaClients this canned origin contains 74 // as a bitmask built from QuotaClient::IDs. 75 bool AddOrigin(const GURL& origin, 76 StorageType type, 77 int quota_client_mask, 78 base::Time modified); 79 80 // Helper methods for timed-deletion testing: 81 // Checks an origin and type against the origins that have been added via 82 // AddOrigin and removed via DeleteOriginData. If the origin exists in the 83 // canned list with the proper StorageType and client, returns true. 84 bool OriginHasData(const GURL& origin, 85 StorageType type, 86 QuotaClient::ID quota_client) const; 87 88 protected: 89 virtual ~MockQuotaManager(); 90 91 private: 92 friend class MockQuotaManagerProxy; 93 94 // Contains the essential bits of information about an origin that the 95 // MockQuotaManager needs to understand for time-based deletion: 96 // the origin itself, the StorageType and its modification time. 97 struct OriginInfo { 98 OriginInfo(const GURL& origin, 99 StorageType type, 100 int quota_client_mask, 101 base::Time modified); 102 ~OriginInfo(); 103 104 GURL origin; 105 StorageType type; 106 int quota_client_mask; 107 base::Time modified; 108 }; 109 110 // Contains the essential information for each origin for usage/quota testing. 111 // (Ideally this should probably merged into the above struct, but for 112 // regular usage/quota testing we hardly need modified time but only 113 // want to keep usage and quota information, so this struct exists. 114 struct StorageInfo { 115 StorageInfo(); 116 ~StorageInfo(); 117 int64 usage; 118 int64 quota; 119 }; 120 121 typedef std::pair<GURL, StorageType> OriginAndType; 122 typedef std::map<OriginAndType, StorageInfo> UsageAndQuotaMap; 123 124 // This must be called via MockQuotaManagerProxy. 125 void UpdateUsage(const GURL& origin, StorageType type, int64 delta); 126 void DidGetModifiedSince(const GetOriginsCallback& callback, 127 std::set<GURL>* origins, 128 StorageType storage_type); 129 void DidDeleteOriginData(const StatusCallback& callback, 130 QuotaStatusCode status); 131 132 // The list of stored origins that have been added via AddOrigin. 133 std::vector<OriginInfo> origins_; 134 UsageAndQuotaMap usage_and_quota_map_; 135 base::WeakPtrFactory<MockQuotaManager> weak_factory_; 136 137 DISALLOW_COPY_AND_ASSIGN(MockQuotaManager); 138 }; 139 140 // MockQuotaManagerProxy. 141 class MockQuotaManagerProxy : public QuotaManagerProxy { 142 public: 143 // It is ok to give NULL to |quota_manager|. 144 MockQuotaManagerProxy(MockQuotaManager* quota_manager, 145 base::SingleThreadTaskRunner* task_runner); 146 147 virtual void RegisterClient(QuotaClient* client) OVERRIDE; 148 149 void SimulateQuotaManagerDestroyed(); 150 151 // We don't mock them. 152 virtual void NotifyOriginInUse(const GURL& origin) OVERRIDE {} 153 virtual void NotifyOriginNoLongerInUse(const GURL& origin) OVERRIDE {} 154 virtual void SetUsageCacheEnabled(QuotaClient::ID client_id, 155 const GURL& origin, 156 StorageType type, 157 bool enabled) OVERRIDE {} 158 virtual void GetUsageAndQuota( 159 base::SequencedTaskRunner* original_task_runner, 160 const GURL& origin, 161 StorageType type, 162 const QuotaManager::GetUsageAndQuotaCallback& callback) OVERRIDE {} 163 164 // Validates the |client_id| and updates the internal access count 165 // which can be accessed via notify_storage_accessed_count(). 166 // The also records the |origin| and |type| in last_notified_origin_ and 167 // last_notified_type_. 168 virtual void NotifyStorageAccessed(QuotaClient::ID client_id, 169 const GURL& origin, 170 StorageType type) OVERRIDE; 171 172 // Records the |origin|, |type| and |delta| as last_notified_origin_, 173 // last_notified_type_ and last_notified_delta_ respecitvely. 174 // If non-null MockQuotaManager is given to the constructor this also 175 // updates the manager's internal usage information. 176 virtual void NotifyStorageModified(QuotaClient::ID client_id, 177 const GURL& origin, 178 StorageType type, 179 int64 delta) OVERRIDE; 180 181 int notify_storage_accessed_count() const { return storage_accessed_count_; } 182 int notify_storage_modified_count() const { return storage_modified_count_; } 183 GURL last_notified_origin() const { return last_notified_origin_; } 184 StorageType last_notified_type() const { return last_notified_type_; } 185 int64 last_notified_delta() const { return last_notified_delta_; } 186 187 protected: 188 virtual ~MockQuotaManagerProxy(); 189 190 private: 191 MockQuotaManager* mock_manager() const { 192 return static_cast<MockQuotaManager*>(quota_manager()); 193 } 194 195 int storage_accessed_count_; 196 int storage_modified_count_; 197 GURL last_notified_origin_; 198 StorageType last_notified_type_; 199 int64 last_notified_delta_; 200 201 QuotaClient* registered_client_; 202 }; 203 204 } // namespace quota 205 206 #endif // WEBKIT_BROWSER_QUOTA_MOCK_QUOTA_MANAGER_H_ 207