mirror of
				https://github.com/Telecominfraproject/wlan-lanforge-scripts.git
				synced 2025-11-04 12:48:00 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			130 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			130 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
#!/usr/bin/env python3
 | 
						|
 | 
						|
import matplotlib.pyplot as plt 
 | 
						|
import matplotlib as mpl 
 | 
						|
import numpy as np 
 | 
						|
import pandas as pd
 | 
						|
import pdfkit
 | 
						|
from lf_report import lf_report
 | 
						|
from lf_graph import lf_bar_graph, lf_scatter_graph , lf_stacked_graph
 | 
						|
 | 
						|
# Unit Test
 | 
						|
if __name__ == "__main__":
 | 
						|
 | 
						|
    # Testing: generate data frame 
 | 
						|
    dataframe = pd.DataFrame({
 | 
						|
    'product':['CT521a-264-1ac-1n','CT521a-1ac-1ax','CT522-264-1ac2-1n','CT523c-2ac2-db-10g-cu','CT523c-3ac2-db-10g-cu','CT523c-8ax-ac10g-cu','CT523c-192-2ac2-1ac-10g'],
 | 
						|
    'radios':[1,1,2,2,6,9,3],
 | 
						|
    'MIMO':['N','N','N','Y','Y','Y','Y'],
 | 
						|
    'stations':[200,64,200,128,384,72,192],
 | 
						|
    'mbps':[300,300,300,10000,10000,10000,10000]
 | 
						|
    })
 | 
						|
 | 
						|
    print(dataframe)
 | 
						|
 | 
						|
    # Testing: generate data frame 
 | 
						|
    dataframe2 = pd.DataFrame({
 | 
						|
     'station':[1,2,3,4,5,6,7],
 | 
						|
     'time_seconds':[23,78,22,19,45,22,25]
 | 
						|
    })
 | 
						|
 | 
						|
 | 
						|
    #report = lf_report(_dataframe=dataframe)
 | 
						|
    report = lf_report()
 | 
						|
 | 
						|
    report_path = report.get_path()
 | 
						|
    report_path_date_time = report.get_path_date_time()
 | 
						|
 | 
						|
    print("path: {}".format(report_path))
 | 
						|
    print("path_date_time: {}".format(report_path_date_time))
 | 
						|
 | 
						|
    report.set_title("Banner Title One")
 | 
						|
    report.build_banner()
 | 
						|
 | 
						|
 | 
						|
    #report.set_title("Banner Title Two")
 | 
						|
    #report.build_banner()
 | 
						|
 | 
						|
    report.set_table_title("Title One")
 | 
						|
    report.build_table_title()
 | 
						|
 | 
						|
    report.set_table_dataframe(dataframe)
 | 
						|
    report.build_table()
 | 
						|
 | 
						|
    report.set_table_title("Title Two")
 | 
						|
    report.build_table_title()
 | 
						|
 | 
						|
    report.set_table_dataframe(dataframe2)
 | 
						|
    report.build_table()
 | 
						|
 | 
						|
    # test lf_graph in report
 | 
						|
    dataset = [[45,67,34,22],[22,45,12,34],[30,55,69,37]]
 | 
						|
    x_axis_values = [1,2,3,4]
 | 
						|
 | 
						|
    report.set_graph_title("Graph Title")
 | 
						|
    report.build_graph_title()
 | 
						|
    
 | 
						|
    graph = lf_bar_graph(_data_set=dataset, 
 | 
						|
                        _xaxis_name="stations", 
 | 
						|
                        _yaxis_name="Throughput 2 (Mbps)", 
 | 
						|
                        _xaxis_categories=x_axis_values,
 | 
						|
                        _graph_image_name="Bi-single_radio_2.4GHz",
 | 
						|
                        _label=["bi-downlink", "bi-uplink",'uplink'], 
 | 
						|
                        _color=None,
 | 
						|
                        _color_edge='red')
 | 
						|
 | 
						|
 | 
						|
    graph_png = graph.build_bar_graph()
 | 
						|
 | 
						|
    print("graph name {}".format(graph_png))
 | 
						|
 | 
						|
    report.set_graph_image(graph_png)
 | 
						|
    # need to move the graph image to the results 
 | 
						|
    report.move_graph_image()
 | 
						|
 | 
						|
    report.build_graph()
 | 
						|
    set1 = [1, 2, 3, 4]
 | 
						|
    set2 = [[45, 67, 45, 34], [34, 56, 45, 34], [45, 78, 23, 45]]
 | 
						|
    graph2 = lf_scatter_graph(_x_data_set=set1, _y_data_set=set2, _xaxis_name="x-axis",
 | 
						|
                              _yaxis_name="y-axis",
 | 
						|
                              _graph_image_name="image_name1",
 | 
						|
                              _color=None,
 | 
						|
                              _label=["s1", "s2", "s3"])
 | 
						|
    graph_png = graph2.build_scatter_graph()
 | 
						|
 | 
						|
    print("graph name {}".format(graph_png))
 | 
						|
 | 
						|
    report.set_graph_image(graph_png)
 | 
						|
    report.move_graph_image()
 | 
						|
 | 
						|
    report.build_graph()
 | 
						|
    dataset = [["1", "2", "3", "4"], [12, 45, 67, 34], [23, 67, 23, 12], [25, 45, 34, 23]]
 | 
						|
    graph = lf_stacked_graph(_data_set=dataset,
 | 
						|
                             _xaxis_name="Stations",
 | 
						|
                             _yaxis_name="Login PASS/FAIL",
 | 
						|
                             _label=['Success', 'Fail', 'both'],
 | 
						|
                             _graph_image_name="login_pass_fail1",
 | 
						|
                             _color=None)
 | 
						|
 | 
						|
    graph_png = graph.build_stacked_graph()
 | 
						|
 | 
						|
    print("graph name {}".format(graph_png))
 | 
						|
 | 
						|
    report.set_graph_image(graph_png)
 | 
						|
    report.move_graph_image()
 | 
						|
    report.build_graph()
 | 
						|
    #report.build_all()
 | 
						|
 | 
						|
    html_file = report.write_html() 
 | 
						|
    print("returned file {}".format(html_file))
 | 
						|
    print(html_file)
 | 
						|
 | 
						|
    # try other pdf formats
 | 
						|
    #report.write_pdf()
 | 
						|
    #report.write_pdf(_page_size = 'A3', _orientation='Landscape')
 | 
						|
    #report.write_pdf(_page_size = 'A4', _orientation='Landscape')
 | 
						|
    report.write_pdf(_page_size = 'Legal', _orientation='Landscape')
 | 
						|
    #report.write_pdf(_page_size = 'Legal', _orientation='Portrait')
 | 
						|
 | 
						|
    #report.generate_report()
 |