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
|
/* Copyright (c) 2019, MariaDB
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; version 2 of the License.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
/**
@file
Unit tests for serialization and deserialization functions
*/
#include "tap.h"
#include "my_byteorder.h"
#include "myisampack.h"
#include "m_string.h"
void test_byte_order()
{
MY_ALIGNED(CPU_LEVEL1_DCACHE_LINESIZE)
uchar buf[CPU_LEVEL1_DCACHE_LINESIZE * 2];
uchar *aligned= buf;
uchar *not_aligned= buf + CPU_LEVEL1_DCACHE_LINESIZE - 1;
#define TEST(STORE_NAME, LOAD_NAME, TYPE, VALUE, BYTES) \
{ \
TYPE value= VALUE; \
uchar bytes[]= BYTES; \
STORE_NAME(aligned, value); \
ok(!memcmp(aligned, bytes, sizeof(bytes)), "aligned\t\t" #STORE_NAME); \
ok(LOAD_NAME(aligned) == value, "aligned\t\t" #LOAD_NAME); \
STORE_NAME(not_aligned, value); \
ok(!memcmp(not_aligned, bytes, sizeof(bytes)), \
"not aligned\t" #STORE_NAME); \
ok(LOAD_NAME(not_aligned) == value, "not aligned\t" #LOAD_NAME); \
}
#define ARRAY_2(A, B) {A, B}
#define ARRAY_3(A, B, C) {A, B, C}
#define ARRAY_4(A, B, C, D) {A, B, C, D}
#define ARRAY_5(A, B, C, D, E) {A, B, C, D, E}
#define ARRAY_6(A, B, C, D, E, F) {A, B, C, D, E, F}
#define ARRAY_7(A, B, C, D, E, F, G) {A, B, C, D, E, F, G}
#define ARRAY_8(A, B, C, D, E, F, G, H) {A, B, C, D, E, F, G, H}
TEST(int2store, sint2korr, int16, 0x0201, ARRAY_2(1, 2));
TEST(int3store, sint3korr, int32, 0xffffffff, ARRAY_3(0xff, 0xff, 0xff));
TEST(int3store, sint3korr, int32, 0x030201, ARRAY_3(1, 2, 3));
TEST(int4store, sint4korr, int32, 0xffffffff,
ARRAY_4(0xff, 0xff, 0xff, 0xff));
TEST(int4store, sint4korr, int32, 0x04030201, ARRAY_4(1, 2, 3, 4));
TEST(int8store, sint8korr, longlong, 0x0807060504030201,
ARRAY_8(1, 2, 3, 4, 5, 6, 7, 8));
TEST(int8store, sint8korr, longlong, 0xffffffffffffffff,
ARRAY_8(0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff));
TEST(int2store, uint2korr, uint16, 0x0201, ARRAY_2(1, 2));
TEST(int3store, uint3korr, uint32, 0x030201, ARRAY_3(1, 2, 3));
TEST(int4store, uint4korr, uint32, 0x04030201, ARRAY_4(1, 2, 3, 4));
TEST(int5store, uint5korr, ulonglong, 0x0504030201, ARRAY_5(1, 2, 3, 4, 5));
TEST(int6store, uint6korr, ulonglong, 0x060504030201,
ARRAY_6(1, 2, 3, 4, 5, 6));
TEST(int8store, uint8korr, ulonglong, 0x0807060504030201,
ARRAY_8(1, 2, 3, 4, 5, 6, 7, 8));
TEST(mi_int5store, mi_uint5korr, ulonglong, 0x0504030201,
ARRAY_5(5, 4, 3, 2, 1));
TEST(mi_int6store, mi_uint6korr, ulonglong, 0x060504030201,
ARRAY_6(6, 5, 4, 3, 2, 1));
TEST(mi_int7store, mi_uint7korr, ulonglong, 0x07060504030201,
ARRAY_7(7, 6, 5, 4, 3, 2, 1));
TEST(mi_int8store, mi_uint8korr, ulonglong, 0x0807060504030201,
ARRAY_8(8, 7, 6, 5, 4, 3, 2, 1));
#undef ARRAY_8
#undef ARRAY_7
#undef ARRAY_6
#undef ARRAY_5
#undef ARRAY_4
#undef ARRAY_3
#undef ARRAY_2
#undef TEST
}
int main(int argc __attribute__((unused)), char **argv __attribute__((unused)))
{
plan(68);
test_byte_order();
return exit_status();
}
|