104 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package cli
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"io"
 | |
| 	"strings"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/apex/log"
 | |
| 	"github.com/ooni/probe-cli/internal/util"
 | |
| )
 | |
| 
 | |
| func statusIcon(ok bool) string {
 | |
| 	if ok {
 | |
| 		return "✓"
 | |
| 	}
 | |
| 	return "❌"
 | |
| }
 | |
| func logMeasurementItem(w io.Writer, f log.Fields) error {
 | |
| 	colWidth := 24
 | |
| 
 | |
| 	rID := f.Get("id").(int64)
 | |
| 	testName := f.Get("test_name").(string)
 | |
| 
 | |
| 	// We currently don't use these fields in the view
 | |
| 	//testGroupName := f.Get("test_group_name").(string)
 | |
| 	//networkName := f.Get("network_name").(string)
 | |
| 	//asn := fmt.Sprintf("AS%d (%s)", f.Get("asn").(uint), f.Get("network_country_code").(string))
 | |
| 	testKeys := f.Get("test_keys").(string)
 | |
| 
 | |
| 	isAnomaly := f.Get("is_anomaly").(bool)
 | |
| 	isFailed := f.Get("is_failed").(bool)
 | |
| 	isUploaded := f.Get("is_uploaded").(bool)
 | |
| 	url := f.Get("url").(string)
 | |
| 	urlCategoryCode := f.Get("url_category_code").(string)
 | |
| 
 | |
| 	isFirst := f.Get("is_first").(bool)
 | |
| 	isLast := f.Get("is_last").(bool)
 | |
| 	if isFirst {
 | |
| 		fmt.Fprintf(w, "┏"+strings.Repeat("━", colWidth*2+2)+"┓\n")
 | |
| 	} else {
 | |
| 		fmt.Fprintf(w, "┢"+strings.Repeat("━", colWidth*2+2)+"┪\n")
 | |
| 	}
 | |
| 
 | |
| 	anomalyStr := fmt.Sprintf("ok: %s", statusIcon(!isAnomaly))
 | |
| 	uploadStr := fmt.Sprintf("uploaded: %s", statusIcon(isUploaded))
 | |
| 	failureStr := fmt.Sprintf("success: %s", statusIcon(!isFailed))
 | |
| 
 | |
| 	fmt.Fprintf(w, fmt.Sprintf("│ %s │\n",
 | |
| 		util.RightPad(
 | |
| 			fmt.Sprintf("#%d", rID), colWidth*2)))
 | |
| 
 | |
| 	if url != "" {
 | |
| 		fmt.Fprintf(w, fmt.Sprintf("│ %s │\n",
 | |
| 			util.RightPad(
 | |
| 				fmt.Sprintf("%s (%s)", url, urlCategoryCode), colWidth*2)))
 | |
| 	}
 | |
| 
 | |
| 	fmt.Fprintf(w, fmt.Sprintf("│ %s %s│\n",
 | |
| 		util.RightPad(testName, colWidth),
 | |
| 		util.RightPad(anomalyStr, colWidth)))
 | |
| 
 | |
| 	fmt.Fprintf(w, fmt.Sprintf("│ %s │\n",
 | |
| 		util.RightPad(testKeys, colWidth*2)))
 | |
| 	fmt.Fprintf(w, fmt.Sprintf("│ %s %s│\n",
 | |
| 		util.RightPad(failureStr, colWidth),
 | |
| 		util.RightPad(uploadStr, colWidth)))
 | |
| 
 | |
| 	if isLast {
 | |
| 		fmt.Fprintf(w, "└┬────────────────────────────────────────────────┬┘\n")
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func logMeasurementSummary(w io.Writer, f log.Fields) error {
 | |
| 	colWidth := 12
 | |
| 
 | |
| 	totalCount := f.Get("total_count").(int64)
 | |
| 	anomalyCount := f.Get("anomaly_count").(int64)
 | |
| 	totalRuntime := f.Get("total_runtime").(float64)
 | |
| 	dataUp := f.Get("data_usage_up").(float64)
 | |
| 	dataDown := f.Get("data_usage_down").(float64)
 | |
| 
 | |
| 	startTime := f.Get("start_time").(time.Time)
 | |
| 
 | |
| 	asn := f.Get("asn").(uint)
 | |
| 	countryCode := f.Get("network_country_code").(string)
 | |
| 	networkName := f.Get("network_name").(string)
 | |
| 
 | |
| 	fmt.Fprintf(w, " │ %s  │\n",
 | |
| 		util.RightPad(startTime.Format(time.RFC822), (colWidth+3)*3),
 | |
| 	)
 | |
| 	fmt.Fprintf(w, " │ %s  │\n",
 | |
| 		util.RightPad(fmt.Sprintf("AS%d, %s (%s)", asn, networkName, countryCode), (colWidth+3)*3),
 | |
| 	)
 | |
| 	fmt.Fprintf(w, " │ %s   %s   %s │\n",
 | |
| 		util.RightPad(fmt.Sprintf("%.2fs", totalRuntime), colWidth),
 | |
| 		util.RightPad(fmt.Sprintf("%d/%d anmls", anomalyCount, totalCount), colWidth),
 | |
| 		util.RightPad(fmt.Sprintf("⬆ %s  ⬇ %s", formatSize(dataUp), formatSize(dataDown)), colWidth+4))
 | |
| 	fmt.Fprintf(w, " └────────────────────────────────────────────────┘\n")
 | |
| 
 | |
| 	return nil
 | |
| }
 |