/* * Copyright (C) 2014 Freie Universität Berlin. * * This file is subject to the terms and conditions of the GNU Lesser * General Public License v2.1. See the file LICENSE in the top level * directory for more details. */ /** * @file testing.h * @brief Test suite for the 6LoWPAN Border Router. * * The tests are managed in the following way: * Packets (ICMPv6 Echo Request) are send onto the sensor node * via the serial interface. The user can then decide what she * wants to measure by calling testing_start() to start the * measuring and testing_stop() to end it. * * @author Martin Lenders */ #ifndef TESTING_H #define TESTING_H #include /** * @brief Defines the format to store test results. */ struct test_stats { uint8_t seq_num; ///< Sequence number of the send packet. /** * @brief Time difference between call of testing_start() and * testing_stop(). */ long int time_diff; }; /** * @brief Starts a test measuring. * @param[in] seq_num Sequence number of the measurement. */ void testing_start(uint8_t seq_num); /** * @brief Stops a test measuring. * @param[in] seq_num Sequence number of the measurement. */ void testing_stop(uint8_t seq_num); /** * @brief Starts the sending of the packets and initialises the * test environment * @param[in] ping_addr The address the packets should be * send to. * @param[in] results_dir_name Name of the results directory. * @param[in] skeleton_file Name of the skeleton file, where * the template for the results file * is. Lines of the formats * "# count=%ld (-c)\n" and * "# interval=%0.2f (-i)\n" * will be replaced with \%ld * set to runs_per_test and * \%0.2f set to * interval. * @param[in] runs_per_test How many packets shall be send in * this test. * @param[in] interval How many seconds shall lay between * the sending of each packet. */ void start_test(const char *ping_addr, const char *results_dir_name, const char *skeleton_file, int runs_per_test, float interval); #endif /* TESTING_H*/