mirror of
https://github.com/systemd/systemd.git
synced 2025-03-08 08:58:27 +03:00
Merge pull request #5957 from keszybz/test-c++
Test compilation under C++
This commit is contained in:
commit
f731ad4456
2
.gitignore
vendored
2
.gitignore
vendored
@ -160,6 +160,8 @@
|
||||
/test-bus-server
|
||||
/test-bus-signature
|
||||
/test-bus-track
|
||||
/test-bus-vtable
|
||||
/test-bus-vtable-cc
|
||||
/test-bus-zero-copy
|
||||
/test-calendarspec
|
||||
/test-cap-list
|
||||
|
@ -3461,6 +3461,7 @@ tests += \
|
||||
test-bus-zero-copy \
|
||||
test-bus-introspect \
|
||||
test-bus-objects \
|
||||
test-bus-vtable \
|
||||
test-bus-error \
|
||||
test-bus-creds \
|
||||
test-bus-gvariant \
|
||||
@ -3530,6 +3531,12 @@ test_bus_objects_SOURCES = \
|
||||
test_bus_objects_LDADD = \
|
||||
libsystemd-shared.la
|
||||
|
||||
test_bus_vtable_SOURCES = \
|
||||
src/libsystemd/sd-bus/test-bus-vtable.c
|
||||
|
||||
test_bus_vtable_LDADD = \
|
||||
libsystemd-shared.la
|
||||
|
||||
test_bus_error_SOURCES = \
|
||||
src/libsystemd/sd-bus/test-bus-error.c
|
||||
|
||||
|
@ -224,6 +224,12 @@ cc = meson.get_compiler('c')
|
||||
pkgconfig = import('pkgconfig')
|
||||
check_compilation_sh = find_program('tools/meson-check-compilation.sh')
|
||||
|
||||
cxx = find_program('c++', required : false)
|
||||
if cxx.found()
|
||||
# Used only for tests
|
||||
add_languages('cpp')
|
||||
endif
|
||||
|
||||
foreach arg : ['-Wundef',
|
||||
'-Wlogical-op',
|
||||
'-Wmissing-include-dirs',
|
||||
|
@ -19,7 +19,6 @@
|
||||
along with systemd; If not, see <http://www.gnu.org/licenses/>.
|
||||
***/
|
||||
|
||||
#include <assert.h>
|
||||
#include <inttypes.h>
|
||||
#include <stdbool.h>
|
||||
#include <sys/param.h>
|
||||
|
@ -18,7 +18,6 @@
|
||||
along with systemd; If not, see <http://www.gnu.org/licenses/>.
|
||||
***/
|
||||
|
||||
#include <assert.h>
|
||||
#include <blkid.h>
|
||||
#include <ctype.h>
|
||||
#include <dirent.h>
|
||||
|
@ -17,7 +17,6 @@
|
||||
along with systemd; If not, see <http://www.gnu.org/licenses/>.
|
||||
***/
|
||||
|
||||
#include <assert.h>
|
||||
#include <errno.h>
|
||||
#include <qrencode.h>
|
||||
#include <stdbool.h>
|
||||
@ -25,6 +24,7 @@
|
||||
#include <stdlib.h>
|
||||
|
||||
#include "journal-qrcode.h"
|
||||
#include "macro.h"
|
||||
|
||||
#define WHITE_ON_BLACK "\033[40;37;1m"
|
||||
#define NORMAL "\033[0m"
|
||||
|
@ -17,7 +17,6 @@
|
||||
along with systemd; If not, see <http://www.gnu.org/licenses/>.
|
||||
***/
|
||||
|
||||
#include <assert.h>
|
||||
#include <errno.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
@ -72,10 +71,10 @@ int arp_send_probe(int fd, int ifindex,
|
||||
be32_t pa, const struct ether_addr *ha) {
|
||||
struct ether_arp ea = {};
|
||||
|
||||
assert(fd >= 0);
|
||||
assert(ifindex > 0);
|
||||
assert(pa != 0);
|
||||
assert(ha);
|
||||
assert_se(fd >= 0);
|
||||
assert_se(ifindex > 0);
|
||||
assert_se(pa != 0);
|
||||
assert_se(ha);
|
||||
|
||||
return arp_network_send_raw_socket(fd, ifindex, &ea);
|
||||
}
|
||||
@ -84,10 +83,10 @@ int arp_send_announcement(int fd, int ifindex,
|
||||
be32_t pa, const struct ether_addr *ha) {
|
||||
struct ether_arp ea = {};
|
||||
|
||||
assert(fd >= 0);
|
||||
assert(ifindex > 0);
|
||||
assert(pa != 0);
|
||||
assert(ha);
|
||||
assert_se(fd >= 0);
|
||||
assert_se(ifindex > 0);
|
||||
assert_se(pa != 0);
|
||||
assert_se(ha);
|
||||
|
||||
return arp_network_send_raw_socket(fd, ifindex, &ea);
|
||||
}
|
||||
|
1
src/libsystemd/sd-bus/test-bus-vtable-cc.cc
Symbolic link
1
src/libsystemd/sd-bus/test-bus-vtable-cc.cc
Symbolic link
@ -0,0 +1 @@
|
||||
test-bus-vtable.c
|
77
src/libsystemd/sd-bus/test-bus-vtable.c
Normal file
77
src/libsystemd/sd-bus/test-bus-vtable.c
Normal file
@ -0,0 +1,77 @@
|
||||
#include <stdbool.h>
|
||||
#include <stddef.h>
|
||||
|
||||
/* We use system assert.h here, because we don't want to keep macro.h and log.h C++ compatible */
|
||||
#undef NDEBUG
|
||||
#include <assert.h>
|
||||
|
||||
#include "sd-bus-vtable.h"
|
||||
|
||||
#define DEFAULT_BUS_PATH "unix:path=/run/dbus/system_bus_socket"
|
||||
|
||||
struct context {
|
||||
bool quit;
|
||||
char *something;
|
||||
char *automatic_string_property;
|
||||
uint32_t automatic_integer_property;
|
||||
};
|
||||
|
||||
static int handler(sd_bus_message *m, void *userdata, sd_bus_error *error) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int value_handler(sd_bus *bus, const char *path, const char *interface, const char *property, sd_bus_message *reply, void *userdata, sd_bus_error *error) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int get_handler(sd_bus *bus, const char *path, const char *interface, const char *property, sd_bus_message *reply, void *userdata, sd_bus_error *error) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int set_handler(sd_bus *bus, const char *path, const char *interface, const char *property, sd_bus_message *value, void *userdata, sd_bus_error *error) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
static const sd_bus_vtable vtable[] = {
|
||||
SD_BUS_VTABLE_START(0),
|
||||
SD_BUS_METHOD("AlterSomething", "s", "s", handler, 0),
|
||||
SD_BUS_METHOD("Exit", "", "", handler, 0),
|
||||
SD_BUS_METHOD_WITH_OFFSET("AlterSomething2", "s", "s", handler, 200, 0),
|
||||
SD_BUS_METHOD_WITH_OFFSET("Exit2", "", "", handler, 200, 0),
|
||||
SD_BUS_PROPERTY("Value", "s", value_handler, 10, SD_BUS_VTABLE_PROPERTY_EMITS_CHANGE),
|
||||
SD_BUS_PROPERTY("Value2", "s", value_handler, 10, SD_BUS_VTABLE_PROPERTY_EMITS_INVALIDATION),
|
||||
SD_BUS_PROPERTY("Value3", "s", value_handler, 10, SD_BUS_VTABLE_PROPERTY_CONST),
|
||||
SD_BUS_PROPERTY("Value4", "s", value_handler, 10, 0),
|
||||
SD_BUS_PROPERTY("AnExplicitProperty", "s", NULL, offsetof(struct context, something),
|
||||
SD_BUS_VTABLE_PROPERTY_EXPLICIT|SD_BUS_VTABLE_PROPERTY_EMITS_INVALIDATION),
|
||||
SD_BUS_WRITABLE_PROPERTY("Something", "s", get_handler, set_handler, 0, 0),
|
||||
SD_BUS_WRITABLE_PROPERTY("AutomaticStringProperty", "s", NULL, NULL,
|
||||
offsetof(struct context, automatic_string_property), 0),
|
||||
SD_BUS_WRITABLE_PROPERTY("AutomaticIntegerProperty", "u", NULL, NULL,
|
||||
offsetof(struct context, automatic_integer_property), 0),
|
||||
SD_BUS_METHOD("NoOperation", NULL, NULL, NULL, 0),
|
||||
SD_BUS_SIGNAL("DummySignal", "b", 0),
|
||||
SD_BUS_SIGNAL("DummySignal2", "so", 0),
|
||||
SD_BUS_VTABLE_END
|
||||
};
|
||||
|
||||
static void test_vtable(void) {
|
||||
sd_bus *bus = NULL;
|
||||
struct context c = {};
|
||||
|
||||
assert(sd_bus_new(&bus) >= 0);
|
||||
|
||||
assert(sd_bus_add_object_vtable(bus, NULL, "/foo", "org.freedesktop.systemd.testVtable", vtable, &c) >= 0);
|
||||
assert(sd_bus_add_object_vtable(bus, NULL, "/foo", "org.freedesktop.systemd.testVtable2", vtable, &c) >= 0);
|
||||
|
||||
assert(sd_bus_set_address(bus, DEFAULT_BUS_PATH) >= 0);
|
||||
assert(sd_bus_start(bus) >= 0);
|
||||
|
||||
sd_bus_unref(bus);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv) {
|
||||
test_vtable();
|
||||
|
||||
return 0;
|
||||
}
|
@ -38,16 +38,17 @@ install_headers(
|
||||
|
||||
############################################################
|
||||
|
||||
opts = [[],
|
||||
['-ansi'],
|
||||
['-std=iso9899:1990']]
|
||||
opts = [['c'],
|
||||
['c', '-ansi'],
|
||||
['c', '-std=iso9899:1990'],
|
||||
['c++']]
|
||||
|
||||
foreach header : _systemd_headers
|
||||
foreach opt : opts
|
||||
name = ''.join([header] + opt)
|
||||
name = ''.join([header, ':'] + opt)
|
||||
test('cc-' + name,
|
||||
check_compilation_sh,
|
||||
args : cc.cmd_array() + ['-x', 'c', '-c'] + opt +
|
||||
args : cc.cmd_array() + ['-c', '-x'] + opt +
|
||||
['-Werror', '-include',
|
||||
join_paths(meson.current_source_dir(), header)])
|
||||
endforeach
|
||||
|
@ -734,6 +734,10 @@ tests += [
|
||||
[],
|
||||
[threads]],
|
||||
|
||||
[['src/libsystemd/sd-bus/test-bus-vtable.c'],
|
||||
[],
|
||||
[]],
|
||||
|
||||
[['src/libsystemd/sd-bus/test-bus-gvariant.c'],
|
||||
[],
|
||||
[libglib,
|
||||
@ -790,6 +794,14 @@ tests += [
|
||||
'', 'manual'],
|
||||
]
|
||||
|
||||
if cxx.found()
|
||||
tests += [
|
||||
[['src/libsystemd/sd-bus/test-bus-vtable-cc.cc'],
|
||||
[],
|
||||
[]]
|
||||
]
|
||||
endif
|
||||
|
||||
############################################################
|
||||
|
||||
tests += [
|
||||
|
Loading…
x
Reference in New Issue
Block a user