Index: google_apis/gcm/gcm_stats_recorder.h |
diff --git a/google_apis/gcm/gcm_stats_recorder.h b/google_apis/gcm/gcm_stats_recorder.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..19d188ec7b23fce5b59cc89b5ece796ca0206197 |
--- /dev/null |
+++ b/google_apis/gcm/gcm_stats_recorder.h |
@@ -0,0 +1,165 @@ |
+// Copyright 2014 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 GOOGLE_APIS_GCM_GCM_STATS_RECORDER_H_ |
+#define GOOGLE_APIS_GCM_GCM_STATS_RECORDER_H_ |
+ |
+#include <deque> |
+#include <map> |
jianli
2014/03/18 23:53:23
not used
juyik
2014/03/20 01:09:53
Done.
|
+#include <string> |
+#include <vector> |
+ |
+#include "base/compiler_specific.h" |
+#include "base/memory/ref_counted.h" |
+#include "base/memory/weak_ptr.h" |
+#include "base/stl_util.h" |
jianli
2014/03/18 23:53:23
not used?
juyik
2014/03/20 01:09:53
Done.
|
+#include "base/time/time.h" |
+#include "google_apis/gcm/base/gcm_export.h" |
+ |
+namespace gcm { |
+ |
+// Records GCM internal stats and activities for debugging purpose. Recording |
+// can be turned on/off by calling SetRecording(...) function. It is turned off |
+// by default. |
+// This class is not thread safe. It is meant to be owned by a gcm client |
+// instance. |
+class GCM_EXPORT GCMStatsRecorder { |
fgorski
2014/03/18 21:28:37
Tests for recorder?
juyik
2014/03/20 01:09:53
Done.
|
+ public: |
+ // Type of the activity. Each activity is one step in a larger operation ( |
+ // register, send, receive, etc). |
+ // Any change made to this enum must propagate to GetTypeString() function. |
+ enum ActivityType { |
+ Initiated, // First attempt of an operation. |
+ RetryRequested, // A retry of the operation is requested. |
+ Retry, // The retry of the operation is actually starting. |
+ Success, // The operation has completed successfully. |
+ Intermediate, // The activity is an intermediate step of an operation. |
+ Failure, // The operation has failed; no more retries. |
+ Error, // The operation encountered an error. |
+ }; |
+ |
+ // Contains data that are common to all activity kinds below. |
+ struct GCM_EXPORT Activity { |
+ Activity(); |
+ virtual ~Activity(); |
+ std::string GetTypeString() const; |
+ |
+ base::Time time; |
+ ActivityType type; |
+ std::string details; // Any additional detail about this activity. |
+ }; |
+ |
+ // Contains relevant data of a check-in step. |
+ struct GCM_EXPORT CheckinActivity : Activity { |
+ CheckinActivity(); |
+ virtual ~CheckinActivity() OVERRIDE; |
+ |
+ uint64 android_id; |
+ }; |
+ |
+ // Contains relevant data of a register step. |
+ struct GCM_EXPORT RegisterActivity : Activity { |
+ RegisterActivity(); |
+ virtual ~RegisterActivity() OVERRIDE; |
+ |
+ std::string app_id; |
+ std::string sender_id; |
+ }; |
+ |
+ // Contains relevant data of a send-message step. |
+ struct GCM_EXPORT SendMessageActivity : Activity { |
+ SendMessageActivity(); |
+ virtual ~SendMessageActivity() OVERRIDE; |
+ |
+ std::string app_id; |
+ std::string receiver_id; |
+ std::string message_id; |
+ uint64 message_len; // Sent message's length in bytes. |
+ }; |
+ |
+ // Contains relevant data of a receive-message step. |
+ struct GCM_EXPORT ReceiveMessageActivity : Activity { |
+ ReceiveMessageActivity(); |
+ virtual ~ReceiveMessageActivity() OVERRIDE; |
+ |
+ std::string sender_id; |
+ std::string app_id; |
+ int message_size; // The number of key-value pairs in received message. |
+ }; |
+ |
+ GCMStatsRecorder(); |
+ virtual ~GCMStatsRecorder(); |
+ |
+ // Indicates whether the recorder is currently recording activities or not. |
+ bool IsRecording() const { |
jianli
2014/03/18 23:53:23
nit: this can be exposed as getter: bool is_record
juyik
2014/03/20 01:09:53
Done.
|
+ return is_recording_; |
+ } |
+ |
+ // Turns recording on/off. |
+ void SetRecording(bool recording); |
+ |
+ // Clear all recorded activities. |
+ void Clear(); |
+ |
+ // Record a checkin activity. |
+ void RecordCheckin(uint64 android_id, ActivityType type); |
+ |
+ // Record a register activity. |
+ void RecordRegister(const std::string& app_id, |
jianli
2014/03/18 23:53:23
RecordRegistration?
juyik
2014/03/20 01:09:53
Will do in my future patch. Splitting this part of
|
+ ActivityType type, |
+ const std::vector<std::string>& sender_id); |
+ void RecordRegisterWithStatus(const std::string& app_id, |
fgorski
2014/03/18 21:28:37
For this and most of the other methods. Consider p
juyik
2014/03/20 01:09:53
I thought about it a little and I felt that the So
|
+ ActivityType type, |
+ const std::vector<std::string>& sender_id, |
+ std::string status); |
jianli
2014/03/18 23:53:23
It would be better to combine both RecordRegister*
juyik
2014/03/20 01:09:53
Will do in my future patch. Splitting this part of
|
+ |
+ // Record a send activity. |
+ void RecordSend(const std::string& app_id, |
jianli
2014/03/18 23:53:23
RecordSending?
juyik
2014/03/20 01:09:53
Done.
|
+ ActivityType type, |
+ const std::string& receiver_id, |
+ const std::string& message_id, |
+ uint64 msg_len); |
+ void RecordSendWithDetails(const std::string& app_id, |
+ ActivityType type, |
+ const std::string& receiver_id, |
+ const std::string& message_id, |
+ uint64 msg_len, |
+ const std::string& details); |
+ |
+ // Record a receive activity. |
+ void RecordReceiveDataMessage(const std::string& sender_id, |
+ const std::string& app_id, |
+ int message_size); |
+ void RecordReceiveWithDetails(ActivityType type, |
+ const std::string& sender_id, |
+ const std::string& app_id, |
+ const std::string& details); |
+ |
+ const std::deque<CheckinActivity>& CheckinActivities() const { |
jianli
2014/03/18 23:53:23
ditto for all these 4 methods
juyik
2014/03/20 01:09:53
Done for sending. Will do the rest in my future pa
|
+ return checkin_activities_; |
+ } |
+ const std::deque<RegisterActivity>& RegisterActivities() const { |
+ return register_activities_; |
+ } |
+ const std::deque<SendMessageActivity>& SendMessageActivities() const { |
+ return send_activities_; |
+ } |
+ const std::deque<ReceiveMessageActivity>& ReceiveMessageActivities() const { |
+ return receive_activities_; |
+ } |
+ |
+ private: |
+ bool is_recording_; |
+ |
+ std::deque<CheckinActivity> checkin_activities_; |
+ std::deque<RegisterActivity> register_activities_; |
+ std::deque<SendMessageActivity> send_activities_; |
+ std::deque<ReceiveMessageActivity> receive_activities_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(GCMStatsRecorder); |
+}; |
+ |
+} // namespace gcm |
+ |
+#endif // GOOGLE_APIS_GCM_GCM_STATS_RECORDER_H_ |