203 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			203 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package doc
 | 
						|
 | 
						|
import (
 | 
						|
	"bufio"
 | 
						|
	"bytes"
 | 
						|
	"fmt"
 | 
						|
	"io/ioutil"
 | 
						|
	"os"
 | 
						|
	"path/filepath"
 | 
						|
	"strings"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/spf13/cobra"
 | 
						|
)
 | 
						|
 | 
						|
var _ = fmt.Println
 | 
						|
var _ = os.Stderr
 | 
						|
 | 
						|
func translate(in string) string {
 | 
						|
	return strings.Replace(in, "-", "\\-", -1)
 | 
						|
}
 | 
						|
 | 
						|
func TestGenManDoc(t *testing.T) {
 | 
						|
	c := initializeWithRootCmd()
 | 
						|
	// Need two commands to run the command alphabetical sort
 | 
						|
	cmdEcho.AddCommand(cmdTimes, cmdEchoSub, cmdDeprecated)
 | 
						|
	c.AddCommand(cmdPrint, cmdEcho)
 | 
						|
	cmdRootWithRun.PersistentFlags().StringVarP(&flags2a, "rootflag", "r", "two", strtwoParentHelp)
 | 
						|
 | 
						|
	out := new(bytes.Buffer)
 | 
						|
 | 
						|
	header := &GenManHeader{
 | 
						|
		Title:   "Project",
 | 
						|
		Section: "2",
 | 
						|
	}
 | 
						|
	// We generate on a subcommand so we have both subcommands and parents
 | 
						|
	if err := GenMan(cmdEcho, header, out); err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
	found := out.String()
 | 
						|
 | 
						|
	// Make sure parent has - in CommandPath() in SEE ALSO:
 | 
						|
	parentPath := cmdEcho.Parent().CommandPath()
 | 
						|
	dashParentPath := strings.Replace(parentPath, " ", "-", -1)
 | 
						|
	expected := translate(dashParentPath)
 | 
						|
	expected = expected + "(" + header.Section + ")"
 | 
						|
	checkStringContains(t, found, expected)
 | 
						|
 | 
						|
	// Our description
 | 
						|
	expected = translate(cmdEcho.Name())
 | 
						|
	checkStringContains(t, found, expected)
 | 
						|
 | 
						|
	// Better have our example
 | 
						|
	expected = translate(cmdEcho.Name())
 | 
						|
	checkStringContains(t, found, expected)
 | 
						|
 | 
						|
	// A local flag
 | 
						|
	expected = "boolone"
 | 
						|
	checkStringContains(t, found, expected)
 | 
						|
 | 
						|
	// persistent flag on parent
 | 
						|
	expected = "rootflag"
 | 
						|
	checkStringContains(t, found, expected)
 | 
						|
 | 
						|
	// We better output info about our parent
 | 
						|
	expected = translate(cmdRootWithRun.Name())
 | 
						|
	checkStringContains(t, found, expected)
 | 
						|
 | 
						|
	// And about subcommands
 | 
						|
	expected = translate(cmdEchoSub.Name())
 | 
						|
	checkStringContains(t, found, expected)
 | 
						|
 | 
						|
	unexpected := translate(cmdDeprecated.Name())
 | 
						|
	checkStringOmits(t, found, unexpected)
 | 
						|
 | 
						|
	// auto generated
 | 
						|
	expected = translate("Auto generated")
 | 
						|
	checkStringContains(t, found, expected)
 | 
						|
}
 | 
						|
 | 
						|
func TestGenManNoGenTag(t *testing.T) {
 | 
						|
	c := initializeWithRootCmd()
 | 
						|
	// Need two commands to run the command alphabetical sort
 | 
						|
	cmdEcho.AddCommand(cmdTimes, cmdEchoSub, cmdDeprecated)
 | 
						|
	c.AddCommand(cmdPrint, cmdEcho)
 | 
						|
	cmdRootWithRun.PersistentFlags().StringVarP(&flags2a, "rootflag", "r", "two", strtwoParentHelp)
 | 
						|
	cmdEcho.DisableAutoGenTag = true
 | 
						|
	out := new(bytes.Buffer)
 | 
						|
 | 
						|
	header := &GenManHeader{
 | 
						|
		Title:   "Project",
 | 
						|
		Section: "2",
 | 
						|
	}
 | 
						|
	// We generate on a subcommand so we have both subcommands and parents
 | 
						|
	if err := GenMan(cmdEcho, header, out); err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
	found := out.String()
 | 
						|
 | 
						|
	unexpected := translate("#HISTORY")
 | 
						|
	checkStringOmits(t, found, unexpected)
 | 
						|
}
 | 
						|
 | 
						|
func TestGenManSeeAlso(t *testing.T) {
 | 
						|
	noop := func(cmd *cobra.Command, args []string) {}
 | 
						|
 | 
						|
	top := &cobra.Command{Use: "top", Run: noop}
 | 
						|
	aaa := &cobra.Command{Use: "aaa", Run: noop, Hidden: true} // #229
 | 
						|
	bbb := &cobra.Command{Use: "bbb", Run: noop}
 | 
						|
	ccc := &cobra.Command{Use: "ccc", Run: noop}
 | 
						|
	top.AddCommand(aaa, bbb, ccc)
 | 
						|
 | 
						|
	out := new(bytes.Buffer)
 | 
						|
	header := &GenManHeader{}
 | 
						|
	if err := GenMan(top, header, out); err != nil {
 | 
						|
		t.Fatal(err)
 | 
						|
	}
 | 
						|
 | 
						|
	scanner := bufio.NewScanner(out)
 | 
						|
 | 
						|
	if err := AssertLineFound(scanner, ".SH SEE ALSO"); err != nil {
 | 
						|
		t.Fatal(fmt.Errorf("Couldn't find SEE ALSO section header: %s", err.Error()))
 | 
						|
	}
 | 
						|
 | 
						|
	if err := AssertNextLineEquals(scanner, ".PP"); err != nil {
 | 
						|
		t.Fatal(fmt.Errorf("First line after SEE ALSO wasn't break-indent: %s", err.Error()))
 | 
						|
	}
 | 
						|
 | 
						|
	if err := AssertNextLineEquals(scanner, `\fBtop\-bbb(1)\fP, \fBtop\-ccc(1)\fP`); err != nil {
 | 
						|
		t.Fatal(fmt.Errorf("Second line after SEE ALSO wasn't correct: %s", err.Error()))
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestManPrintFlagsHidesShortDeperecated(t *testing.T) {
 | 
						|
	cmd := &cobra.Command{}
 | 
						|
	flags := cmd.Flags()
 | 
						|
	flags.StringP("foo", "f", "default", "Foo flag")
 | 
						|
	flags.MarkShorthandDeprecated("foo", "don't use it no more")
 | 
						|
 | 
						|
	out := new(bytes.Buffer)
 | 
						|
	manPrintFlags(out, flags)
 | 
						|
 | 
						|
	expected := "**--foo**=\"default\"\n\tFoo flag\n\n"
 | 
						|
	if out.String() != expected {
 | 
						|
		t.Fatalf("Expected %s, but got %s", expected, out.String())
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func TestGenManTree(t *testing.T) {
 | 
						|
	cmd := &cobra.Command{
 | 
						|
		Use: "do [OPTIONS] arg1 arg2",
 | 
						|
	}
 | 
						|
	header := &GenManHeader{Section: "2"}
 | 
						|
	tmpdir, err := ioutil.TempDir("", "test-gen-man-tree")
 | 
						|
	if err != nil {
 | 
						|
		t.Fatalf("Failed to create tempdir: %s", err.Error())
 | 
						|
	}
 | 
						|
	defer os.RemoveAll(tmpdir)
 | 
						|
 | 
						|
	if err := GenManTree(cmd, header, tmpdir); err != nil {
 | 
						|
		t.Fatalf("GenManTree failed: %s", err.Error())
 | 
						|
	}
 | 
						|
 | 
						|
	if _, err := os.Stat(filepath.Join(tmpdir, "do.2")); err != nil {
 | 
						|
		t.Fatalf("Expected file 'do.2' to exist")
 | 
						|
	}
 | 
						|
 | 
						|
	if header.Title != "" {
 | 
						|
		t.Fatalf("Expected header.Title to be unmodified")
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func AssertLineFound(scanner *bufio.Scanner, expectedLine string) error {
 | 
						|
	for scanner.Scan() {
 | 
						|
		line := scanner.Text()
 | 
						|
		if line == expectedLine {
 | 
						|
			return nil
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	if err := scanner.Err(); err != nil {
 | 
						|
		return fmt.Errorf("AssertLineFound: scan failed: %s", err.Error())
 | 
						|
	}
 | 
						|
 | 
						|
	return fmt.Errorf("AssertLineFound: hit EOF before finding %#v", expectedLine)
 | 
						|
}
 | 
						|
 | 
						|
func AssertNextLineEquals(scanner *bufio.Scanner, expectedLine string) error {
 | 
						|
	if scanner.Scan() {
 | 
						|
		line := scanner.Text()
 | 
						|
		if line == expectedLine {
 | 
						|
			return nil
 | 
						|
		}
 | 
						|
		return fmt.Errorf("AssertNextLineEquals: got %#v, not %#v", line, expectedLine)
 | 
						|
	}
 | 
						|
 | 
						|
	if err := scanner.Err(); err != nil {
 | 
						|
		return fmt.Errorf("AssertNextLineEquals: scan failed: %s", err.Error())
 | 
						|
	}
 | 
						|
 | 
						|
	return fmt.Errorf("AssertNextLineEquals: hit EOF before finding %#v", expectedLine)
 | 
						|
}
 |