mirror of
https://github.com/paulscherrerinstitute/sf_daq_buffer.git
synced 2026-04-21 03:04:37 +02:00
239 lines
7.7 KiB
C++
239 lines
7.7 KiB
C++
#include <netinet/in.h>
|
|
#include <jungfrau.hpp>
|
|
#include "gtest/gtest.h"
|
|
#include "BufferUdpReceiver.hpp"
|
|
#include "mock/udp.hpp"
|
|
|
|
#include <thread>
|
|
#include <chrono>
|
|
#include <future>
|
|
|
|
using namespace std;
|
|
|
|
TEST(BufferUdpReceiver, simple_recv)
|
|
{
|
|
auto n_packets = JUNGFRAU_N_PACKETS_PER_FRAME;
|
|
int source_id = 1234;
|
|
int n_frames = 5;
|
|
|
|
uint16_t udp_port = MOCK_UDP_PORT;
|
|
auto server_address = get_server_address(udp_port);
|
|
auto send_socket_fd = socket(AF_INET, SOCK_DGRAM, 0);
|
|
ASSERT_TRUE(send_socket_fd >= 0);
|
|
|
|
BufferUdpReceiver udp_receiver(udp_port, source_id);
|
|
|
|
auto handle = async(launch::async, [&](){
|
|
for (int i_frame=0; i_frame < n_frames; i_frame++){
|
|
for (size_t i_packet=0; i_packet<n_packets; i_packet++) {
|
|
jungfrau_packet send_udp_buffer;
|
|
send_udp_buffer.packetnum = i_packet;
|
|
send_udp_buffer.bunchid = i_frame + 1;
|
|
send_udp_buffer.framenum = i_frame + 1000;
|
|
send_udp_buffer.debug = i_frame + 10000;
|
|
|
|
::sendto(
|
|
send_socket_fd,
|
|
&send_udp_buffer,
|
|
JUNGFRAU_BYTES_PER_PACKET,
|
|
0,
|
|
(sockaddr*) &server_address,
|
|
sizeof(server_address));
|
|
}
|
|
}
|
|
});
|
|
|
|
handle.wait();
|
|
|
|
ModuleFrame metadata;
|
|
auto frame_buffer = make_unique<char[]>(JUNGFRAU_DATA_BYTES_PER_FRAME);
|
|
|
|
for (int i_frame=0; i_frame < n_frames; i_frame++) {
|
|
auto pulse_id = udp_receiver.get_frame_from_udp(
|
|
metadata, frame_buffer.get());
|
|
|
|
ASSERT_EQ(i_frame + 1, pulse_id);
|
|
ASSERT_EQ(metadata.frame_index, i_frame + 1000);
|
|
ASSERT_EQ(metadata.daq_rec, i_frame + 10000);
|
|
// -1 because we skipped a packet.
|
|
ASSERT_EQ(metadata.n_received_packets, n_packets);
|
|
ASSERT_EQ(metadata.module_id, source_id);
|
|
}
|
|
|
|
::close(send_socket_fd);
|
|
}
|
|
|
|
TEST(BufferUdpReceiver, missing_middle_packet)
|
|
{
|
|
auto n_packets = JUNGFRAU_N_PACKETS_PER_FRAME;
|
|
int source_id = 1234;
|
|
int n_frames = 3;
|
|
|
|
uint16_t udp_port = MOCK_UDP_PORT;
|
|
auto server_address = get_server_address(udp_port);
|
|
auto send_socket_fd = socket(AF_INET, SOCK_DGRAM, 0);
|
|
ASSERT_TRUE(send_socket_fd >= 0);
|
|
|
|
BufferUdpReceiver udp_receiver(udp_port, source_id);
|
|
|
|
auto handle = async(launch::async, [&](){
|
|
for (int i_frame=0; i_frame < n_frames; i_frame++){
|
|
for (size_t i_packet=0; i_packet<n_packets; i_packet++) {
|
|
// Skip some random middle packet.
|
|
if (i_packet == 10) {
|
|
continue;
|
|
}
|
|
|
|
jungfrau_packet send_udp_buffer;
|
|
send_udp_buffer.packetnum = i_packet;
|
|
send_udp_buffer.bunchid = i_frame + 1;
|
|
send_udp_buffer.framenum = i_frame + 1000;
|
|
send_udp_buffer.debug = i_frame + 10000;
|
|
|
|
::sendto(
|
|
send_socket_fd,
|
|
&send_udp_buffer,
|
|
JUNGFRAU_BYTES_PER_PACKET,
|
|
0,
|
|
(sockaddr*) &server_address,
|
|
sizeof(server_address));
|
|
}
|
|
}
|
|
});
|
|
|
|
handle.wait();
|
|
|
|
ModuleFrame metadata;
|
|
auto frame_buffer = make_unique<char[]>(JUNGFRAU_DATA_BYTES_PER_FRAME);
|
|
|
|
for (int i_frame=0; i_frame < n_frames; i_frame++) {
|
|
auto pulse_id = udp_receiver.get_frame_from_udp(
|
|
metadata, frame_buffer.get());
|
|
|
|
ASSERT_EQ(i_frame + 1, pulse_id);
|
|
ASSERT_EQ(metadata.frame_index, i_frame + 1000);
|
|
ASSERT_EQ(metadata.daq_rec, i_frame + 10000);
|
|
// -1 because we skipped a packet.
|
|
ASSERT_EQ(metadata.n_received_packets, n_packets-1);
|
|
ASSERT_EQ(metadata.module_id, source_id);
|
|
}
|
|
|
|
::close(send_socket_fd);
|
|
}
|
|
|
|
TEST(BufferUdpReceiver, missing_first_packet)
|
|
{
|
|
auto n_packets = JUNGFRAU_N_PACKETS_PER_FRAME;
|
|
int source_id = 1234;
|
|
int n_frames = 3;
|
|
|
|
uint16_t udp_port = MOCK_UDP_PORT;
|
|
auto server_address = get_server_address(udp_port);
|
|
auto send_socket_fd = socket(AF_INET, SOCK_DGRAM, 0);
|
|
ASSERT_TRUE(send_socket_fd >= 0);
|
|
|
|
BufferUdpReceiver udp_receiver(udp_port, source_id);
|
|
|
|
auto handle = async(launch::async, [&](){
|
|
for (int i_frame=0; i_frame < n_frames; i_frame++){
|
|
for (size_t i_packet=0; i_packet<n_packets; i_packet++) {
|
|
// Skip first packet.
|
|
if (i_packet == 0) {
|
|
continue;
|
|
}
|
|
|
|
jungfrau_packet send_udp_buffer;
|
|
send_udp_buffer.packetnum = i_packet;
|
|
send_udp_buffer.bunchid = i_frame + 1;
|
|
send_udp_buffer.framenum = i_frame + 1000;
|
|
send_udp_buffer.debug = i_frame + 10000;
|
|
|
|
::sendto(
|
|
send_socket_fd,
|
|
&send_udp_buffer,
|
|
JUNGFRAU_BYTES_PER_PACKET,
|
|
0,
|
|
(sockaddr*) &server_address,
|
|
sizeof(server_address));
|
|
}
|
|
}
|
|
});
|
|
|
|
handle.wait();
|
|
|
|
ModuleFrame metadata;
|
|
auto frame_buffer = make_unique<char[]>(JUNGFRAU_DATA_BYTES_PER_FRAME);
|
|
|
|
for (int i_frame=0; i_frame < n_frames; i_frame++) {
|
|
auto pulse_id = udp_receiver.get_frame_from_udp(
|
|
metadata, frame_buffer.get());
|
|
|
|
ASSERT_EQ(i_frame + 1, pulse_id);
|
|
ASSERT_EQ(metadata.frame_index, i_frame + 1000);
|
|
ASSERT_EQ(metadata.daq_rec, i_frame + 10000);
|
|
// -1 because we skipped a packet.
|
|
ASSERT_EQ(metadata.n_received_packets, n_packets-1);
|
|
ASSERT_EQ(metadata.module_id, source_id);
|
|
}
|
|
|
|
::close(send_socket_fd);
|
|
}
|
|
|
|
TEST(BufferUdpReceiver, missing_last_packet)
|
|
{
|
|
auto n_packets = JUNGFRAU_N_PACKETS_PER_FRAME;
|
|
int source_id = 1234;
|
|
int n_frames = 3;
|
|
|
|
uint16_t udp_port = MOCK_UDP_PORT;
|
|
auto server_address = get_server_address(udp_port);
|
|
auto send_socket_fd = socket(AF_INET, SOCK_DGRAM, 0);
|
|
ASSERT_TRUE(send_socket_fd >= 0);
|
|
|
|
BufferUdpReceiver udp_receiver(udp_port, source_id);
|
|
|
|
auto handle = async(launch::async, [&](){
|
|
for (int i_frame=0; i_frame < n_frames; i_frame++){
|
|
for (size_t i_packet=0; i_packet<n_packets; i_packet++) {
|
|
// Skip the last packet.
|
|
if (i_packet == n_packets-1) {
|
|
continue;
|
|
}
|
|
|
|
jungfrau_packet send_udp_buffer;
|
|
send_udp_buffer.packetnum = i_packet;
|
|
send_udp_buffer.bunchid = i_frame + 1;
|
|
send_udp_buffer.framenum = i_frame + 1000;
|
|
send_udp_buffer.debug = i_frame + 10000;
|
|
|
|
::sendto(
|
|
send_socket_fd,
|
|
&send_udp_buffer,
|
|
JUNGFRAU_BYTES_PER_PACKET,
|
|
0,
|
|
(sockaddr*) &server_address,
|
|
sizeof(server_address));
|
|
}
|
|
}
|
|
});
|
|
|
|
handle.wait();
|
|
|
|
ModuleFrame metadata;
|
|
auto frame_buffer = make_unique<char[]>(JUNGFRAU_DATA_BYTES_PER_FRAME);
|
|
|
|
// n_frames -1 because the last frame is not complete.
|
|
for (int i_frame=0; i_frame < n_frames - 1; i_frame++) {
|
|
auto pulse_id = udp_receiver.get_frame_from_udp(
|
|
metadata, frame_buffer.get());
|
|
|
|
ASSERT_EQ(i_frame + 1, pulse_id);
|
|
ASSERT_EQ(metadata.frame_index, i_frame + 1000);
|
|
ASSERT_EQ(metadata.daq_rec, i_frame + 10000);
|
|
// -1 because we skipped a packet.
|
|
ASSERT_EQ(metadata.n_received_packets, n_packets-1);
|
|
ASSERT_EQ(metadata.module_id, source_id);
|
|
}
|
|
|
|
::close(send_socket_fd);
|
|
} |