Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 5739d2b8 authored by nelsonli's avatar nelsonli Committed by Nelson Li
Browse files

[vts-core] add VtsHalIrV1_0TargetTest to vts-core

Convert VtsHalIrV1_0TargetTest to be parameterized test
and add it to vts-core

Bug: 142397658
Bug: 143195812
Test: $ atest VtsHalIrV1_0TargetTest
Change-Id: Iced511be1f08e790715ec25fe66c30c4609ed6fe
parent 475414d8
Loading
Loading
Loading
Loading
+1 −1
Original line number Original line Diff line number Diff line
@@ -21,5 +21,5 @@ cc_test {
    static_libs: [
    static_libs: [
        "android.hardware.ir@1.0",
        "android.hardware.ir@1.0",
    ],
    ],
    test_suites: ["general-tests"],
    test_suites: ["general-tests", "vts-core"],
}
}
+11 −30
Original line number Original line Diff line number Diff line
@@ -21,8 +21,9 @@
#include <android/hardware/ir/1.0/IConsumerIr.h>
#include <android/hardware/ir/1.0/IConsumerIr.h>
#include <android/hardware/ir/1.0/types.h>
#include <android/hardware/ir/1.0/types.h>


#include <VtsHalHidlTargetTestBase.h>
#include <gtest/gtest.h>
#include <VtsHalHidlTargetTestEnvBase.h>
#include <hidl/GtestPrinter.h>
#include <hidl/ServiceManagement.h>
#include <algorithm>
#include <algorithm>


using ::android::hardware::ir::V1_0::IConsumerIr;
using ::android::hardware::ir::V1_0::IConsumerIr;
@@ -31,26 +32,10 @@ using ::android::hardware::hidl_vec;
using ::android::hardware::Return;
using ::android::hardware::Return;
using ::android::sp;
using ::android::sp;


// Test environment for Ir
class ConsumerIrHidlTest : public ::testing::TestWithParam<std::string> {
class ConsumerIrHidlEnvironment : public ::testing::VtsHalHidlTargetTestEnvBase {
 public:
  // get the test environment singleton
  static ConsumerIrHidlEnvironment* Instance() {
    static ConsumerIrHidlEnvironment* instance = new ConsumerIrHidlEnvironment;
    return instance;
  }

  virtual void registerTestServices() override { registerTestService<IConsumerIr>(); }
 private:
  ConsumerIrHidlEnvironment() {}
};

// The main test class for IR HIDL HAL.
class ConsumerIrHidlTest : public ::testing::VtsHalHidlTargetTestBase {
 public:
 public:
  virtual void SetUp() override {
  virtual void SetUp() override {
    ir = ::testing::VtsHalHidlTargetTestBase::getService<IConsumerIr>(
    ir = IConsumerIr::getService(GetParam());
      ConsumerIrHidlEnvironment::Instance()->getServiceName<IConsumerIr>());
    ASSERT_NE(ir, nullptr);
    ASSERT_NE(ir, nullptr);
  }
  }


@@ -60,7 +45,7 @@ class ConsumerIrHidlTest : public ::testing::VtsHalHidlTargetTestBase {
};
};


// Test transmit() for the min and max frequency of every available range
// Test transmit() for the min and max frequency of every available range
TEST_F(ConsumerIrHidlTest, TransmitTest) {
TEST_P(ConsumerIrHidlTest, TransmitTest) {
  bool success;
  bool success;
  hidl_vec<ConsumerIrFreqRange> ranges;
  hidl_vec<ConsumerIrFreqRange> ranges;
  auto cb = [&](bool s, hidl_vec<ConsumerIrFreqRange> v) {
  auto cb = [&](bool s, hidl_vec<ConsumerIrFreqRange> v) {
@@ -84,7 +69,7 @@ TEST_F(ConsumerIrHidlTest, TransmitTest) {
}
}


// Test transmit() when called with invalid frequencies
// Test transmit() when called with invalid frequencies
TEST_F(ConsumerIrHidlTest, BadFreqTest) {
TEST_P(ConsumerIrHidlTest, BadFreqTest) {
  uint32_t len = 16;
  uint32_t len = 16;
  hidl_vec<int32_t> vec;
  hidl_vec<int32_t> vec;
  vec.resize(len);
  vec.resize(len);
@@ -92,11 +77,7 @@ TEST_F(ConsumerIrHidlTest, BadFreqTest) {
  EXPECT_FALSE(ir->transmit(-1, vec));
  EXPECT_FALSE(ir->transmit(-1, vec));
}
}


int main(int argc, char **argv) {
INSTANTIATE_TEST_SUITE_P(
  ::testing::AddGlobalTestEnvironment(ConsumerIrHidlEnvironment::Instance());
        PerInstance, ConsumerIrHidlTest,
  ::testing::InitGoogleTest(&argc, argv);
        testing::ValuesIn(android::hardware::getAllHalInstanceNames(IConsumerIr::descriptor)),
  ConsumerIrHidlEnvironment::Instance()->init(&argc, argv);
        android::hardware::PrintInstanceNameToString);
  int status = RUN_ALL_TESTS();
  LOG(INFO) << "Test result = " << status;
  return status;
}