/*
* Copyright (C) 2016 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "ranged_converter.h"
#include <gmock/gmock.h>
#include <gtest/gtest.h>
#include "converter_interface_mock.h"
using testing::Return;
using testing::SetArgPointee;
using testing::Test;
using testing::_;
namespace v4l2_camera_hal {
class RangedConverterTest : public Test {
protected:
virtual void SetUp() {
converter_.reset(new ConverterInterfaceMock<int, int32_t>());
dut_.reset(
new RangedConverter<int, int32_t>(converter_, min_, max_, step_));
}
virtual void ExpectConvert(int32_t converted, int32_t expected) {
int initial = 99;
EXPECT_CALL(*converter_, MetadataToV4L2(initial, _))
.WillOnce(DoAll(SetArgPointee<1>(converted), Return(0)));
int32_t actual = expected + 1; // Initialize to non-expected value.
ASSERT_EQ(dut_->MetadataToV4L2(initial, &actual), 0);
EXPECT_EQ(actual, expected);
}
std::shared_ptr<ConverterInterfaceMock<int, int32_t>> converter_;
std::unique_ptr<RangedConverter<int, int32_t>> dut_;
const int32_t min_ = -11;
const int32_t max_ = 10;
const int32_t step_ = 3;
};
TEST_F(RangedConverterTest, NormalConversion) {
// A value that's in range and on step.
ExpectConvert(max_ - step_, max_ - step_);
}
TEST_F(RangedConverterTest, RoundingConversion) {
// A value that's in range but off step.
ExpectConvert(max_ - step_ + 1, max_ - step_);
}
TEST_F(RangedConverterTest, ClampUpConversion) {
// A value that's below range.
ExpectConvert(min_ - 1, min_);
}
TEST_F(RangedConverterTest, ClampDownConversion) {
// A value that's above range (even after fitting to step).
ExpectConvert(max_ + step_, max_);
}
TEST_F(RangedConverterTest, ConversionError) {
int initial = 99;
int err = -99;
EXPECT_CALL(*converter_, MetadataToV4L2(initial, _)).WillOnce(Return(err));
int32_t unused;
EXPECT_EQ(dut_->MetadataToV4L2(initial, &unused), err);
}
} // namespace v4l2_camera_hal