Skip to main content

Perform traffic tests for TR-398 using ByteBlower.

Project description

Introduction

This package contains an implementation of the TR-398 Test using the ByteBlower Test Framework.

The primary goal of TR-398 is to provide a standard set of test cases and framework to measure aspect of the performance between Access Point, one or more reference Stations and if applicable, one Wi-Fi repeater, under controlled laboratory conditions.

Release notes

What can this version bring to you? See our exciting new and existing features below!

📢 New since v1.0.0! 📢

It is with great pleasure that we announce our new features of this test case!

TR-398 Airtime Fairness introduction

Airtime Fairness Test intends to verify the capability of the access point to guarantee the fairness of airtime usage.

This ByteBlower TR-398 Airtime Fairness test case allows you to:

  1. Run Airtime Fairness tests based on TR-398 Airtime Fairness Test

  2. Collect & Analyse statistics

  3. Generate HTML & JSON reports

For more detailed documentation, please have a look at Test Case: TR-398 Airtime Fairness in the ByteBlower API documentation.

Installation

Requirements

Prepare runtime environment

We recommend managing the runtime environment in a Python virtual environment. This guarantees proper separation of the system-wide installed Python and pip packages.

Python

The ByteBlower Test Framework currently supports Python versions 3.7 up to 3.11.

Important: Working directory

All the following sections expect that you first moved to your working directory where you want to run this project. You may also want to create your configuration files under a sub-directory of your choice.

  1. On Unix-based systems (Linux, WSL, macOS):

    cd '/path/to/working/directory'
  2. On Windows systems using PowerShell:

    cd 'c:\path\to\working\directory'

Python virtual environment

Make sure to use the right Python version (>= 3.7, <= 3.11), list all Python versions installed in your machine by running:

  1. On Windows systems using PowerShell:

    py --list

If no Python version is in the required range, you can download and install Python 3.7 or above using your system package manager or from https://www.python.org/ftp/python.

Prepare Python virtual environment: Create the virtual environment and install/update pip and build.

  1. On Unix-based systems (Linux, WSL, macOS):

    Note: Mind the leading . which means sourcing ./.venv/bin/activate.

    python3 -m venv --clear .venv
    . ./.venv/bin/activate
    pip install -U pip build
  2. On Windows systems using PowerShell:

    Note: On Microsoft Windows, it may be required to enable the Activate.ps1 script by setting the execution policy for the user. You can do this by issuing the following PowerShell command:

    PS C:> Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser

    See About Execution Policies for more information.

    Make sure to specify the python version you’re using. For example, for Python 3.8:

    py -3.8 -m venv --clear .venv
    & ".\.venv\Scripts\activate.ps1"
    python -m pip install -U pip build

To install the ByteBlower TR-398 test case and its dependencies, first make sure that you have activated your virtual environment:

  1. On Unix-based systems (Linux, WSL, macOS):

    . ./.venv/bin/activate
  2. On Windows systems using PowerShell:

    ./.venv/Scripts/activate.ps1

Then, run:

pip install -U byteblower-test-cases-tr-398

Quick start

Command-line interface

After providing the appropriate test setup and frame configurations, the test script can be run either as python module or as a command-line script.

For example (to get help for the command-line arguments):

  1. As a python module:

    # To get help for the command-line arguments:
    python -m byteblower.test_cases.tr_398 --help
  2. As a command-line script:

    # To get help for the command-line arguments:
    byteblower-test-cases-tr-398-airtime-fairness --help

To run the ByteBlower TR-398 Airtime Fairness test case, you should first provide your test configuration file.

you can use the Configuration file example as a reference. Make sure to update the example configuration to your actual setup configuration (ByteBlower server host name or IP, source and destination ports)

tr_398.json is the default configuration file name. You can use the argument --config-file to specify your configuration file.

The reports will be stored under a subdirectory reports/.

  1. On Unix-based systems (Linux, WSL, macOS):

    # Optional: create tr_398.json, then copy the configuration to it
    touch tr_398.json
    # Create reports folder to store HTML/JSON files
    mkdir reports
    # Run test
    byteblower-test-cases-tr-398-airtime-fairness --report-path reports
  2. On Windows systems using PowerShell:

    # Optional: create tr_398.json, then copy the configuration to it
    New-Item tr_398.json
    # Create reports folder to store HTML/JSON files
    md reports
    # Run test
    byteblower-test-cases-tr-398-airtime-fairness --report-path reports

Integrated

from byteblower.test_cases.tr_398.airtime_fairness import run

# Defining test configuration, report path and report file name prefix:
test_config = {} # Here you should provide your test setup + frame(s') configuration(s)
report_path = 'my-output-folder' # Optional: provide the path to the output folder, defaults to the current working directory
report_prefix = 'my-dut-feature-test' # Optional: provide prefix of the output files, defaults to 'report'

# Run the TR-398 Airtime fairness test:
run(test_config, report_path=report_path, report_prefix=report_prefix)

Configuration file example

{
    "server":"byteblower-server.example.com.",
    "meeting_point": "byteblower-meeting-point.example.com.",
    "dut": {
        "name": "DUT",
        "interface": "trunk-1-2",
        "ipv4": "192.168.5.2",
        "netmask": "255.255.255.0",
        "gateway": "192.168.5.254"
    },
    "wlan_stations": [
        {
            "name": "STA1",
            "uuid": "017d7da0-9724-4459-a037-bcec9acf577a",
            "ipv4": true
        },
        {
            "name": "STA2",
            "uuid": "9956866a-03a7-43c8-9cb9-8d3570d8c6a4",
            "ipv4": true
        },
        {
            "name": "STA3",
            "uuid": "4d9a5fdb-32b4-4523-ace9-5972518de13b",
            "ipv4": true
        }
    ]
}

More detailed documentation is available in the Configuration file section of the documentation.

Project details


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

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page