| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493 |
- /*********************************************************************
- * _ _ _
- * _ __ | |_ _ | | __ _ | |__ ___
- * | '__|| __|(_)| | / _` || '_ \ / __|
- * | | | |_ _ | || (_| || |_) |\__ \
- * |_| \__|(_)|_| \__,_||_.__/ |___/
- *
- * www.rt-labs.com
- * Copyright 2018 rt-labs AB, Sweden.
- *
- * This software is dual-licensed under GPLv3 and a commercial
- * license. See the file LICENSE.md distributed with this software for
- * full license information.
- ********************************************************************/
- /**
- * @file
- * @brief Integration testing of CMRDR.
- *
- * Using for example:
- * pnet_application_ready()
- * pnet_output_get_data_and_iops()
- * pnet_input_get_iocs()
- * pnet_input_set_data_and_iops()
- * pnet_output_set_iocs()
- * pnet_create_log_book_entry()
- * pnet_diag_add()
- *
- */
- #include "utils_for_testing.h"
- #include "mocks.h"
- #include "pf_includes.h"
- #include <gtest/gtest.h>
- // clang-format off
- static uint8_t connect_req[] =
- {
- 0x04, 0x00, 0x28, 0x00, 0x10, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0xa0, 0xde, 0x97, 0x6c, 0xd1, 0x11, 0x82, 0x71, 0x00, 0x01, 0xbe, 0xef,
- 0xfe, 0xed, 0x01, 0x00, 0xa0, 0xde, 0x97, 0x6c, 0xd1, 0x11, 0x82, 0x71, 0x00, 0xa0, 0x24, 0x42,
- 0xdf, 0x7d, 0xbb, 0xac, 0x97, 0xe2, 0x76, 0x54, 0x9f, 0x47, 0xa5, 0xbd, 0xa5, 0xe3, 0x7d, 0x98,
- 0xe5, 0xda, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0xff, 0xff, 0xff, 0xff, 0x86, 0x01, 0x00, 0x00, 0x00, 0x00, 0x24, 0x10, 0x00, 0x00, 0x72, 0x01,
- 0x00, 0x00, 0x24, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x72, 0x01, 0x00, 0x00, 0x01, 0x01,
- 0x00, 0x42, 0x01, 0x00, 0x00, 0x01, 0x30, 0xab, 0xa9, 0xa3, 0xf7, 0x64, 0xb7, 0x44, 0xb3, 0xb6,
- 0x7e, 0xe2, 0x8a, 0x1a, 0x02, 0xcb, 0x00, 0x02, 0xc8, 0x5b, 0x76, 0xe6, 0x89, 0xdf, 0xde, 0xa0,
- 0x00, 0x00, 0x6c, 0x97, 0x11, 0xd1, 0x82, 0x71, 0x00, 0x01, 0xf0, 0x00, 0x00, 0x01, 0x40, 0x00,
- 0x00, 0x11, 0x02, 0x58, 0x88, 0x92, 0x00, 0x0c, 0x72, 0x74, 0x2d, 0x6c, 0x61, 0x62, 0x73, 0x2d,
- 0x64, 0x65, 0x6d, 0x6f, 0x01, 0x02, 0x00, 0x50, 0x01, 0x00, 0x00, 0x01, 0x00, 0x01, 0x88, 0x92,
- 0x00, 0x00, 0x00, 0x02, 0x00, 0x28, 0x80, 0x01, 0x00, 0x20, 0x00, 0x01, 0x00, 0x01, 0x00, 0x00,
- 0xff, 0xff, 0xff, 0xff, 0x00, 0x03, 0x00, 0x03, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00,
- 0x80, 0x00, 0x00, 0x01, 0x00, 0x00, 0x80, 0x01, 0x00, 0x02, 0x00, 0x01, 0x00, 0x01, 0x00, 0x03,
- 0x00, 0x01, 0x00, 0x01, 0x00, 0x01, 0x00, 0x05, 0x01, 0x02, 0x00, 0x50, 0x01, 0x00, 0x00, 0x02,
- 0x00, 0x02, 0x88, 0x92, 0x00, 0x00, 0x00, 0x02, 0x00, 0x28, 0x80, 0x00, 0x00, 0x20, 0x00, 0x01,
- 0x00, 0x01, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0x00, 0x03, 0x00, 0x03, 0xc0, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x01, 0x00, 0x01,
- 0x00, 0x04, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x80, 0x00, 0x00, 0x01,
- 0x00, 0x00, 0x80, 0x01, 0x00, 0x02, 0x00, 0x01, 0x00, 0x01, 0x00, 0x03, 0x01, 0x04, 0x00, 0x3c,
- 0x01, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00,
- 0x00, 0x03, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x01, 0x01,
- 0x80, 0x00, 0x00, 0x00, 0x80, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x01, 0x01, 0x80, 0x01,
- 0x00, 0x00, 0x80, 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x01, 0x01, 0x01, 0x04, 0x00, 0x26,
- 0x01, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x32, 0x00, 0x00,
- 0x00, 0x01, 0x00, 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x03, 0x00, 0x01, 0x00, 0x01, 0x01, 0x01,
- 0x00, 0x02, 0x00, 0x01, 0x01, 0x01, 0x01, 0x03, 0x00, 0x16, 0x01, 0x00, 0x00, 0x01, 0x88, 0x92,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x03, 0x00, 0x02, 0x00, 0xc8, 0xc0, 0x00, 0xa0, 0x00
- };
- static uint8_t release_req[] =
- {
- 0x04, 0x00, 0x28, 0x00, 0x10, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0xa0, 0xde, 0x97, 0x6c, 0xd1, 0x11, 0x82, 0x71, 0x00, 0x01, 0xbe, 0xef,
- 0xfe, 0xed, 0x01, 0x00, 0xa0, 0xde, 0x97, 0x6c, 0xd1, 0x11, 0x82, 0x71, 0x00, 0xa0, 0x24, 0x42,
- 0xdf, 0x7d, 0xbb, 0xac, 0x97, 0xe2, 0x76, 0x54, 0x9f, 0x47, 0xa5, 0xbd, 0xa5, 0xe3, 0x7d, 0x98,
- 0xe5, 0xda, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x01, 0x00,
- 0xff, 0xff, 0xff, 0xff, 0x34, 0x00, 0x00, 0x00, 0x00, 0x00, 0x3e, 0x00, 0x00, 0x00, 0x20, 0x00,
- 0x00, 0x00, 0x3e, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x01, 0x14,
- 0x00, 0x1c, 0x01, 0x00, 0x00, 0x00, 0x30, 0xab, 0xa9, 0xa3, 0xf7, 0x64, 0xb7, 0x44, 0xb3, 0xb6,
- 0x7e, 0xe2, 0x8a, 0x1a, 0x02, 0xcb, 0x00, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00
- };
- static uint8_t prm_end_req[] =
- {
- 0x04, 0x00, 0x28, 0x00, 0x10, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0xa0, 0xde, 0x97, 0x6c, 0xd1, 0x11, 0x82, 0x71, 0x00, 0x01, 0xbe, 0xef,
- 0xfe, 0xed, 0x01, 0x00, 0xa0, 0xde, 0x97, 0x6c, 0xd1, 0x11, 0x82, 0x71, 0x00, 0xa0, 0x24, 0x42,
- 0xdf, 0x7d, 0xbb, 0xac, 0x97, 0xe2, 0x76, 0x54, 0x9f, 0x47, 0xa5, 0xbd, 0xa5, 0xe3, 0x7d, 0x98,
- 0xe5, 0xda, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x04, 0x00,
- 0xff, 0xff, 0xff, 0xff, 0x34, 0x00, 0x00, 0x00, 0x00, 0x00, 0x3e, 0x00, 0x00, 0x00, 0x20, 0x00,
- 0x00, 0x00, 0x3e, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x01, 0x10,
- 0x00, 0x1c, 0x01, 0x00, 0x00, 0x00, 0x30, 0xab, 0xa9, 0xa3, 0xf7, 0x64, 0xb7, 0x44, 0xb3, 0xb6,
- 0x7e, 0xe2, 0x8a, 0x1a, 0x02, 0xcb, 0x00, 0x02, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00
- };
- static uint8_t appl_rdy_rsp[] =
- {
- 0x04, 0x02, 0x0a, 0x00, 0x10, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0xa0, 0xde, 0x97, 0x6c, 0xd1, 0x11, 0x82, 0x71, 0x00, 0x00, 0xbe, 0xef,
- 0xfe, 0xed, 0x01, 0x00, 0xa0, 0xde, 0x97, 0x6c, 0xd1, 0x11, 0x82, 0x71, 0x00, 0xa0, 0x24, 0x42,
- 0xdf, 0x7d, 0x79, 0x56, 0x34, 0x12, 0x34, 0x12, 0x78, 0x56, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06,
- 0x07, 0x08, 0x01, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x04, 0x00,
- 0xff, 0xff, 0xff, 0xff, 0x34, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00,
- 0x00, 0x00, 0xdc, 0x05, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x81, 0x12,
- 0x00, 0x1c, 0x01, 0x00, 0x00, 0x00, 0x30, 0xab, 0xa9, 0xa3, 0xf7, 0x64, 0xb7, 0x44, 0xb3, 0xb6,
- 0x7e, 0xe2, 0x8a, 0x1a, 0x02, 0xcb, 0x00, 0x02, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00
- };
- static uint8_t data_packet_good_iops_good_iocs[] =
- {
- 0x1e, 0x30, 0x6c, 0xa2, 0x45, 0x5e, 0xc8, 0x5b, 0x76, 0xe6, 0x89, 0xdf, 0x88, 0x92, 0x80, 0x00,
- 0x80, 0x80, 0x80, 0x80, 0x23, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xf6, 0x35, 0x00
- };
- static uint16_t test_mod_diff[] =
- {
- 0xe002
- };
- static uint16_t test_reads[] =
- {
- 0x8000, 0x8001,
- 0x800a, 0x800b, 0x800c,
- 0x8010, 0x8011, 0x8012, 0x8013,
- 0x801e,
- 0x8020,
- 0x8027, 0x8028, 0x8029,
- 0x802a, 0x802b,
- 0x802c, 0x802d,
- 0x802f,
- 0x8030, 0x8031,
- 0x8050, 0x8051, 0x8052, 0x8053, 0x8054, 0x8055, 0x8056, 0x8057,
- 0x8060, 0x8061, 0x8062,
- 0x8070, 0x8071, 0x8072,
- 0x8080,
- 0x8090,
- 0x80af,
- 0x80b0,
- 0x80cf,
- 0xaff0, 0xaff1, 0xaff2, 0xaff3, 0xaff4, 0xaff5, 0xaff6, 0xaff7, 0xaff8, 0xaff9, 0xaffa, 0xaffb, 0xaffc, 0xaffd, 0xaffe, 0xafff,
- 0xc000, 0xc001,
- 0xc00a, 0xc00b, 0xc00c,
- 0xc010, 0xc011, 0xc012, 0xc013,
- 0xe000, 0xe001, 0xe002,
- 0xe00a, 0xe00b, 0xe00c,
- 0xe010, 0xe011, 0xe012, 0xe013,
- 0xe030, 0xe031,
- 0xe040,
- 0xe050,
- 0xe060, 0xe061,
- 0xf000,
- 0xf00a, 0xf00b, 0xf00c,
- 0xf010, 0xf011, 0xf012, 0xf013,
- 0xf020,
- 0xf80c,
- 0xf820, 0xf821,
- 0xf830, 0xf831,
- 0xf840, 0xf841, 0xf842,
- 0xf850,
- 0xf860,
- 0xf870, 0xf871,
- 0xf880, 0xf881, 0xf882, 0xf883, 0xf884, 0xf885, 0xf886, 0xf887, 0xf888, 0xf889,
- 0xfbff,
- };
- // clang-format on
- static pf_iod_read_request_t read_request;
- static pnet_result_t read_status;
- static uint16_t seq_nbr = 0;
- class CmrdrTest : public PnetIntegrationTest
- {
- protected:
- void test_read (uint16_t idx)
- {
- pf_ar_t * p_ar;
- uint8_t buffer[PF_FRAME_BUFFER_SIZE];
- uint16_t pos = 0;
- /* Send data to prevent timeout */
- send_data (
- data_packet_good_iops_good_iocs,
- sizeof (data_packet_good_iops_good_iocs));
- run_stack (TEST_DATA_DELAY);
- memset (&read_status, 0, sizeof (read_status));
- memset (&read_request, 0, sizeof (read_request));
- pf_ar_find_by_arep (net, appdata.main_arep, &p_ar);
- read_request.sequence_number = seq_nbr++;
- /* read_request.ar_uuid = NIL */
- read_request.api = 0;
- read_request.slot_number = 1;
- read_request.subslot_number = 1;
- read_request.index = idx;
- read_request.record_data_length = 0;
- // read_request.target_ar_uuid; /* Only used if implicit AR */
- pf_cmrdr_rm_read_ind (
- net,
- p_ar,
- &read_request,
- &read_status,
- sizeof (buffer),
- buffer,
- &pos);
- if (read_status.pnio_status.error_code != PNET_ERROR_CODE_NOERROR)
- {
- TEST_TRACE ("Read failed for idx %#x\n", (unsigned)idx);
- appdata.read_fails++;
- }
- }
- };
- TEST_F (CmrdrTest, CmrdrRunTest)
- {
- int ret;
- pnet_pnio_status_t pnio_status = {1, 2, 3, 4};
- bool new_flag = false;
- uint8_t in_data[10];
- uint16_t in_len = sizeof (in_data);
- uint8_t out_data[] = {
- 0x33, /* Slot 1, subslot 1 Data */
- };
- uint8_t iops = PNET_IOXS_BAD;
- uint8_t iocs = PNET_IOXS_BAD;
- uint32_t ix;
- pnet_diag_source_t diag_source = {
- .api = TEST_API_IDENT,
- .slot = TEST_SLOT_IDENT,
- .subslot = TEST_SUBSLOT_IDENT,
- .ch = TEST_CHANNEL_IDENT,
- .ch_grouping = PNET_DIAG_CH_INDIVIDUAL_CHANNEL,
- .ch_direction = TEST_CHANNEL_DIRECTION};
- TEST_TRACE ("\nGenerating mock connection request\n");
- mock_set_pnal_udp_recvfrom_buffer (connect_req, sizeof (connect_req));
- run_stack (TEST_UDP_DELAY);
- EXPECT_EQ (appdata.call_counters.state_calls, 1);
- EXPECT_EQ (appdata.call_counters.connect_calls, 1);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_STARTUP);
- EXPECT_GT (mock_os_data.eth_send_count, 0);
- TEST_TRACE ("\nGenerating mock parameter end request\n");
- mock_set_pnal_udp_recvfrom_buffer (prm_end_req, sizeof (prm_end_req));
- run_stack (TEST_UDP_DELAY);
- EXPECT_EQ (appdata.call_counters.state_calls, 2);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_PRMEND);
- EXPECT_EQ (appdata.call_counters.connect_calls, 1);
- TEST_TRACE ("\nSimulate application calling APPL_RDY\n");
- TEST_TRACE ("Line %d\n", __LINE__);
- ret = pnet_application_ready (net, appdata.main_arep);
- EXPECT_EQ (ret, 0);
- EXPECT_EQ (appdata.call_counters.state_calls, 3);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_APPLRDY);
- TEST_TRACE ("\nGenerating mock application ready response\n");
- mock_set_pnal_udp_recvfrom_buffer (appl_rdy_rsp, sizeof (appl_rdy_rsp));
- run_stack (TEST_UDP_DELAY);
- EXPECT_EQ (appdata.call_counters.state_calls, 3);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_APPLRDY);
- TEST_TRACE ("\nSend a couple of data packets and verify reception\n");
- for (ix = 0; ix < 100; ix++)
- {
- send_data (
- data_packet_good_iops_good_iocs,
- sizeof (data_packet_good_iops_good_iocs));
- run_stack (TEST_DATA_DELAY);
- }
- iops = 88; /* Something non-valid */
- in_len = sizeof (in_data);
- ret = pnet_output_get_data_and_iops (
- net,
- TEST_API_IDENT,
- TEST_SLOT_IDENT,
- TEST_SUBSLOT_IDENT,
- &new_flag,
- in_data,
- &in_len,
- &iops);
- EXPECT_EQ (ret, 0);
- EXPECT_EQ (new_flag, true);
- EXPECT_EQ (in_len, 1);
- EXPECT_EQ (in_data[0], 0x23);
- EXPECT_EQ (iops, PNET_IOXS_GOOD);
- iocs = 77; /* Something non-valid */
- ret = pnet_input_get_iocs (
- net,
- TEST_API_IDENT,
- TEST_SLOT_IDENT,
- TEST_SUBSLOT_IDENT,
- &iocs);
- EXPECT_EQ (ret, 0);
- EXPECT_EQ (new_flag, true);
- EXPECT_EQ (in_len, 1);
- EXPECT_EQ (iocs, PNET_IOXS_GOOD);
- EXPECT_EQ (appdata.call_counters.state_calls, 4);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_DATA);
- TEST_TRACE ("\nSend some data to the controller\n");
- ret = pnet_input_set_data_and_iops (
- net,
- TEST_API_IDENT,
- TEST_SLOT_IDENT,
- TEST_SUBSLOT_IDENT,
- out_data,
- sizeof (out_data),
- PNET_IOXS_GOOD);
- EXPECT_EQ (ret, 0);
- TEST_TRACE ("\nAcknowledge the reception of controller data\n");
- ret = pnet_output_set_iocs (
- net,
- TEST_API_IDENT,
- TEST_SLOT_IDENT,
- TEST_SUBSLOT_IDENT,
- PNET_IOXS_GOOD);
- EXPECT_EQ (ret, 0);
- EXPECT_EQ (appdata.call_counters.state_calls, 4);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_DATA);
- /* Send data to avoid timeout */
- send_data (
- data_packet_good_iops_good_iocs,
- sizeof (data_packet_good_iops_good_iocs));
- run_stack (TEST_DATA_DELAY);
- TEST_TRACE ("\nCreate a logbook entry\n");
- pnet_create_log_book_entry (net, appdata.main_arep, &pnio_status, 0x13245768);
- TEST_TRACE ("\nCreate a diag and an alarm.\n");
- pnet_diag_std_add (
- net,
- &diag_source,
- TEST_CHANNEL_NUMBER_OF_BITS,
- PNET_DIAG_CH_PROP_MAINT_FAULT,
- TEST_CHANNEL_ERRORTYPE,
- TEST_DIAG_EXT_ERRTYPE,
- TEST_DIAG_EXT_ADDVALUE,
- TEST_DIAG_QUALIFIER_NOTSET);
- TEST_TRACE ("Number of tests: %u\n", (unsigned)NELEMENTS (test_reads));
- TEST_TRACE ("\nNow read all the records\n");
- for (ix = 0; ix < NELEMENTS (test_reads); ix++)
- {
- test_read (test_reads[ix]);
- }
- EXPECT_EQ (appdata.read_fails, 61); // Currently expected number of fails.
- TEST_TRACE ("\nGenerating mock release request\n");
- mock_set_pnal_udp_recvfrom_buffer (release_req, sizeof (release_req));
- run_stack (TEST_UDP_DELAY);
- EXPECT_EQ (appdata.call_counters.release_calls, 1);
- EXPECT_EQ (appdata.call_counters.state_calls, 5);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_ABORT);
- }
- TEST_F (CmrdrTest, CmrdrModDiffTest)
- {
- int ret;
- pnet_pnio_status_t pnio_status = {1, 2, 3, 4};
- bool new_flag = false;
- uint8_t in_data[10];
- uint16_t in_len = sizeof (in_data);
- uint8_t out_data[] = {
- 0x33, /* Slot 1, subslot 1 Data */
- };
- uint8_t iops = PNET_IOXS_BAD;
- uint8_t iocs = PNET_IOXS_BAD;
- uint32_t ix;
- const uint16_t slot = 1;
- const uint16_t subslot = 1;
- // TODO This test used to have an offset for the submodule identifier value
- // in the on_submodule callback. However it does not make any difference
- // for the test result
- TEST_TRACE ("\nGenerating mock connection request\n");
- mock_set_pnal_udp_recvfrom_buffer (connect_req, sizeof (connect_req));
- run_stack (TEST_UDP_DELAY);
- EXPECT_EQ (appdata.call_counters.state_calls, 1);
- EXPECT_EQ (appdata.call_counters.connect_calls, 1);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_STARTUP);
- EXPECT_GT (mock_os_data.eth_send_count, 0);
- TEST_TRACE ("\nGenerating mock parameter end request\n");
- mock_set_pnal_udp_recvfrom_buffer (prm_end_req, sizeof (prm_end_req));
- run_stack (TEST_UDP_DELAY);
- EXPECT_EQ (appdata.call_counters.state_calls, 2);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_PRMEND);
- EXPECT_EQ (appdata.call_counters.connect_calls, 1);
- TEST_TRACE ("\nSimulate application calling APPL_RDY\n");
- ret = pnet_application_ready (net, appdata.main_arep);
- EXPECT_EQ (ret, 0);
- EXPECT_EQ (appdata.call_counters.state_calls, 3);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_APPLRDY);
- TEST_TRACE ("\nGenerating mock application ready response\n");
- mock_set_pnal_udp_recvfrom_buffer (appl_rdy_rsp, sizeof (appl_rdy_rsp));
- run_stack (TEST_UDP_DELAY);
- EXPECT_EQ (appdata.call_counters.state_calls, 3);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_APPLRDY);
- TEST_TRACE ("\nSend a couple of data packets and verify reception\n");
- for (ix = 0; ix < 100; ix++)
- {
- send_data (
- data_packet_good_iops_good_iocs,
- sizeof (data_packet_good_iops_good_iocs));
- run_stack (TEST_DATA_DELAY);
- }
- iops = 88; /* Something non-valid */
- in_len = sizeof (in_data);
- ret = pnet_output_get_data_and_iops (
- net,
- TEST_API_IDENT,
- slot,
- subslot,
- &new_flag,
- in_data,
- &in_len,
- &iops);
- EXPECT_EQ (ret, 0);
- EXPECT_EQ (new_flag, true);
- EXPECT_EQ (in_len, 1);
- EXPECT_EQ (in_data[0], 0x23);
- EXPECT_EQ (iops, PNET_IOXS_GOOD);
- iocs = 77; /* Something non-valid */
- ret = pnet_input_get_iocs (net, TEST_API_IDENT, slot, subslot, &iocs);
- EXPECT_EQ (ret, 0);
- EXPECT_EQ (new_flag, true);
- EXPECT_EQ (in_len, 1);
- EXPECT_EQ (iocs, PNET_IOXS_GOOD);
- EXPECT_EQ (appdata.call_counters.state_calls, 4);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_DATA);
- /* Send some data to the controller */
- TEST_TRACE ("Line %d\n", __LINE__);
- ret = pnet_input_set_data_and_iops (
- net,
- TEST_API_IDENT,
- slot,
- subslot,
- out_data,
- sizeof (out_data),
- PNET_IOXS_GOOD);
- EXPECT_EQ (ret, 0);
- /* Acknowledge the reception of controller data */
- ret =
- pnet_output_set_iocs (net, TEST_API_IDENT, slot, subslot, PNET_IOXS_GOOD);
- EXPECT_EQ (ret, 0);
- EXPECT_EQ (appdata.call_counters.state_calls, 4);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_DATA);
- /* Setup some record for the reader */
- TEST_TRACE ("Line %d\n", __LINE__);
- /* Create a logbook entry */
- pnet_create_log_book_entry (net, appdata.main_arep, &pnio_status, 0x13245768);
- TEST_TRACE ("Number of tests: %u\n", (unsigned)NELEMENTS (test_mod_diff));
- /* Now read all the mod diff record */
- for (ix = 0; ix < NELEMENTS (test_mod_diff); ix++)
- {
- test_read (test_mod_diff[ix]);
- }
- EXPECT_EQ (appdata.read_fails, 0);
- TEST_TRACE ("\nGenerating mock release request\n");
- mock_set_pnal_udp_recvfrom_buffer (release_req, sizeof (release_req));
- run_stack (TEST_UDP_DELAY);
- EXPECT_EQ (appdata.call_counters.release_calls, 1);
- EXPECT_EQ (appdata.call_counters.state_calls, 5);
- EXPECT_EQ (appdata.cmdev_state, PNET_EVENT_ABORT);
- }
|