/* * Copyright 2022 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #ifndef API_FIELD_TRIALS_REGISTRY_H_ #define API_FIELD_TRIALS_REGISTRY_H_ #include #include #include "absl/strings/string_view.h" #include "api/field_trials_view.h" #include "rtc_base/containers/flat_set.h" #include "rtc_base/system/rtc_export.h" namespace webrtc { // Abstract base class for a field trial registry that verifies that any looked // up key has been pre-registered in accordance with `g3doc/field-trials.md`. class RTC_EXPORT FieldTrialsRegistry : public FieldTrialsView { public: FieldTrialsRegistry() = default; FieldTrialsRegistry(const FieldTrialsRegistry&) = default; FieldTrialsRegistry& operator=(const FieldTrialsRegistry&) = default; ~FieldTrialsRegistry() override = default; // Verifies that `key` is a registered field trial and then returns the // configured value for `key` or an empty string if the field trial isn't // configured. std::string Lookup(absl::string_view key) const override; // Register additional `keys` for testing. This should only be used for // imaginary keys that are never used outside test code. void RegisterKeysForTesting(flat_set keys) { test_keys_ = std::move(keys); } private: virtual std::string GetValue(absl::string_view key) const = 0; // Imaginary keys only used for testing. flat_set test_keys_; }; } // namespace webrtc #endif // API_FIELD_TRIALS_REGISTRY_H_