// Copyright (c) 2010 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 CHROME_BROWSER_CHROMEOS_EXTERNAL_METRICS_H_ #define CHROME_BROWSER_CHROMEOS_EXTERNAL_METRICS_H_ #include "base/basictypes.h" #include "base/compiler_specific.h" #include "base/file_path.h" #include "base/hash_tables.h" #include "base/task.h" #include "testing/gtest/include/gtest/gtest_prod.h" // For FRIEND_TEST namespace chromeos { // ExternalMetrics is a service that Chrome offers to Chrome OS to upload // metrics to the UMA server on its behalf. Chrome periodically reads the // content of a well-know file, and parses it into name-value pairs, each // representing a Chrome OS metrics event. The events are logged using the // normal UMA mechanism. The file is then truncated to zero size. Chrome uses // flock() to synchronize accesses to the file. class ExternalMetrics : public base::RefCountedThreadSafe { FRIEND_TEST(ExternalMetricsTest, ParseExternalMetricsFile); friend class base::RefCountedThreadSafe; public: ExternalMetrics() : test_recorder_(NULL) {} // Begins the external data collection. This service is started and stopped // by the chrome metrics service. Calls to RecordAction originate in the // File thread but are executed in the UI thread. void Start(); private: // There is one function with this type for each action. typedef void (*RecordFunctionType)(); typedef void (*RecorderType)(const char*, const char*); // For testing only. // The max length of a message (name-value pair, plus header) static const int kMetricsMessageMaxLength = 1024; // be generous ~ExternalMetrics() {} // Registers a user action by associating the action name with a function // that records instances of that action. void DefineUserAction(const std::string& name, RecordFunctionType f); // Registers all user actions external to the browser. void InitializeUserActions(); // Passes an action event to the UMA service on the UI thread. void RecordActionUI(std::string action_string); // Passes an action event to the UMA service. void RecordAction(const char* action_name); // Passes an histogram event to the UMA service. |histogram_data| is in the // form . void RecordHistogram(const char* histogram_data); // Passes a linear histogram event to the UMA service. |histogram_data| is // in the form . void RecordLinearHistogram(const char* histogram_data); // Collects external events from metrics log file. This is run at periodic // intervals. void CollectEvents(); // Calls CollectEvents and reschedules a future collection. void CollectEventsAndReschedule(); // Schedules a metrics event collection in the future. void ScheduleCollector(); // Maps histogram or action names to recorder structs. base::hash_map action_recorders_; // Used for testing only. RecorderType test_recorder_; FilePath test_path_; DISALLOW_COPY_AND_ASSIGN(ExternalMetrics); }; } // namespace chromeos #endif // CHROME_BROWSER_CHROMEOS_EXTERNAL_METRICS_H_