summaryrefslogtreecommitdiffstats
path: root/src/libsystemd-network
diff options
context:
space:
mode:
Diffstat (limited to 'src/libsystemd-network')
-rw-r--r--src/libsystemd-network/test-dhcp6-client.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/src/libsystemd-network/test-dhcp6-client.c b/src/libsystemd-network/test-dhcp6-client.c
index 5aa7ebb977..3b25df7625 100644
--- a/src/libsystemd-network/test-dhcp6-client.c
+++ b/src/libsystemd-network/test-dhcp6-client.c
@@ -886,7 +886,21 @@ static void test_client_callback(sd_dhcp6_client *client, int event, void *userd
test_lease_managed(client);
- assert_se(sd_event_exit(sd_dhcp6_client_get_event(client), 0) >= 0);
+ switch (test_client_sent_message_count) {
+ case 3:
+ assert_se(sd_dhcp6_client_stop(client) >= 0);
+ assert_se(sd_dhcp6_client_start(client) >= 0);
+ assert_se(dhcp6_client_set_transaction_id(client, ((const DHCP6Message*) msg_reply)->transaction_id) >= 0);
+ break;
+
+ case 4:
+ assert_se(sd_event_exit(sd_dhcp6_client_get_event(client), 0) >= 0);
+ break;
+
+ default:
+ assert_not_reached();
+ }
+
break;
case DHCP6_CLIENT_EVENT_TEST_ADVERTISED: {
@@ -936,6 +950,11 @@ int dhcp6_network_send_udp_socket(int s, struct in6_addr *a, const void *packet,
assert_se(write(test_fd[1], msg_reply, sizeof(msg_reply)) == sizeof(msg_reply));
break;
+ case 3:
+ test_client_verify_solicit(packet, len);
+ assert_se(write(test_fd[1], msg_reply, sizeof(msg_reply)) == sizeof(msg_reply));
+ break;
+
default:
assert_not_reached();
}
@@ -983,7 +1002,7 @@ static void test_dhcp6_client(void) {
assert_se(sd_event_loop(e) >= 0);
- assert_se(test_client_sent_message_count == 3);
+ assert_se(test_client_sent_message_count == 4);
test_fd[1] = safe_close(test_fd[1]);
}