.. SPDX-License-Identifier: Apache-2.0 Copyright (C) 2020-2022 OKTET Labs Ltd. All rights reserved. .. index:: pair: group; Test Engine .. _doxid-group__te__engine: Test Engine =========== .. toctree:: :hidden: group_kernel_log.rst group_te_engine_builder.rst group_te_engine_conf.rst group_te_engine_logger.rst group_te_engine_dispatcher.rst group_te_engine_rcf.rst group_te_engine_tester.rst group_rgt.rst group_trc.rst .. _doxid-group__te__engine_1te_eng_introduction: Introduction ~~~~~~~~~~~~ Test Engine is a set of software components that provide essential features of Test Environment. It is unlikely that you will need to update any of Test Engine components, but more likely you will need to implement some helper libraries that utilize services provided by Test Engine or you will need to add some functionality in te_agents. .. image:: /static/image/ten_decomposition.png :alt: High Level decomposition of Test Engine Components Test Engine consists of the following components: * :ref:`Dispatcher `, which is responsible for configuring and starting of another subsystems; * :ref:`Builder `, which is responsible for preparing libraries and executables for te_agents and TE Subsystems as well as NUT bootable images and building the tests; * :ref:`Configurator `, which is responsible for configuring the environment, providing configuration information to tests and for recovering the configuration after failures. Moreover it supports some TEN-local database used by Test Packages to store shared data; * :ref:`Remote Control Facility (RCF) `, which is responsible for starting te_agents and for all interactions between :ref:`Test Engine ` and te_agents on behalf of other subsystems and tests; * :ref:`Tester `, which is responsible for running a set of Test Packages specified by a user in the mode specified by a user (one-by-one, simultaneous, debugging); * :ref:`Logger `, which provides logging facilities for Test Environment (:ref:`Test Engine ` and te_agents) and tests, and log processing tools for users. The following diagram gives more detailed information on relations between Test Environment components: .. image:: /static/image/ten_interconnections.png :alt: Interconnections of Test Engine components | :ref:`Builder` | :ref:`Configurator` | :ref:`API Usage: Configurator API` | :ref:`API: Configurator` | :ref:`Configuration backup manipulation` | :ref:`Configuration tree traversal` | :ref:`Configuration tree access operations` | :ref:`Synchronization configuration tree with Test Agent` | :ref:`Test Agent reboot` | :ref:`TAPI: Test API for configuration nodes` | :ref:`ARL table configuration` | :ref:`Agent namespaces configuration` | :ref:`Agents, namespaces and interfaces relations` | :ref:`Bonding and bridging configuration` | :ref:`CPU topology configuration of Test Agents` | :ref:`Command monitor TAPI` | :ref:`DHCP Server configuration` | :ref:`DUT serial console access` | :ref:`Environment variables configuration` | :ref:`Ethernet PHY configuration` | :ref:`Ethernet interface features configuration` | :ref:`IP rules configuration` | :ref:`IPv6 specific configuration` | :ref:`Kernel modules configuration` | :ref:`L2TP configuration` | :ref:`Local subtree access` | :ref:`Manipulation of network address pools` | :ref:`NTP daemon configuration` | :ref:`Neighbour table configuration` | :ref:`Network Base configuration` | :ref:`Network Emulator configuration` | :ref:`Network Interface configuration` | :ref:`Network Switch configuration` | :ref:`Network sniffers configuration` | :ref:`Network statistics access` | :ref:`Network topology configuration of Test Agents` | :ref:`PPPoE Server configuration` | :ref:`Processes configuration` | :ref:`Queuing Discipline configuration` | :ref:`tc qdisc TBF configuration` | :ref:`Routing Table configuration` | :ref:`Serial console parsers configuration` | :ref:`Solarflare PTP daemon configuration` | :ref:`System parameters configuration` | :ref:`TA system options configuration (OBSOLETE)` | :ref:`Test API to handle a cache` | :ref:`VTund configuration` | :ref:`Virtual machines configuration` | :ref:`XEN configuration` | :ref:`iptables configuration` | :ref:`Dispatcher` | :ref:`Logger` | :ref:`API: Logger` | :ref:`API: Logger messages stack` | :ref:`Remote Control Facility (RCF)` | :ref:`API Usage: Remote Control Facility API` | :ref:`API: RCF` | :ref:`API Usage: Remote Procedure Calls (RPC)` | :ref:`API: RCF RPC` | :ref:`RPC pointer namespaces` | :ref:`TAPI: Remote Procedure Calls (RPC)` | :ref:`Macros for socket API remote calls` | :ref:`TAPI for RTE EAL API remote calls` | :ref:`TAPI for RTE Ethernet Device API remote calls` | :ref:`TAPI for RTE FLOW API remote calls` | :ref:`TAPI for RTE MBUF API remote calls` | :ref:`TAPI for RTE MEMPOOL API remote calls` | :ref:`TAPI for RTE mbuf layer API remote calls` | :ref:`TAPI for RTE ring API remote calls` | :ref:`TAPI for asynchronous I/O calls` | :ref:`TAPI for directory operation calls` | :ref:`TAPI for interface name/index calls` | :ref:`TAPI for miscellaneous remote calls` | :ref:`TAPI for name/address resolution remote calls` | :ref:`TAPI for remote calls of Winsock2-specific routines` | :ref:`TAPI for remote calls of dynamic linking loader` | :ref:`TAPI for remote calls of power switch` | :ref:`TAPI for signal and signal sets remote calls` | :ref:`TAPI for socket API remote calls` | :ref:`TAPI for some file operations calls` | :ref:`TAPI for standard I/O calls` | :ref:`Report Generator Tool` | :ref:`Test Results Comparator` | :ref:`Tester`