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
|
/**
* Copyright (C) Mellanox Technologies Ltd. 2001-2021. ALL RIGHTS RESERVED.
*
* See file LICENSE for terms.
*/
#include "ucp_test.h"
#include <ucp/core/ucp_context.h>
class test_ucp_ep : public ucp_test {
public:
static void get_test_variants(std::vector<ucp_test_variant> &variants)
{
add_variant(variants, UCP_FEATURE_TAG);
}
/// @override
virtual void init()
{
ucp_test::init();
sender().connect(&receiver(), get_ep_params());
}
};
UCS_TEST_P(test_ucp_ep, ucp_query_ep)
{
ucp_ep_h ep;
ucs_status_t status;
ucp_ep_evaluate_perf_param_t param;
ucp_ep_evaluate_perf_attr_t attr;
double estimated_time_0, estimated_time_1000;
param.field_mask = UCP_EP_PERF_PARAM_FIELD_MESSAGE_SIZE;
attr.field_mask = UCP_EP_PERF_ATTR_FIELD_ESTIMATED_TIME;
param.message_size = 0;
create_entity();
ep = sender().ep();
status = ucp_ep_evaluate_perf(ep, ¶m, &attr);
EXPECT_EQ(status, UCS_OK);
EXPECT_GE(attr.estimated_time, 0);
estimated_time_0 = attr.estimated_time;
param.message_size = 1000;
status = ucp_ep_evaluate_perf(ep, ¶m, &attr);
EXPECT_EQ(status, UCS_OK);
EXPECT_GT(attr.estimated_time, 0);
EXPECT_LT(attr.estimated_time, 10);
estimated_time_1000 = attr.estimated_time;
param.message_size = 2000;
status = ucp_ep_evaluate_perf(ep, ¶m, &attr);
EXPECT_EQ(status, UCS_OK);
EXPECT_GT(attr.estimated_time, 0);
EXPECT_LT(attr.estimated_time, 10);
/* Test time estimation sanity, by verifying constant increase per message
size (which represents current calculation model) */
EXPECT_FLOAT_EQ(attr.estimated_time - estimated_time_1000,
estimated_time_1000 - estimated_time_0);
}
UCP_INSTANTIATE_TEST_CASE(test_ucp_ep);
|