1
0
mirror of https://gitlab.com/libvirt/libvirt.git synced 2025-01-06 17:17:56 +03:00
libvirt/scripts/rpcgen/tests
Michal Privoznik 94ded36b3f rpcgen: tests: Run cleanly on platforms where char is unsigned
There are some platforms where 'char' is unsigned, by default
(RPi, s390x to name a few). And because of how test_demo is
written we are experiencing some test cases failing there. For
instance: /xdr/struct-scalar is failing. This is because in the
test (test_struct_scalar()), we have a struct with two chars. One
is initialized to 0xca, the other 0xfe (note that both have the
MSB set). The XDR encoder (xdr_TestStructScalar()) then calls
xdr_char() on both of them. But XDR itself has no notion of
char type, so under the hood, it expands it to int [1] and calls
xdr_int(). And this is where the problem lies. On platforms where
char is signed, the integer expansion results in 0xffffffca, but
on platforms where char is unsigned it results in 0x000000ca. Two
distinct results.

The test then goes and compares the encoded buffer with an
expected one (memcmp(), read from the disk earlier).

This poses no problem for real life use, because when decoding
those chars back, the padding is thrown away.

To avoid tickling this issue, use values that don't have the MSB
set.

1: https://git.linux-nfs.org/?p=steved/libtirpc.git;a=blob;f=src/xdr.c;h=28d1382cc4853ecf1238d792af5016160435d1e0;hb=HEAD#l487

Fixes: 40cbaa8fbe rpcgen: add test case for XDR serialization
Reported-by: Boris Fiuczynski <fiuczy@linux.ibm.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Boris Fiuczynski <fiuczy@linux.ibm.com>
2023-11-29 17:16:45 +01:00
..
demo.c rpcgen: add g_auto function support 2023-11-03 14:06:35 -04:00
demo.h rpcgen: add g_auto function support 2023-11-03 14:06:35 -04:00
demo.x rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
meson.build rpcgen: tests: Allow running test_demo from anywhere 2023-11-29 14:34:11 +01:00
simple.x
test_demo_enum_fixed_array.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_enum_pointer_null.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_enum_pointer_set.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_enum_scalar.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_enum_variable_array_empty.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_enum_variable_array_set.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_enum.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_int_fixed_array.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_int_pointer_null.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_int_pointer_set.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_int_scalar.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_int_variable_array_empty.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_int_variable_array_set.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_opaque_fixed_array.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_opaque_variable_array_empty.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_opaque_variable_array_set.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_string_variable_array_empty.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_string_variable_array_set.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_struct_fixed_array.bin rpcgen: tests: Run cleanly on platforms where char is unsigned 2023-11-29 17:16:45 +01:00
test_demo_struct_pointer_null.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_struct_pointer_set.bin rpcgen: tests: Run cleanly on platforms where char is unsigned 2023-11-29 17:16:45 +01:00
test_demo_struct_scalar.bin rpcgen: tests: Run cleanly on platforms where char is unsigned 2023-11-29 17:16:45 +01:00
test_demo_struct_variable_array_empty.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_struct_variable_array_set.bin rpcgen: tests: Run cleanly on platforms where char is unsigned 2023-11-29 17:16:45 +01:00
test_demo_struct.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_test_struct_all_types.bin rpcgen: tests: Run cleanly on platforms where char is unsigned 2023-11-29 17:16:45 +01:00
test_demo_union_case.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_union_default.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_union_fixed_array.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_union_no_default_case.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_union_pointer_null.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_union_pointer_set.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_union_scalar.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_union_variable_array_empty.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_union_variable_array_set.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_union_void_default_case.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo_union_void_default_default.bin rpcgen: add test case for XDR serialization 2023-11-03 14:06:35 -04:00
test_demo.c rpcgen: tests: Run cleanly on platforms where char is unsigned 2023-11-29 17:16:45 +01:00
test_generator.py rpcgen: add g_auto function support 2023-11-03 14:06:35 -04:00
test_lexer.py
test_parser.py rpcgen: add an XDR protocol parser 2023-11-03 14:06:35 -04:00