Library for testing network virtual appliances using Docker
Project description
Alpy
Test network virtual appliance using Docker containers
This project is a Python library for testing network virtual appliances.
The appliance being tested is referred to as a device under test or DUT.
This repository includes scripts and modules to build a simple appliance called Rabbit. Rabbit is Alpine Linux with a few packages pre-installed. Having this simple DUT allows to quickly test the alpy library and to demonstrate its features.
The tests for the Rabbit device share a lot of code so the code is organized as a library. The library is called carrot.
Author
Alexey Bogdanenko
License
Alpy is licensed under:
SPDX-License-Identifier: GPL-3.0-or-later
See COPYING for more details.
Network design
The DUT communicates with containers attached to each of its network links.
Guest network adapters are connected to the host via tap devices (Figure 1).
+-----QEMU hypervisor------+
| | +-------------+
| +-----Guest OS-----+ | | |
| | | | | docker |
| | +--------------+ | | | container |
| | | | | | | network |
| | | NIC driver | | | | namespace |
| | | | | | | |
| +------------------+ | | +-----+ |
| | | | | | | |
| | NIC hardware +---+-----------+ tap | |
| | | | | | | | |
| +--------------+ | | | +-----+ |
| | | | |
+--------------------------+ +-------------+
|
|
v
+-----------+
| |
| pcap file |
| |
+-----------+
Figure 1. Network link between QEMU guest and a docker container.
Each tap device lives in its network namespace. This namespace belongs to a dedicated container - a node. The node's purpose is to keep the namespace alive during the lifetime of a test.
For an application to be able to communicate with the DUT the application is containerized. The application container must be created in a special way: it must share network namespace with one of the nodes.
Figure 2 shows an example where application containers app0 and app1 share network namespace with node container node0. Application container app2 shares another network namespace with node2.
This sharing is supported by Docker. All we have to do is to create the
application container with the --network=container:NODE_NAME
Docker option.
For example, if we want to send traffic to the DUT via its first link, we create
a traffic generator container with Docker option --network=container:node0
.
+----QEMU---+ +------shared network namespace-----+
| | | |
| | | eth0 |
| +---+ | | +---+ +-----+ +----+ +----+ |
| |NIC+-----------+tap| |node0| |app0| |app1| |
| +---+ | | +---+ +-----+ +----+ +----+ |
| | | |
| | +-----------------------------------+
| |
| |
| |
| | +------shared network namespace-----+
| | | |
| | | eth0 |
| +---+ | | +---+ +-----+ |
| |NIC+-----------+tap| |node1| |
| +---+ | | +---+ +-----+ |
| | | |
| | +-----------------------------------+
| |
| |
| |
| | +------shared network namespace-----+
| | | |
| | | eth0 |
| +---+ | | +---+ +-----+ +----+ |
| |NIC+-----------+tap| |node2| |app2| |
| +---+ | | +---+ +-----+ +----+ |
| | | |
+-----------+ +-----------------------------------+
Figure 2. Application containers attached to the DUT links.
A note about GitLab Container Registry
Many CI jobs use one of the custom images built on the "build-docker-images" stage. The images are stored in the GitLab Container Registry.
The images are pulled from locations specified by GitLab variables. By default, the variables point to the registry of the current GitLab project.
If you forked this project and GitLab Container Registry is disabled in your project, override the variables on a project level so that the images are pulled from some other registry.
For example, set IMAGE_ALPINE=registry.gitlab.com/abogdanenko/alpy/alpine
.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file alpy-0.22.0.tar.gz
.
File metadata
- Download URL: alpy-0.22.0.tar.gz
- Upload date:
- Size: 10.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | be63995646e6dbac48adb8dca322d37496a6718f68d60aded39f7e9a41195905 |
|
MD5 | c5b621f0597aa9822a07083fb8580849 |
|
BLAKE2b-256 | ed0e3cd5f6f1392bc3209a60183d14cd4f15dcf522b1ea82e7c6ba66e107e519 |
File details
Details for the file alpy-0.22.0-py3-none-any.whl
.
File metadata
- Download URL: alpy-0.22.0-py3-none-any.whl
- Upload date:
- Size: 23.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.7.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3b561ddd629d38405845811c70efca8f8db7c08730fc51c92b6892014166e605 |
|
MD5 | 08520ae0be36dd5eeaa820b55a9d917f |
|
BLAKE2b-256 | 5dc68646fb73f297b99d2dc664a5159c2be99a17e802972a2b565a830a361242 |