TEACUP
    
            
                
                    TCP Experiment Automation Controlled Using Python
                
            
             
            
             
            
        
            TEACUP automates many aspects of running TCP performance experiments in a specially-constructed physical testbed. TEACUP enables repeatable testing of different TCP algorithms over a range of emulated network path conditions, bottleneck rate limits and bottleneck queuing disciplines.
TEACUP utilises a text-based configuration file to define experiments as combinations of parameters specifying desired network path and end host conditions. When multiple values are provided (e.g. for TCP congestion control algorithm), an experiment is made up of multiple tests.
For each experiment and test, TEACUP collects a range of data, such as tcpdump files of traffic seen  or TCP stack information (e.g. using Web10G). TEACUP also collects a variety of metadata from the end hosts and bottleneck router, such as the actual OS/kernel version(s) used.
TEACUP also provides some simple tools for analysing the results of experiments, such as plotting a flow's experienced RTT over time.