.. SPDX-License-Identifier: Apache-2.0 Copyright (C) 2019-2022 OKTET Labs Ltd. All rights reserved. .. index:: pair: group; Test Environment .. _doxid-group__te: Test Environment ================ .. toctree:: :hidden: pages/group_terminology pages/group_te_ts pages/group_te_user pages/group_te_engine pages/group_te_agents pages/group_te_tools pages/selftest pages/add_doc generated/global .. _doxid-group__te_1te_introduction: Introduction ~~~~~~~~~~~~ OKTET Labs Test Environment (TE) is a software product that is intended to ease creating automated test suites. The history of TE goes back to 2000 year when the first prototype of software was created. At that time the product was used for testing SNMP MIBs and CLI commands. Two years later (in 2002) software was extended to support testing of IPv6 protocol. Few years of intensive usage the software in testing projects showed that a deep re-design was necessary to make the architecture flexible and extandable for new and new upcoming features. In 2003 year it was decided that the redesign should be fulfilled. Due to the careful and well-thought design decisions made in 2003 year, the overall TE architecture (main components and interconnections between them) are still valid even though a lot of new features has been added since then. .. _doxid-group__te_1te_conventions: Conventions ~~~~~~~~~~~ Through the documentation the following conventions are used: * directory paths or file names marked as: ``/usr/bin/bash``, ``Makefile``; * program names (scripts or binary executables) marked as: ``gdb``, ``dispatcher.sh``; * program options are marked as: ``help``, ``-q``; * environment variables are marked as: ``TE_BASE``, ``${PATH}``; * different directives in configuration files are marked as: ``TE_LIB_PARMS``, ``include``; * configuration paths as marked as: ``/agent/interface``, ``/local:/net:A``; * names of different attributes (mainly names of XML element attributes) are marked as: ``type``, ``src``; * values of different attributes are marked as: ``unix``, ``${TE_BASE}/suites/ipv6-demo``; * different kind of commands or modes are marked as: ``Unregister``, ``live``. .. _doxid-group__te_1te_abrev_term: Abbreviations and Terminology ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ See :ref:`Terminology ` for the abbreviations and terminology. .. _doxid-group__te_1te_architecture: Test Environment Architecture ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ From the high level point of view TE consists of two main parts: * :ref:`Test Engine `; * :ref:`Test Agents `. The following picture shows high level decomposition of TE components: .. image:: /static/image/hl-decomposition.png :alt: High Level Decomposition of Test Environment components There are several kinds of Test Agents (see the diagram below): * Test Agent running on an auxiliary station and controlling this station: Test Protocol is used over a network and all commands are applied to the station on which Test Agent runs. * Test Agent running on an auxiliary station and controlling the NUT: :ref:`Test Protocol ` is used over a network and all commands are applied to the NUT (Test Agent interacts with the NUT via a NUT-specific interface). * Test Agent running on a NUT and controlling the NUT: Test Protocol is used over a network or over some other transport (for example, over a serial port or Ethernet) and all commands are applied to the NUT. Selection of appropriate usage scenario depends on the object being tested. If it's a network device the Test Agent can run either on the device itself or (if black box testing is performed or device hardware is not capable of running the agent) on an auxiliary station. If a network library is tested then the agent should probably be running on the NUT itself (in such case NUT is the host on which the service that uses the library is running). Apart from these three kinds of agents (or should they be called 'Test Agent usage scenarios') there can exist arbitrary number of agents running on other equipments which participates in the testing process. Examples include: * other hosts which are used for traffic generation; * proxy agents which are used to control various services used for network environment creation or DUT configuration via management protocols; * agents used for debug information collection, for instance serial logs. The below diagram shows various scenarios and Test Agents locations. .. image:: /static/image/te_agent_types.png :alt: Stations and applications participating in the testing process TE subsystems and :ref:`Test Agents ` are distributed among several applications running on different stations. Apart from other things :ref:`Test Engine ` controls :ref:`Test Agents ` by means of so-called :ref:`Test Protocol ` * a text-based protocol used in communication between :ref:`Test Engine ` and :ref:`Test Agents `. According to initial design :ref:`Test Engine ` runs on Linux platform and there is no intend to port it to any other OS type, but :ref:`Test Agents ` can be run on different platforms providing particular set of mandatory features for :ref:`Test Engine `. :ref:`Test Agents ` are the subject to be ported to hardware/software specific components of test infrastructure. .. _doxid-group__te_1te_tools: Test Environment Tools ~~~~~~~~~~~~~~~~~~~~~~ Apart from main components, TE provides the following set of tools: * :ref:`Report Generator Tool ` representing logs in different formats; * :ref:`Test Results Comparator ` utility that can be used to check the difference between different test runs (TRC tool); * :ref:`Packet Sniffer ` to be used for traffic capture on the test agents; * **Testing Coverage Estimation** tool that gives some report about the quality of test suite we run against the software under test; * **Test Package Generator** tool. | :ref:`Common tools API` | :ref:`Call shell commands` | :ref:`Date, time` | :ref:`Dynamic array` | :ref:`Dynamic buffers` | :ref:`Dynamic strings` | :ref:`Execute a program in a child process` | :ref:`File operations` | :ref:`Format string parsing` | :ref:`IP stack headers` | :ref:`Key-value pairs` | :ref:`Log buffers` | :ref:`Log format string processing` | :ref:`Logger subsystem` | :ref:`Machine interface data logging` | :ref:`MI measurement-specific declarations` | :ref:`Mapping of unix signal names and numbers` | :ref:`Regular binary buffers` | :ref:`Regular strings` | :ref:`Safe memory allocation` | :ref:`Serial console` | :ref:`Serial console common tools` | :ref:`Serial console parser` | :ref:`Sleep` | :ref:`Sockaddr` | :ref:`Tail queue of strings` | :ref:`Toeplitz hash` | :ref:`Unit-conversion` | :ref:`Unix Kernel Logger` | :ref:`iSCSI` | :ref:`TE: User Guide` | :ref:`Network namespaces` | :ref:`TE Config Files Basics` | :ref:`Terminology` | :ref:`Test Agents` | :ref:`Test Agents: Command Handler` | :ref:`Command Handler: Configuration support` | :ref:`Configuration node definition macros` | :ref:`Command Handler: File manipulation support` | :ref:`Command Handler: Function call support` | :ref:`Command Handler: Process/thread support` | :ref:`Command Handler: Reboot and shutdown support` | :ref:`Command Handler: Symbol name and address resolver support` | :ref:`Command Handler: Traffic Application Domain (TAD) support` | :ref:`Command Handler: Variables support` | :ref:`Test Agents: Creating new configuration nodes in Test Agent` | :ref:`Test Agents: Portable Commands Handler` | :ref:`API: Shared TA resources` | :ref:`Test Agents: Unix Test Agent` | :ref:`Test Agents: Windows Test Agent` | :ref:`Test Engine` | :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:`NTP daemon configuration` | :ref:`Network Base configuration` | :ref:`Network Emulator 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:`Queuing Discipline configuration` | :ref:`Routing Table configuration` | :ref:`Manipulation of network address pools` | :ref:`Neighbour table configuration` | :ref:`Network Interface 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:`Kernel Logging` | :ref:`Console Log Level Configuration` | :ref:`Packet Serial Parser` | :ref:`Logger` | :ref:`API: Logger` | :ref:`API: Logger messages stack` | :ref:`Command Output Logging` | :ref:`Packet Sniffer` | :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` | :ref:`Test Suite` | :ref:`Network topology configuration of Test Agents` | :ref:`Test API` | :ref:`Agent job control` | :ref:`Helper functions for handling options` | :ref:`convenience macros for option` | :ref:`functions for argument formatting` | :ref:`BPF/XDP configuration of Test Agents` | :ref:`Control NVMeOF` | :ref:`Kernel target` | :ref:`ONVMe target` | :ref:`Control network channel using a gateway` | :ref:`DPDK RTE flow helper functions TAPI` | :ref:`DPDK helper functions TAPI` | :ref:`DPDK statistics helper functions TAPI` | :ref:`Engine and TA files management` | :ref:`FIO tool` | :ref:`Control a FIO tool` | :ref:`FIO tool internals` | :ref:`GTest support` | :ref:`High level TAPI to configure network` | :ref:`High level TAPI to work with sockets` | :ref:`I/O multiplexers` | :ref:`Macros to get test parameters on a gateway configuration` | :ref:`Network Traffic TAPI` | :ref:`CSAP TAPI` | :ref:`Route Gateway TAPI` | :ref:`TAPI for testing TCP states` | :ref:`TAPI definitions for testing TCP states` | :ref:`TCP socket emulation` | :ref:`RADIUS Server Configuration and RADIUS CSAP` | :ref:`Stack of jumps` | :ref:`Target requirements modification` | :ref:`Test` | :ref:`Network environment` | :ref:`Test execution flow` | :ref:`Test misc` | :ref:`Test parameters` | :ref:`Test run status` | :ref:`Test API to control a network throughput test tool` | :ref:`Test API to control Unbound DNS server` | :ref:`Test API to generate Unbound DNS server config file` | :ref:`Test API to generate zone file` | :ref:`Test API to operate the UPnP` | :ref:`Test API for DLNA UPnP commons` | :ref:`Test API to operate the DLNA UPnP Content Directory Resources` | :ref:`Test API to operate the DLNA UPnP Content Directory Service` | :ref:`Test API to operate the DLNA UPnP Device information` | :ref:`Test API to operate the DLNA UPnP Service information` | :ref:`Test API to operate the UPnP Control Point` | :ref:`Test API to operate the media data` | :ref:`Test API to control a media player` | :ref:`Test API to control the mplayer media player` | :ref:`Test API to operate the DLNA media files` | :ref:`Test API to operate the media files` | :ref:`Test API to operate the storage` | :ref:`Test API to control the local storage device` | :ref:`Test API to control the storage FTP client` | :ref:`Test API to control the storage client` | :ref:`Test API to control the storage server` | :ref:`Test API to perform the generic operations over the storage` | :ref:`Test API to use memory-related functions conveniently` | :ref:`Test API to use packetdrill test tool` | :ref:`Test API to control Wi-Fi client` | :ref:`Tools to work with "struct sockaddr"` | :ref:`Traffic Application Domain` | :ref:`ARP` | :ref:`ATM` | :ref:`CLI` | :ref:`DHCP` | :ref:`Ethernet` | :ref:`Forwarder module` | :ref:`Generic TAD API` | :ref:`IGMP` | :ref:`IP stack` | :ref:`Common functions for IPv4 and IPv6` | :ref:`ICMP` | :ref:`ICMP4` | :ref:`ICMP6` | :ref:`IPv4` | :ref:`IPv6` | :ref:`Socket` | :ref:`TCP` | :ref:`UDP` | :ref:`Network Data Notation (NDN)` | :ref:`PCAP` | :ref:`PPP` | :ref:`PPPOE` | :ref:`Packet flow processing` | :ref:`RTE mbuf` | :ref:`SNMP` | :ref:`STP` | :ref:`iSCSI` | :ref:`tool functions TAPI` | :ref:`tool functions TAPI` | :ref:`The format of test suite scenarios`