mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2025-12-29 01:50:53 +00:00
This checks boot key combination like Power-F3-ESC and Power-F3-Down can be properly detected. BUG=chrome-os-partner:19236 TEST=Pass kb_scan test BRANCH=None Change-Id: I180918977299219a8421798dac2ab9fed84ef9a2 Signed-off-by: Vic Yang <victoryang@chromium.org> Reviewed-on: https://chromium-review.googlesource.com/167802
169 lines
3.9 KiB
C
169 lines
3.9 KiB
C
/* Copyright (c) 2013 The Chromium OS Authors. All rights reserved.
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
/* Various utility for unit testing */
|
|
|
|
#ifndef __CROS_EC_TEST_UTIL_H
|
|
#define __CROS_EC_TEST_UTIL_H
|
|
|
|
#include "common.h"
|
|
#include "console.h"
|
|
|
|
#define RUN_TEST(n) \
|
|
do { \
|
|
ccprintf("Running %s...", #n); \
|
|
cflush(); \
|
|
if (n() == EC_SUCCESS) { \
|
|
ccputs("OK\n"); \
|
|
} else { \
|
|
ccputs("Fail\n"); \
|
|
__test_error_count++; \
|
|
} \
|
|
} while (0)
|
|
|
|
#define TEST_ASSERT(n) \
|
|
do { \
|
|
if (!(n)) { \
|
|
ccprintf("%d: ASSERTION failed: %s\n", __LINE__, #n); \
|
|
return EC_ERROR_UNKNOWN; \
|
|
} \
|
|
} while (0)
|
|
|
|
#define __ABS(n) ((n) > 0 ? (n) : -(n))
|
|
|
|
#define TEST_ASSERT_ABS_LESS(n, t) \
|
|
do { \
|
|
if (__ABS(n) >= t) { \
|
|
ccprintf("%d: ASSERT_ABS_LESS failed: abs(%d) is " \
|
|
"not less than %d\n", __LINE__, n, t); \
|
|
return EC_ERROR_UNKNOWN; \
|
|
} \
|
|
} while (0)
|
|
|
|
#define TEST_ASSERT_ARRAY_EQ(s, d, n) \
|
|
do { \
|
|
int __i; \
|
|
for (__i = 0; __i < n; ++__i) \
|
|
if ((s)[__i] != (d)[__i]) { \
|
|
ccprintf("%d: ASSERT_ARRAY_EQ failed at " \
|
|
"index=%d: %d != %d\n", __LINE__, \
|
|
__i, (int)(s)[__i], (int)(d)[__i]); \
|
|
return EC_ERROR_UNKNOWN; \
|
|
} \
|
|
} while (0)
|
|
|
|
#define TEST_CHECK(n) \
|
|
do { \
|
|
if (n) \
|
|
return EC_SUCCESS; \
|
|
else \
|
|
return EC_ERROR_UNKNOWN; \
|
|
} while (0)
|
|
|
|
/* Mutlistep test states */
|
|
enum test_state_t {
|
|
TEST_STATE_STEP_1 = 0,
|
|
TEST_STATE_STEP_2,
|
|
TEST_STATE_STEP_3,
|
|
TEST_STATE_STEP_4,
|
|
TEST_STATE_STEP_5,
|
|
TEST_STATE_STEP_6,
|
|
TEST_STATE_STEP_7,
|
|
TEST_STATE_STEP_8,
|
|
TEST_STATE_STEP_9,
|
|
TEST_STATE_PASSED,
|
|
TEST_STATE_FAILED,
|
|
};
|
|
#define TEST_STATE_MASK(x) (1 << (x))
|
|
|
|
/* Hooks gcov_flush() for test coverage report generation */
|
|
void register_test_end_hook(void);
|
|
|
|
/*
|
|
* Test initialization. This is called after all _pre_init() calls and before
|
|
* all _init() calls.
|
|
*/
|
|
void test_init(void);
|
|
|
|
/* Test entry point */
|
|
void run_test(void);
|
|
|
|
/* Resets test error count */
|
|
void test_reset(void);
|
|
|
|
/* Reports test pass */
|
|
void test_pass(void);
|
|
|
|
/* Reports test failure */
|
|
void test_fail(void);
|
|
|
|
/* Prints test result, including number of failed tests */
|
|
void test_print_result(void);
|
|
|
|
/* Returns the number of failed tests */
|
|
int test_get_error_count(void);
|
|
|
|
/* Simulates host command sent from the host */
|
|
int test_send_host_command(int command, int version, const void *params,
|
|
int params_size, void *resp, int resp_size);
|
|
|
|
/* Number of failed tests */
|
|
extern int __test_error_count;
|
|
|
|
/* Simulates UART input */
|
|
void uart_inject_char(char *s, int sz);
|
|
|
|
#define UART_INJECT(s) uart_inject_char(s, strlen(s));
|
|
|
|
/* Simulates chipset power on */
|
|
void test_chipset_on(void);
|
|
|
|
/* Simulates chipset power off */
|
|
void test_chipset_off(void);
|
|
|
|
/* Start/stop capturing console output */
|
|
void test_capture_console(int enabled);
|
|
|
|
/* Get captured console output */
|
|
const char *test_get_captured_console(void);
|
|
|
|
/*
|
|
* Flush emulator status. Must be called before emulator reboots or
|
|
* exits.
|
|
*/
|
|
void emulator_flush(void);
|
|
|
|
/*
|
|
* Entry point of multi-step test.
|
|
*
|
|
* Depending on current test state, this function runs the corresponding
|
|
* test step. This function should be called in a dedicated task on every
|
|
* reboot. Also, run_test() is responsible for starting the test by kicking
|
|
* that task.
|
|
*/
|
|
void test_run_multistep(void);
|
|
|
|
/*
|
|
* A function that runs the test step specified in 'state'. This function
|
|
* should be defined by all multi-step tests.
|
|
*
|
|
* @param state TEST_STATE_MASK(x) indicating the step to run.
|
|
*/
|
|
void test_run_step(uint32_t state);
|
|
|
|
/* Get the current test state */
|
|
uint32_t test_get_state(void);
|
|
|
|
/*
|
|
* Multistep test clean up. If a multi-step test has this function defined,
|
|
* it will be called on test end. (i.e. when test passes or fails.)
|
|
*/
|
|
void test_clean_up(void);
|
|
|
|
/* Set the next step and reboot */
|
|
void test_reboot_to_next_step(enum test_state_t step);
|
|
|
|
#endif /* __CROS_EC_TEST_UTIL_H */
|