spf13--cobra/doc/man_docs_test.go

98 lines
2.5 KiB
Go
Raw Normal View History

package doc
2015-08-18 22:33:41 +00:00
import (
"bytes"
"fmt"
"os"
"strings"
"testing"
)
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",
}
2015-08-18 22:33:41 +00:00
// We generate on a subcommand so we have both subcommands and parents
if err := GenMan(cmdEcho, header, out); err != nil {
t.Fatal(err)
}
2015-08-18 22:33:41 +00:00
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)
2015-08-18 22:33:41 +00:00
// Our description
expected = translate(cmdEcho.Name())
checkStringContains(t, found, expected)
2015-08-18 22:33:41 +00:00
// Better have our example
expected = translate(cmdEcho.Name())
checkStringContains(t, found, expected)
2015-08-18 22:33:41 +00:00
// A local flag
expected = "boolone"
checkStringContains(t, found, expected)
2015-08-18 22:33:41 +00:00
// persistent flag on parent
expected = "rootflag"
checkStringContains(t, found, expected)
2015-08-18 22:33:41 +00:00
// We better output info about our parent
expected = translate(cmdRootWithRun.Name())
checkStringContains(t, found, expected)
2015-08-18 22:33:41 +00:00
// And about subcommands
expected = translate(cmdEchoSub.Name())
checkStringContains(t, found, expected)
2015-08-18 22:33:41 +00:00
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)
2015-08-18 22:33:41 +00:00
}