blob: 4993147dcb33972e819ae17678626cf012a4f06e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
/* 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.
*
* Test lid switch.
*/
#include "common.h"
#include "console.h"
#include "hooks.h"
#include "host_command.h"
#include "lid_switch.h"
#include "timer.h"
#include "util.h"
static int error_count;
static int mock_lid;
static int lid_hook_count;
#define RUN_TEST(n) \
do { \
ccprintf("Running %s...", #n); \
cflush(); \
if (n() == EC_SUCCESS) { \
ccputs("OK\n"); \
} else { \
ccputs("Fail\n"); \
error_count++; \
} \
} while (0)
#define TEST_ASSERT(n) \
do { \
if (!(n)) \
return EC_ERROR_UNKNOWN; \
} while (0)
int gpio_get_level(enum gpio_signal signal)
{
if (signal == GPIO_LID_OPEN)
return mock_lid;
return 0;
}
static void lid_change_hook(void)
{
lid_hook_count++;
}
DECLARE_HOOK(HOOK_LID_CHANGE, lid_change_hook, HOOK_PRIO_DEFAULT);
static int test_hook(void)
{
/* Close lid for testing */
mock_lid = 0;
lid_interrupt(GPIO_LID_OPEN);
msleep(100);
lid_hook_count = 0;
host_clear_events(0xffffffff);
mock_lid = 1;
lid_interrupt(GPIO_LID_OPEN);
msleep(50);
TEST_ASSERT(lid_hook_count == 1);
TEST_ASSERT(lid_is_open());
TEST_ASSERT(host_get_events() &
EC_HOST_EVENT_MASK(EC_HOST_EVENT_LID_OPEN));
mock_lid = 0;
lid_interrupt(GPIO_LID_OPEN);
msleep(50);
TEST_ASSERT(lid_hook_count == 2);
TEST_ASSERT(!lid_is_open());
TEST_ASSERT(host_get_events() &
EC_HOST_EVENT_MASK(EC_HOST_EVENT_LID_CLOSED));
return EC_SUCCESS;
}
static int test_debounce(void)
{
/* Close lid for testing */
mock_lid = 0;
lid_interrupt(GPIO_LID_OPEN);
msleep(100);
lid_hook_count = 0;
host_clear_events(0xffffffff);
mock_lid = 1;
lid_interrupt(GPIO_LID_OPEN);
msleep(20);
TEST_ASSERT(lid_hook_count == 0);
TEST_ASSERT(!lid_is_open());
TEST_ASSERT(!(host_get_events() &
EC_HOST_EVENT_MASK(EC_HOST_EVENT_LID_OPEN)));
mock_lid = 0;
lid_interrupt(GPIO_LID_OPEN);
msleep(50);
TEST_ASSERT(lid_hook_count == 0);
TEST_ASSERT(!lid_is_open());
TEST_ASSERT(!(host_get_events() &
EC_HOST_EVENT_MASK(EC_HOST_EVENT_LID_OPEN)));
return EC_SUCCESS;
}
void run_test(void)
{
error_count = 0;
RUN_TEST(test_hook);
RUN_TEST(test_debounce);
if (error_count)
ccprintf("Fail!\n", error_count);
else
ccprintf("Pass!\n");
}
static int command_run_test(int argc, char **argv)
{
run_test();
return EC_SUCCESS;
}
DECLARE_CONSOLE_COMMAND(runtest, command_run_test,
NULL, NULL, NULL);
|