Changes since v2.2.0 include:
Released on 2024-09-10.
Changes since v2.1.1 include:
-
Support capturing and plotting CPU usage for individual CPUs instead of just a total.
-
Don't pass control_host values to IPv6 UDP_RR tests, as netperf doesn't support them.
-
Improve the GUI error message if matplotlib is not installed and when no tabs are open.
-
Fix compatibility with newer versions of Iperf2.
-
Fix a bunch of deprecation warnings and backwards compatibility issues with various Python and Matplotlib versions.
-
Fix some crashes in the GUI.
Released on 2022-11-02.
Changes since v2.1.0 include:
- Fix crash on summary output when numpy is not installed.
Released on 2022-11-02.
The main changes in this release are some reworking of process forking and output parsing to make it scale better, improving performance with tests with many runners. Another notable performance improvement is the addition of a cache for the lookup of runner binaries.
Changes since v2.0.1 include:
-
Add --irtt-sampling-interval parameter to run irtt at a different sampling interval than the rest of the test.
-
Add 99th percentile data to text-based output formats (like the default summary after running a test).
-
Add --test-payload option to support sending custom data files as the TCP payload in netperf tests.
-
Add caching of the results of looking up and probing the binaries used by the various runners to speed up test startup especially when using the remote launch feature to run binaries over ssh. By default the cache is only kept in memory (for a single run of 'flent'), but it can be made persistent with the --cache-file argument.
-
Rework the process forking used to fork off processes to run the test utilities. This significantly speeds up running tests with many flows, to the point where it's now possible to spawn 1000 runner subprocesses on a moderately powerful laptop.
-
Offload runner output parsing to parallel subprocesses, meaning that runner output parsing can take advantage of all available cores. This is only enabled on Linux as the multiprocessing module is a bit flaky, leading to hangs, on OSX.
-
Fix several issues with ping and fping when using --local-bind
-
Fix some issues with parsing the output of 'ss', and share the parsing output so the output data is only parsed once when getting the output of multiple flows.
-
Make sure to pass the right options to force irtt to use the same IP version as the rest of the test utilities.
-
Fix parsing of D-ITG output.
-
Fix an annoying crash when starting a test from the GUI.
Released on 2021-06-24.
Changes since v2.0.0 include:
-
Fix globbing in plot and test definitions so it works on newer Python versions
-
Don't hang forever while trying to process invalid time series data, and check fping timestamp output before using it (fixes a hang bug when using certain versions of fping on BSD and OSX)
-
Don't crash on metadata collection if hexdump is not available on the system.
-
Clarify that the Flent license doesn't apply to its output
Released on 2021-01-14.
This release drops support for Python 2 and Qt4, and associated older versions of matplotlib. The major version bump is to signify this change; otherwise consider this a (long overdue) regular incremental release over v1.3.0.
Changes since v1.3.0 include:
-
Drop support for Python 2; the minimum required Python version is now 3.5.
-
Drop support for old versions of libraries. The minimum supported version of matplotlib is 1.5, and for the GUI, Qt 5 is required, using either PyQt or PySide2. A new dependency on the 'QtPy' package is added to support both Qt bindings.
-
Add parsing of WiFi device information as extended metadata (from Emilly Albuquerque).
-
Add the ping_markings test parameter for setting DSCP values on ping flows.
-
Add new plot types to rrul_be, tcp_nup and related tests (from Pete Heist).
-
Add multiple-inheritance support for batch files (from Pete Heist).
-
Support running multiple instances of http-getter for HTTP tests, by supplying the --http-getter-urllist option multiple times.
-
Add new rrul_var test where the number of bidirectional streams can be configured via the bidir_streams test parameter.
-
Support output of aggregate statistics per series also in csv format (via the 'stats_csv' formatter).
-
Make sure all underlying tools use the same values for symbolic diffserv markings by parsing the symbolic names into numeric values before passing them down to the tools.
-
Support specifying custom symbolic diffserv markings using the --marking-name options. This can be used to specify site-specific names for diffserv markings (e.g., 'gaming') that can then be used when running a test.
-
Support specifying the same hostname multiple times (for tests that take multiple targets). Previously, this could only be achieved by using different hostnames that all resolve to the same IP address; now, Flent will accept the same hostname multiple times, but will turn append a number after two slashes ('//N') to the display of the hostname when doing so.
-
Support ranges and wildcards in the --remote-hosts parameter for running test runners remotely via SSH. For instance '--remote-host=1-3=host1' will run the first three runners on 'host1', or '--remote-host=*=host2' will run all runners on host2. If both concrete numbers (or ranges) and the wildcard are specified, the concrete numbers will take precedence.
-
Fix several bugs related to plotting, the loading of old data files and RC files, running of commands etc.
Released on 2019-11-26.
This is a bugfix-only release of the 1.3 series of Flent.
Changes since v1.3.1 include:
- Fix 'make test' which broke from partial bugfix backport
Released on 2019-11-26.
This is a bugfix-only release of the 1.3 series of Flent.
Changes since v1.3.0 include:
-
Fix calculation of pacing and delivery rate
-
Make sure series metadata is saved properly
-
Try to kill subprocesses with SIGINT before sending SIGTERM
-
Also try to parse stderr of runners; fixes issues with missing fping aggregate statistics.
-
Fix summary output with median values.
Released on 2019-07-09.
Note that this will be the last release with Python 2 support!
Changes since v1.2.2 include:
-
New --data-cutoff parameter filter data outside a specified time interval when plotting or formatting. This is useful for, e.g., showing flow behaviour after steady state has been reached for long-running tests.
-
New cc_algos test parameter to set per-flow congestion control algorithm being used by Netperf for TCP flows.
-
Storing lots more metadata from Netperf data series, including total elapsed time, total bytes sent and received and reported TOS.
-
Fixes to plot label override settings.
-
Option to copy metadata to clipboard from GUI right-click menu.
-
Support for passing DSCP mark values to Iperf.
-
Lots of bug fixes, mostly in the plotting and display code. And better test coverage to hopefully prevent things regressing again.
-
Addition of .appdata.xml file for the GUI, and an RPM spec file for packaging on RPM-based distros.
Released on 2018-04-17.
Changes since v1.2.1 include:
-
Add workaround for the new timeout behaviour in fping v4.0, which would result in no ping data being recorded.
-
Fix plotting bugs where the idle period at the start and end of tests were not removed from aggregate plots in single-flow TCP tests.
-
Add missing {bar,box}combine{up,down} plots to RRUL test.
-
Fix filtering of combination plot filenames and make sure legends are filtered in box plot ticklabels.
-
Add voip_marking test parameter to set diffserv marking for VoIP flows.
-
Add udp_flood_var_up_staggered test that runs multiple UDP flood flows with staggered start times.
Released on 2018-03-28.
Changes since v1.2.0 include:
-
Fix DSCP handling for irtt flows.
-
Fix several crashes in the GUI.
-
Fix handling of empty data series and several potential crashes in the plotting code.
-
Fix potential crash in metadata gathering and add timeout to commands.
-
Add several missing plots to various tests.
Released on 2018-02-06.
Changes since v1.1.1 include:
-
Add support for the irtt binary (https://github.com/peteheist/irtt/) for isochronous UDP latency tests. If irtt is available in $PATH, it will be preferred over netperf for UDP RTT tests and over D-ITG for VoIP tests. This means that UDP latency tests will no longer use more bandwidth as the RTT decreases, and VoIP tests are easier to setup. Many thanks to Pete Heist for writing the irtt tool.
As part of this change, a generic facility for runner preferences has been added, which makes it possible to define a test in terms of higher level functionality and let Flent pick the best available underlying tool to run the test. For now this is only used in the cases mentioned above for irtt.
-
Add a configurable option for overriding the colour mode for plots. This makes it possible to change how colours are assigned to different data series.
-
Improve handling of multi-value options between batch files, rc file and command line. This means that multi-value options can now use both comma and semicolon as separators in the batch file, and values can be quoted to prevent splitting.
-
Drop compatibility with matplotlib versions earlier than 1.4.2. Using older versions resulted in spurious errors anyway, and it is too much backporting work to support them properly.
-
Fix batch mode logging to make sure a log file for a batch run only includes log lines from that run and not previous runs.
-
Fix several bugs in the plotting and runner code.
Released on 2017-11-15.
Changes since v1.1.0 include:
- Fix several plotting bugs resulting from the overhaul of the plotting code. This includes a couple of crash bugs, bugs in the airtime plots, and a bug where all bar plots were completely broken, showing wrong values.
Released on 2017-10-26.
Changes since v1.0.1 include:
-
A complete overhaul of the plotting code so that it now uses the exact data points captured from the test tools wherever possible, instead of interpolating values to align data points on the time axis. This should improve the accuracy of plots, especially for integer-value data series such as packet drops.
-
The GUI has gained a new widget that makes it possible to control all plot-related settings. Previously, only a few of the settings for generating plots that are available on the command line could be set from within the GUI; now, the full set of command line settings can be manipulated in the GUI settings pane as well.
-
Another rewrite of the plot layout algorithm which should result in fewer issues with plot elements such as titles being drawn on top of the plot.
-
More keyboard shortcuts in the GUI: Ctrl+Up/Down will move between different plots, and x/X and y/Y will zoom the axes in/out.
-
By default, batch run order is now randomised to prevent periodic errors biasing results in long tests. This can be turned off with the --batch-no-shuffle option.
-
Netperf is now instructed to prefill its buffers with random data, instead of the data packets consisting repeated 7-byte strings ('netperf'). This ensures that data flows are not trivially compressible, which should improve test accuracy on encapsulated connections that enable compression.
-
Added support for setting TCP congestion control and diffserv markings as test parameters for some tests.
-
Added support for capturing socket statistics for TCP flows and store them as an auxiliary data set. This makes it possible to capture window size and RTT estimates from the kernel TCP state machine (Linux only). Thanks to Matthias Tafelmeier for the initial implementation of this feature.
-
Added support for watchdog timers to make sure runners don't go over time. This is applied to the fping runner thus far.
-
More metadata is captured from test runs; in particular, Netperf TCP_INFO variables, the congestion control used for each flow and socket buffer sizes are captured for every flow and stored in the metadata object.
-
Numerous bug fixes throughout.
Released on 2017-01-16.
Changes since v1.0.0 include:
-
Change the default hosts used for rtt_fair tests. One of the old ones did not exist anymore.
-
Fix a bunch of crashes and behavioural issues in the new test dialog in the GUI.
-
Make sure log entries emitted during startup make it to the GUI console.
Released on 2017-01-14.
Changes since v0.15.0 include:
-
With most of the longtime outstanding issues closed, Flent has now reached the big 1.0. Woohoo!
-
Use the UltraJSON library (if available) to load data files; this speeds up loading of data files moderately.
-
Improve logging of Flent's operations. The log file will now contain a proper superset of the console output, and Flent has been made slightly more verbose about what it is doing. Also, the log is now shown in a pane in the GUI.
-
Fix an error breaking plots on Python 2 and some versions of matplotlib.
-
Support PyQt5 in the GUI (and prefer it over PyQt4). If PyQt5 is not found, fall back to PyQt4.
-
Add new SummaryFormatter that outputs mean and median values for each data series. This is the new default formatter, meaning that its output will be shown after a test run if no other formatter (or plot) is specified.
-
Support multiprocessing in the GUI. When loading several plots at once, plotting will now be passed off to separate worker processes. This allows plotting to use all the available processors on the machine, and speeds up loading of many plots tremendously (initial load is sped up by an order of magnitude). This change also means that re-plotting on config changes will be done dynamically in the background, which makes the GUI more responsive.
-
Make text completely black in the default colour scheme. This increases contrast, and helps legibility, especially on printed figures.
-
Some internal code changes: Port command line parser from the old optparse class to the newer argparse, and fix a bunch of linter errors.
Released on 2016-10-01.
This release represents eight months of development since v0.14.0. There are several new features and a bunch of bugfixes. Also, starting from this release, Flent will be packaged for Debian and included in upcoming releases of both Debian and Ubuntu. Thanks to Iain Learmonth for sponsoring this.
Changes since v0.14.0 include:
-
Several new tests, including the rtt_fair_var* tests and tcp_n{up,down} tests which take a variable number of hostnames as targets.
-
Fixes to the UDP tests and a new test parameter to support setting UDP flow bandwidth.
-
Support for setting TOS values for some tests.
-
Added parser for WiFi statistics such as aggregation size and airtime (the latter requires a patched ath9k).
-
Support globbing in test plot specifications.
-
Added test mixins for adding several types of extra flows by specifying test parameters. These include ping flows, VoIP flows, HTTP traffic and WiFi and Qdisc stats. The parameters are documented in the 'tests' section of the man page and documentation.
-
Generate a UUID when running a batch sequence, and support grouping combination plots on these. This makes it possible to turn individual batch sequences into data series when plotting combination plots.
-
Support saving the intermedia result sets generated when creating combination plots. This speeds up subsequent plottings of the same data (which is helpful when experimenting with customising the plots).
-
Added a bunch of command line options to customise lots of aspects of the plot appearance (labels, legend placement, etc.). See man page or --help output for details.
-
Add a runner to parse /proc/net/netstat TCPext mib entries.
-
Customise plot appearance by directly setting matplotlib RC parameters instead of loading an RC file. This means that plots will always use the included style unless --no-matplotlibrc is used.
-
Allow plotting results from different test names on the same plot. This is especially useful with the mixins, which generate the same series names independent on which underlying test is used. No checking is done for whether two different tests make sense to plot together, though, so use common sense.
-
Support computing Jain's fairness index as a plot combiner. This means that it is now possible to plot the fairness index across averages of datasets, for instance to compare average throughput values over whole test runs.
-
Support computing (and plotting) MOS scores from latency and delay values using the ITU G.107 06/2015 E-model.
-
Added rudimentary support for running a test runner on a remote host. I.e. Flent can now SSH to another host and run (e.g.) a netperf instance and add that data into a test.
-
Support normalising data series by each other when plotting. This can be used to, for instance, normalise individual host throughput values by the total throughput to get a fractional value.
-
Support using the raw values when reducing data series in combination plots.
-
A bunch of bug fixes too numerous to list here.
Released on 2016-02-03.
This release adds mixins for capturing qdisc stats and CPU usage, adds some convenience functions to the GUI and fixes a bunch of bugs, most notably making the GUI work on Windows.
-
Batch mode: Try to estimate the total runtime of a batch and print it before executing the batch itself.
-
GUI: Add support for pinning a metadata item open when flipping between tabs, and support adding columns to the open files view from the metadata view. Both functions are available from the context menu when right-clicking in the metadata view.
-
Add test mixins to a bunch of tests making it possible to simultaneously capture qdisc stats and/or CPU stats of one or more hosts while the test is run. This works by setting the test parameters qdisc_stats_hosts, qdisc_stats_interfaces and cpu_stats_hosts to comma-separated lists of hosts and interface names. The functionality relies on the tc_iterator and stats_iterator helper scripts.
-
Add a C implementation of the tc_iterator helper script that works on OpenWrt and also gives higher polling accuracy than the shell script.
-
Add a kill_timeout setting for runners in test definitions which will forcibly kill a subprocess after an interval (if it hasn't exited already).
-
Add the tcp_upload_1000 test for seriously overloading things. On most systems, increasing the ulimit is necessary to run this test.
-
Support globbing selectors in plot configuration when specifying datasets for a plot.
-
Record number of failed runners (non-0 exit status) as a metadata key.
-
GUI: Fix bugs in plot blitting on older matplotlibs, fix test running without a pre-set HOST, fix bugs in draw cache handling, and restore the GUI to a working state on Windows.
-
Various bugfixes.
Released on 2015-11-06.
This release of Flent adds a couple of new features to the GUI, updates Iperf support and adds a bunch of bugfixes.
-
GUI: For line graphs (timeseries and CDF plots), highlight data series when the mouse is hovering over the lines themselves or their corresponding legend items. This makes it easier to pick out specific data series when browsing graphs. There's a toggle to turn off this feature, since it can perform badly on slow systems and/or causes flicker in some instances on OSX.
-
GUI: Experimental feature to run tests from the GUI. Fairly basic thus far, but it is possible to run a simple test from the GUI which will subsequently be loaded in the graph view.
-
File format: Bump file format to v3. The file format now uses UTC timestamps everywhere internally, which is an incompatible change; hence the version bump. Old data files will be loaded assuming local times and converted appropriately on load. File name date stamps are still done in local time for the box running the test.
-
Bring Iperf support up-to-date. The newest git version of Iperf (2) adds support for sub-second timestamps. Flent now detects this and can use and parse Iperf results when this support is detected. So far, no tests actually use Iperf, though.
-
Flent will now capture the module version of a running Cake shaper module as part of extended metadata. TCP buffer size limit sysctls are now also captured.
-
Some bug fixes related to matplotlib and Qt version compatibility and weirdness of the OSX file selector dialog.
Released on 2015-09-22.
This is a small bugfix release. Changes since v0.12.3:
-
Packaging fixes for Debian.
-
Support for Python 2.6 has officially been dropped (it had already bitrotted, so now a nicer error message is shown straight away).
-
Bug in local_bind for ping commands fixed.
-
More graphs for tcp_* tests and fixed labels on HTTP test graphs.
-
Catch unhandled exception that caused crashed when using a null output formatter.
Released on 2015-08-03.
This is a minor bugfix release, fixing an important regression in the GUI preventing files from being loaded when running under Python 2.
Released on 2015-07-29.
This release includes a major refactoring of the plotting code, which should make it easier to extend in the future.
Other changes since v0.11.1:
-
GUI restructuring: The plot settings now reside in a menu, the metadata view defaults to the bottom part of the window, and a new open files view has been added to make it easier to manage many open files at once in the GUI.
-
Revert to writing data files to the current directory by default. A new parameter, -D, can optionally select a different output dir.
-
The man page is now generated from the Sphinx documentation.
-
Try to detect if the system
ping
utility produces parsable output before using it. Should give nicer error messages on OSX if fping is not installed. -
Add a new qdisc-stats test which will periodically gather qdisc statistics and a wlan-retries test which will gather WiFi retry statistics.
-
New tests comparing different TCP congestion control algorithms have been added.
-
Add a --replace-legend parameter to do search/replace on legends when plotting.
-
A test suite has been added containing basic unittests for parts of the code. Test coverage is still fairly poor, but will be extended going forward. Run
make test
to run the test suite (requires the 'mock' Python library). -
VoIP tests can now show loss rates.
-
A bunch of bug fixes.