File: help_quality_test.go

package info (click to toggle)
golang-github-smallstep-cli 0.15.16%2Bds-4
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 4,404 kB
  • sloc: sh: 512; makefile: 99
file content (88 lines) | stat: -rw-r--r-- 3,113 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
// +build integration

package integration

import (
	"encoding/json"
	"fmt"
	"io/ioutil"
	"sort"
	"strings"
	"testing"

	"github.com/smallstep/assert"
	"github.com/smallstep/cli/usage"
)

func TestHelpQuality(t *testing.T) {
	cmd := NewCLICommand().setCommand("../bin/step help").setFlag("html", "./html").setFlag("report", "")
	cmd.run()

	raw, _ := ioutil.ReadFile("./html/report.json")
	var report *usage.Report
	json.Unmarshal([]byte(raw), &report)

	expectations := make(map[string]usage.Section)
	expectations["COMMANDS"] = usage.Section{Name: "COMMANDS", Words: 0, Lines: 0}
	expectations["COPYRIGHT"] = usage.Section{Name: "COPYRIGHT", Words: 5, Lines: 1}
	expectations["DESCRIPTION"] = usage.Section{Name: "DESCRIPTION", Words: 8, Lines: 1}
	expectations["EXAMPLES"] = usage.Section{Name: "EXAMPLES", Words: 10, Lines: 1}
	expectations["EXIT CODES"] = usage.Section{Name: "EXIT CODES", Words: 12, Lines: 1}
	expectations["ONLINE"] = usage.Section{Name: "ONLINE", Words: 7, Lines: 1}
	expectations["OPTIONS"] = usage.Section{Name: "OPTIONS", Words: 6, Lines: 2}
	expectations["POSITIONAL ARGUMENTS"] = usage.Section{Name: "POSITIONAL ARGUMENTS", Words: 6, Lines: 2}
	expectations["PRINTING"] = usage.Section{Name: "PRINTING", Words: 23, Lines: 1}
	expectations["SECURITY CONSIDERATIONS"] = usage.Section{Name: "SECURITY CONSIDERATIONS", Words: 220, Lines: 25}
	expectations["STANDARDS"] = usage.Section{Name: "STANDARDS", Words: 45, Lines: 10}
	expectations["USAGE"] = usage.Section{Name: "USAGE", Words: 2, Lines: 1}
	expectations["VERSION"] = usage.Section{Name: "VERSION", Words: 3, Lines: 1}

	t.Run("Headlines consistency", func(t *testing.T) {
		var headlines []string
		for _, top := range report.Report {
			for _, section := range top.Sections {
				headlines = append(headlines, section.Name)
			}
		}
		sort.Strings(headlines)

		grouped := make(map[string]int)
		for _, line := range headlines {
			grouped[line]++
		}

		for item, count := range grouped {
			fmt.Printf("%s: %d\n", item, count)

			// Let's say only upper case considered headlines
			if strings.ToUpper(item) == item {

				_, ok := expectations[item]
				msg := fmt.Sprintf("Unexpected headline %s might lead to inconsistent docs", item)
				assert.Equals(t, ok, true, msg)
			}
		}
	})

	t.Run("Thresholds", func(t *testing.T) {
		for _, expected := range expectations {
			entries := report.PerHeadline(expected.Name)

			for _, entry := range entries {
				msgw := fmt.Sprintf("Short on words (%d < %d) in %s (%s)", entry.Words, expected.Words, entry.Command, expected.Name)
				msgl := fmt.Sprintf("Short on lines (%d < %d) in %s (%s)", entry.Lines, expected.Lines, entry.Command, expected.Name)
				assert.True(t, entry.Words >= expected.Words, msgw)
				assert.True(t, entry.Lines >= expected.Lines, msgl)
			}
		}
	})

	t.Run("No TODOs", func(t *testing.T) {
		for _, top := range report.Report {
			for _, section := range top.Sections {
				msg := fmt.Sprintf("TODO found in %s (%s)", section.Command, section.Name)
				assert.False(t, strings.Contains(strings.ToUpper(section.Text), "TODO"), msg)
			}
		}
	})
}