| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 // FieldTrial is a class for handling details of statistical experiments | 5 // FieldTrial is a class for handling details of statistical experiments |
| 6 // performed by actual users in the field (i.e., in a shipped or beta product). | 6 // performed by actual users in the field (i.e., in a shipped or beta product). |
| 7 // All code is called exclusively on the UI thread currently. | 7 // All code is called exclusively on the UI thread currently. |
| 8 // | 8 // |
| 9 // The simplest example is an experiment to see whether one of two options | 9 // The simplest example is an experiment to see whether one of two options |
| 10 // produces "better" results across our user population. In that scenario, UMA | 10 // produces "better" results across our user population. In that scenario, UMA |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 52 //------------------------------------------------------------------------------ | 52 //------------------------------------------------------------------------------ |
| 53 | 53 |
| 54 #ifndef BASE_METRICS_FIELD_TRIAL_H_ | 54 #ifndef BASE_METRICS_FIELD_TRIAL_H_ |
| 55 #define BASE_METRICS_FIELD_TRIAL_H_ | 55 #define BASE_METRICS_FIELD_TRIAL_H_ |
| 56 | 56 |
| 57 #include <map> | 57 #include <map> |
| 58 #include <string> | 58 #include <string> |
| 59 #include <vector> | 59 #include <vector> |
| 60 | 60 |
| 61 #include "base/base_export.h" | 61 #include "base/base_export.h" |
| 62 #include "base/callback_forward.h" |
| 62 #include "base/gtest_prod_util.h" | 63 #include "base/gtest_prod_util.h" |
| 63 #include "base/memory/ref_counted.h" | 64 #include "base/memory/ref_counted.h" |
| 64 #include "base/observer_list_threadsafe.h" | 65 #include "base/observer_list_threadsafe.h" |
| 65 #include "base/synchronization/lock.h" | 66 #include "base/synchronization/lock.h" |
| 66 #include "base/time/time.h" | 67 #include "base/time/time.h" |
| 67 | 68 |
| 68 namespace base { | 69 namespace base { |
| 69 | 70 |
| 70 class FieldTrialList; | 71 class FieldTrialList; |
| 71 | 72 |
| (...skipping 210 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 282 | 283 |
| 283 DISALLOW_COPY_AND_ASSIGN(FieldTrial); | 284 DISALLOW_COPY_AND_ASSIGN(FieldTrial); |
| 284 }; | 285 }; |
| 285 | 286 |
| 286 //------------------------------------------------------------------------------ | 287 //------------------------------------------------------------------------------ |
| 287 // Class with a list of all active field trials. A trial is active if it has | 288 // Class with a list of all active field trials. A trial is active if it has |
| 288 // been registered, which includes evaluating its state based on its probaility. | 289 // been registered, which includes evaluating its state based on its probaility. |
| 289 // Only one instance of this class exists. | 290 // Only one instance of this class exists. |
| 290 class BASE_EXPORT FieldTrialList { | 291 class BASE_EXPORT FieldTrialList { |
| 291 public: | 292 public: |
| 293 // A callback that returns true if |name| describes a field trial that should |
| 294 // be accepted by the method it was passed to. |
| 295 typedef base::Callback<bool(const std::string& name)> |
| 296 IsAcceptedFieldTrialCallback; |
| 297 |
| 292 // Specifies whether field trials should be activated (marked as "used"), when | 298 // Specifies whether field trials should be activated (marked as "used"), when |
| 293 // created using |CreateTrialsFromString()|. | 299 // created using |CreateTrialsFromString()|. |
| 294 enum FieldTrialActivationMode { | 300 enum FieldTrialActivationMode { |
| 295 DONT_ACTIVATE_TRIALS, | 301 DONT_ACTIVATE_TRIALS, |
| 296 ACTIVATE_TRIALS, | 302 ACTIVATE_TRIALS, |
| 297 }; | 303 }; |
| 298 | 304 |
| 299 // Define a separator character to use when creating a persistent form of an | 305 // Define a separator character to use when creating a persistent form of an |
| 300 // instance. This is intended for use as a command line argument, passed to a | 306 // instance. This is intended for use as a command line argument, passed to a |
| 301 // second process to mimic our state (i.e., provide the same group name). | 307 // second process to mimic our state (i.e., provide the same group name). |
| (...skipping 103 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 405 static void GetActiveFieldTrialGroups( | 411 static void GetActiveFieldTrialGroups( |
| 406 FieldTrial::ActiveGroups* active_groups); | 412 FieldTrial::ActiveGroups* active_groups); |
| 407 | 413 |
| 408 // Use a state string (re: StatesToString()) to augment the current list of | 414 // Use a state string (re: StatesToString()) to augment the current list of |
| 409 // field trials to include the supplied trials, and using a 100% probability | 415 // field trials to include the supplied trials, and using a 100% probability |
| 410 // for each trial, force them to have the same group string. This is commonly | 416 // for each trial, force them to have the same group string. This is commonly |
| 411 // used in a non-browser process, to carry randomly selected state in a | 417 // used in a non-browser process, to carry randomly selected state in a |
| 412 // browser process into this non-browser process, but could also be invoked | 418 // browser process into this non-browser process, but could also be invoked |
| 413 // through a command line argument to the browser process. The created field | 419 // through a command line argument to the browser process. The created field |
| 414 // trials are marked as "used" for the purposes of active trial reporting if | 420 // trials are marked as "used" for the purposes of active trial reporting if |
| 415 // |mode| is ACTIVATE_TRIALS. | 421 // |mode| is ACTIVATE_TRIALS. If |is_accepted_callback| is not null: field |
| 416 static bool CreateTrialsFromString(const std::string& prior_trials, | 422 // trials for which |is_accepted_callback| returns false are ignored. |
| 417 FieldTrialActivationMode mode); | 423 static bool CreateTrialsFromString( |
| 424 const std::string& prior_trials, |
| 425 FieldTrialActivationMode mode, |
| 426 const IsAcceptedFieldTrialCallback& is_accepted_callback); |
| 418 | 427 |
| 419 // Create a FieldTrial with the given |name| and using 100% probability for | 428 // Create a FieldTrial with the given |name| and using 100% probability for |
| 420 // the FieldTrial, force FieldTrial to have the same group string as | 429 // the FieldTrial, force FieldTrial to have the same group string as |
| 421 // |group_name|. This is commonly used in a non-browser process, to carry | 430 // |group_name|. This is commonly used in a non-browser process, to carry |
| 422 // randomly selected state in a browser process into this non-browser process. | 431 // randomly selected state in a browser process into this non-browser process. |
| 423 // It returns NULL if there is a FieldTrial that is already registered with | 432 // It returns NULL if there is a FieldTrial that is already registered with |
| 424 // the same |name| but has different finalized group string (|group_name|). | 433 // the same |name| but has different finalized group string (|group_name|). |
| 425 static FieldTrial* CreateFieldTrial(const std::string& name, | 434 static FieldTrial* CreateFieldTrial(const std::string& name, |
| 426 const std::string& group_name); | 435 const std::string& group_name); |
| 427 | 436 |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 474 | 483 |
| 475 // List of observers to be notified when a group is selected for a FieldTrial. | 484 // List of observers to be notified when a group is selected for a FieldTrial. |
| 476 scoped_refptr<ObserverListThreadSafe<Observer> > observer_list_; | 485 scoped_refptr<ObserverListThreadSafe<Observer> > observer_list_; |
| 477 | 486 |
| 478 DISALLOW_COPY_AND_ASSIGN(FieldTrialList); | 487 DISALLOW_COPY_AND_ASSIGN(FieldTrialList); |
| 479 }; | 488 }; |
| 480 | 489 |
| 481 } // namespace base | 490 } // namespace base |
| 482 | 491 |
| 483 #endif // BASE_METRICS_FIELD_TRIAL_H_ | 492 #endif // BASE_METRICS_FIELD_TRIAL_H_ |
| OLD | NEW |