1 /******************************************************************************
2 *
3 * Copyright 2017 The Android Open Source Project
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at:
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 *
17 ******************************************************************************/
18
19 #include <gtest/gtest.h>
20 #include "advertise_data_parser.h"
21
TEST(AdvertiseDataParserTest,IsValidEmpty)22 TEST(AdvertiseDataParserTest, IsValidEmpty) {
23 const std::vector<uint8_t> data0;
24 EXPECT_TRUE(AdvertiseDataParser::IsValid(data0));
25
26 // Single empty field allowed (treated as zero padding).
27 const std::vector<uint8_t> data1{0x00};
28 EXPECT_TRUE(AdvertiseDataParser::IsValid(data1));
29 }
30
TEST(AdvertiseDataParserTest,IsValidBad)31 TEST(AdvertiseDataParserTest, IsValidBad) {
32 // Single field, field empty.
33 const std::vector<uint8_t> data0{0x01};
34 EXPECT_FALSE(AdvertiseDataParser::IsValid(data0));
35
36 // Single field, first field length too long.
37 const std::vector<uint8_t> data1{0x05, 0x02, 0x00, 0x00, 0x00};
38 EXPECT_FALSE(AdvertiseDataParser::IsValid(data1));
39
40 // Two fields, second field length too long.
41 const std::vector<uint8_t> data2{0x02, 0x02, 0x00, 0x02, 0x00};
42 EXPECT_FALSE(AdvertiseDataParser::IsValid(data2));
43
44 // Two fields, second field empty.
45 const std::vector<uint8_t> data3{0x02, 0x02, 0x00, 0x01};
46 EXPECT_FALSE(AdvertiseDataParser::IsValid(data3));
47
48 // Non-zero padding at end of packet.
49 const std::vector<uint8_t> data4{0x03, 0x02, 0x01, 0x02, 0x02, 0x03, 0x01,
50 0x00, 0x00, 0xBA, 0xBA, 0x00, 0x00};
51 EXPECT_FALSE(AdvertiseDataParser::IsValid(data1));
52
53 // Non-zero padding at end of packet.
54 const std::vector<uint8_t> data5{0x03, 0x02, 0x01, 0x02, 0x02,
55 0x03, 0x01, 0x00, 0xBA};
56 EXPECT_FALSE(AdvertiseDataParser::IsValid(data1));
57 }
58
TEST(AdvertiseDataParserTest,IsValidGood)59 TEST(AdvertiseDataParserTest, IsValidGood) {
60 // Single field.
61 const std::vector<uint8_t> data0{0x03, 0x02, 0x01, 0x02};
62 EXPECT_TRUE(AdvertiseDataParser::IsValid(data0));
63
64 // Two fields.
65 const std::vector<uint8_t> data1{0x03, 0x02, 0x01, 0x02, 0x02, 0x03, 0x01};
66 EXPECT_TRUE(AdvertiseDataParser::IsValid(data1));
67
68 // Zero padding at end of packet.
69 const std::vector<uint8_t> data2{0x03, 0x02, 0x01, 0x02,
70 0x02, 0x03, 0x01, 0x00};
71 EXPECT_TRUE(AdvertiseDataParser::IsValid(data2));
72
73 // zero padding at end of packet, sample data from real device
74 const std::vector<uint8_t> data3{
75 0x10, 0x096, 0x85, 0x44, 0x32, 0x04, 0x74, 0x32, 0x03, 0x13, 0x93,
76 0xa, 0x32, 0x39, 0x3a, 0x65, 0x32, 0x05, 0x12, 0x50, 0x00, 0x50,
77 0x00, 0x02, 0x0a, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
78 EXPECT_TRUE(AdvertiseDataParser::IsValid(data3));
79
80 // Test Quirk for Traxxas (bad name length, should be 0x11 is 0x14)
81 const std::vector<uint8_t> data4{0x14, 0x09, 0x54, 0x52, 0x58, 0x20,
82 0x42, 0x4C, 0x45, 0x05, 0x12, 0x60,
83 0x00, 0xE8, 0x03, 0x02, 0x0A, 0x00};
84 EXPECT_TRUE(AdvertiseDataParser::IsValid(data4));
85
86 // Test Quirk for Traxxas (bad name length, should be 0x11 is 0x14)
87 const std::vector<uint8_t> data5{0x14, 0x09, 0x54, 0x51, 0x69, 0x20,
88 0x42, 0x4C, 0x45, 0x05, 0x12, 0x64,
89 0x00, 0xE8, 0x03, 0x02, 0x0A, 0x00};
90 EXPECT_TRUE(AdvertiseDataParser::IsValid(data5));
91
92 // Test Quirk for Traxxas (bad name length, should be 0x11 is 0x14)
93 const std::vector<uint8_t> data6{0x14, 0x09, 0x54, 0x51, 0x69, 0x20,
94 0x42, 0x4C, 0x45, 0x05, 0x12, 0x60,
95 0x00, 0xE8, 0x03, 0x02, 0x0A, 0x00};
96 EXPECT_TRUE(AdvertiseDataParser::IsValid(data6));
97
98 // Test Quirk for Traxxas (bad length, should be 0x11 is 0x14)
99 // scan response glued after advertise data
100 const std::vector<uint8_t> data7{
101 0x02, 0x01, 0x06, 0x11, 0x06, 0x00, 0x00, 0x00, 0x00, 0x00,
102 0x00, 0x64, 0xB1, 0x73, 0x41, 0xE7, 0xF3, 0xC4, 0xB4, 0x80,
103 0x08, 0x14, 0x09, 0x54, 0x51, 0x69, 0x20, 0x42, 0x4C, 0x45,
104 0x05, 0x12, 0x60, 0x00, 0xE8, 0x03, 0x02, 0x0A, 0x00};
105 EXPECT_TRUE(AdvertiseDataParser::IsValid(data7));
106 }
107
TEST(AdvertiseDataParserTest,GetFieldByType)108 TEST(AdvertiseDataParserTest, GetFieldByType) {
109 // Single field.
110 const std::vector<uint8_t> data0{0x03, 0x02, 0x01, 0x02};
111
112 uint8_t p_length;
113 const uint8_t* data =
114 AdvertiseDataParser::GetFieldByType(data0, 0x02, &p_length);
115 EXPECT_EQ(data0.data() + 2, data);
116 EXPECT_EQ(2, p_length);
117
118 // Two fields, second field length too long.
119 const std::vector<uint8_t> data1{0x02, 0x02, 0x00, 0x03, 0x00};
120
121 // First field is ok.
122 data = AdvertiseDataParser::GetFieldByType(data1, 0x02, &p_length);
123 EXPECT_EQ(data1.data() + 2, data);
124 EXPECT_EQ(0x01, p_length);
125
126 // Second field have bad length.
127 data = AdvertiseDataParser::GetFieldByType(data1, 0x03, &p_length);
128 EXPECT_EQ(nullptr, data);
129 EXPECT_EQ(0, p_length);
130 }
131
132 // This test makes sure that RemoveTrailingZeros is working correctly. It does
133 // run the RemoveTrailingZeros for ad data, then glue scan response at end of
134 // it, and checks that the resulting data is good.
TEST(AdvertiseDataParserTest,RemoveTrailingZeros)135 TEST(AdvertiseDataParserTest, RemoveTrailingZeros) {
136 std::vector<uint8_t> podo_ad_data{
137 0x02, 0x01, 0x02, 0x11, 0x06, 0x66, 0x9a, 0x0c, 0x20, 0x00, 0x08,
138 0x37, 0xa8, 0xe5, 0x11, 0x81, 0x8b, 0xd0, 0xf0, 0xf0, 0xf0, 0x00,
139 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
140 std::vector<uint8_t> podo_scan_resp{
141 0x03, 0x19, 0x00, 0x80, 0x09, 0x09, 0x50, 0x6f, 0x64, 0x6f, 0x51,
142 0x35, 0x56, 0x47, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
143 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
144
145 AdvertiseDataParser::RemoveTrailingZeros(podo_ad_data);
146 AdvertiseDataParser::RemoveTrailingZeros(podo_scan_resp);
147
148 std::vector<uint8_t> glued(podo_ad_data);
149 glued.insert(glued.end(), podo_scan_resp.begin(), podo_scan_resp.end());
150
151 EXPECT_TRUE(AdvertiseDataParser::IsValid(glued));
152 }
153
154 // This test makes sure that RemoveTrailingZeros is removing all bytes after
155 // first zero length field. It does run the RemoveTrailingZeros for data with
156 // non-zero bytes after zero length field, then glue scan response at end of it,
157 // and checks that the resulting data is good. Note: specification requires all
158 // bytes after zero length field to be zero padding, but many legacy devices got
159 // this wrong, causing us to have this workaround.
TEST(AdvertiseDataParserTest,RemoveTrailingZerosMalformed)160 TEST(AdvertiseDataParserTest, RemoveTrailingZerosMalformed) {
161 std::vector<uint8_t> ad_data{0x02, 0x01, 0x02, 0x11, 0x06, 0x66, 0x9a, 0x0c,
162 0x20, 0x00, 0x08, 0x37, 0xa8, 0xe5, 0x11, 0x81,
163 0x8b, 0xd0, 0xf0, 0xf0, 0xf0, 0x00, 0xFF, 0xFF,
164 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
165 std::vector<uint8_t> scan_resp{0x03, 0x19, 0x00, 0x80, 0x09, 0x09, 0x50, 0x6f,
166 0x64, 0x6f, 0x51, 0x35, 0x56, 0x47, 0x00, 0xFF,
167 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
168 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
169
170 AdvertiseDataParser::RemoveTrailingZeros(ad_data);
171 AdvertiseDataParser::RemoveTrailingZeros(scan_resp);
172
173 std::vector<uint8_t> glued(ad_data);
174 glued.insert(glued.end(), scan_resp.begin(), scan_resp.end());
175
176 EXPECT_TRUE(AdvertiseDataParser::IsValid(glued));
177 }
178
TEST(AdvertiseDataParserTest,GetFieldByTypeInLoop)179 TEST(AdvertiseDataParserTest, GetFieldByTypeInLoop) {
180 // Single field.
181 const uint8_t AD_TYPE_SVC_DATA = 0x16;
182 const std::vector<uint8_t> data0{
183 0x02, 0x01, 0x02,
184 0x07, 0x2e, 0x6a, 0xc1, 0x19, 0x52, 0x1e, 0x49,
185 0x09, 0x16, 0x4e, 0x18, 0x00, 0xff, 0x0f, 0x03, 0x00, 0x00,
186 0x02, 0x0a, 0x7f,
187 0x03, 0x16, 0x4f, 0x18,
188 0x04, 0x16, 0x53, 0x18, 0x00,
189 0x0f, 0x09, 0x48, 0x5f, 0x43, 0x33, 0x45, 0x41, 0x31, 0x36, 0x33, 0x46, 0x35, 0x36, 0x34, 0x46 };
190
191 const uint8_t* p_service_data = data0.data();
192 uint8_t service_data_len = 0;
193
194 int match_no = 0;
195 while ((p_service_data = AdvertiseDataParser::GetFieldByType(
196 p_service_data + service_data_len,
197 data0.size() - (p_service_data - data0.data()) - service_data_len,
198 AD_TYPE_SVC_DATA, &service_data_len))) {
199 auto position = (p_service_data - data0.data());
200 if (match_no == 0) {
201 EXPECT_EQ(position, 13);
202 EXPECT_EQ(service_data_len, 8);
203 } else if (match_no == 1) {
204 EXPECT_EQ(position, 26);
205 EXPECT_EQ(service_data_len, 2);
206 } else if (match_no == 2) {
207 EXPECT_EQ(position, 30);
208 EXPECT_EQ(service_data_len, 3);
209 }
210 match_no++;
211 }
212 EXPECT_EQ(match_no, 3);
213 }