| // Copyright 2017 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| #include "remoting/base/weighted_samples.h" |
| #include "testing/gtest/include/gtest/gtest.h" |
| TEST(WeightedSamplesTest, CalculateWeightedAverage) { |
| static constexpr double kWeightFactor = 0.9; |
| static constexpr double kExpected[] = { |
| WeightedSamples samples(kWeightFactor); |
| for (size_t i = 0; i < std::size(kExpected); i++) { |
| EXPECT_DOUBLE_EQ(kExpected[i], samples.WeightedAverage()); |
| TEST(WeightedSamplesTest, CalculateWeightedAverage_SameValues) { |
| WeightedSamples samples(0.9); |
| for (int i = 0; i < 100; i++) { |
| EXPECT_EQ(samples.WeightedAverage(), 100); |
| TEST(WeightedSamplesTest, ReturnZeroIfNoRecords) { |
| WeightedSamples samples(0.9); |
| EXPECT_EQ(samples.WeightedAverage(), 0); |