mirror of
https://github.com/thegeeklab/wp-plugin-go.git
synced 2024-11-24 23:20:41 +00:00
feat: generate required and type information for docs (#45)
This commit is contained in:
parent
f5134fd97b
commit
ae9066d3cc
32
docs/docs.go
32
docs/docs.go
@ -4,6 +4,8 @@ import (
|
|||||||
"bytes"
|
"bytes"
|
||||||
"embed"
|
"embed"
|
||||||
"html/template"
|
"html/template"
|
||||||
|
"reflect"
|
||||||
|
"regexp"
|
||||||
"sort"
|
"sort"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
@ -17,6 +19,8 @@ type PluginArg struct {
|
|||||||
EnvVars []string
|
EnvVars []string
|
||||||
Description string
|
Description string
|
||||||
Default string
|
Default string
|
||||||
|
Type string
|
||||||
|
Required bool
|
||||||
}
|
}
|
||||||
|
|
||||||
type CliTemplate struct {
|
type CliTemplate struct {
|
||||||
@ -90,6 +94,12 @@ func parseFlags(flags []cli.Flag) []*PluginArg {
|
|||||||
modArg.Description = flag.GetUsage()
|
modArg.Description = flag.GetUsage()
|
||||||
modArg.Default = flag.GetDefaultText()
|
modArg.Default = flag.GetDefaultText()
|
||||||
|
|
||||||
|
if rf, _ := f.(cli.RequiredFlag); ok {
|
||||||
|
modArg.Required = rf.IsRequired()
|
||||||
|
}
|
||||||
|
|
||||||
|
modArg.Type = parseType(reflect.TypeOf(f).String())
|
||||||
|
|
||||||
args = append(args, modArg)
|
args = append(args, modArg)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -99,3 +109,25 @@ func parseFlags(flags []cli.Flag) []*PluginArg {
|
|||||||
|
|
||||||
return args
|
return args
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func parseType(raw string) string {
|
||||||
|
reSlice := regexp.MustCompile(`^\*cli\.(.+?)SliceFlag$`)
|
||||||
|
|
||||||
|
if reSlice.MatchString(raw) {
|
||||||
|
return "list"
|
||||||
|
}
|
||||||
|
|
||||||
|
re := regexp.MustCompile(`^\*cli\.(.+?)Flag$`)
|
||||||
|
match := re.FindStringSubmatch(raw)
|
||||||
|
|
||||||
|
if len(match) > 1 {
|
||||||
|
switch ctype := strings.ToLower(match[1]); ctype {
|
||||||
|
case "int", "int64", "uint", "uint64", "float64":
|
||||||
|
return "number"
|
||||||
|
default:
|
||||||
|
return ctype
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
@ -5,6 +5,7 @@ import (
|
|||||||
"os"
|
"os"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/google/go-cmp/cmp"
|
||||||
"github.com/urfave/cli/v2"
|
"github.com/urfave/cli/v2"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -13,11 +14,19 @@ func testApp() *cli.App {
|
|||||||
Name: "test",
|
Name: "test",
|
||||||
Description: "test description",
|
Description: "test description",
|
||||||
Flags: []cli.Flag{
|
Flags: []cli.Flag{
|
||||||
|
&cli.Int64Flag{
|
||||||
|
Name: "dummy-flag-int",
|
||||||
|
Usage: "dummy int flag desc",
|
||||||
|
EnvVars: []string{"PLUGIN_DUMMY_FLAG_INT"},
|
||||||
|
Value: 10,
|
||||||
|
Required: true,
|
||||||
|
},
|
||||||
&cli.StringFlag{
|
&cli.StringFlag{
|
||||||
Name: "dummy-flag",
|
Name: "dummy-flag",
|
||||||
Usage: "dummy flag desc",
|
Usage: "dummy flag desc",
|
||||||
EnvVars: []string{"PLUGIN_DUMMY_FLAG"},
|
EnvVars: []string{"PLUGIN_DUMMY_FLAG"},
|
||||||
Value: "test",
|
Value: "test",
|
||||||
|
Required: true,
|
||||||
},
|
},
|
||||||
&cli.StringFlag{
|
&cli.StringFlag{
|
||||||
Name: "simpe-flag",
|
Name: "simpe-flag",
|
||||||
@ -28,6 +37,11 @@ func testApp() *cli.App {
|
|||||||
Usage: "other flag with desc",
|
Usage: "other flag with desc",
|
||||||
EnvVars: []string{"PLUGIN_Z_OTHER_FLAG"},
|
EnvVars: []string{"PLUGIN_Z_OTHER_FLAG"},
|
||||||
},
|
},
|
||||||
|
&cli.StringSliceFlag{
|
||||||
|
Name: "slice.flag",
|
||||||
|
Usage: "slice flag",
|
||||||
|
EnvVars: []string{"PLUGIN_SLICE_FLAG"},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -53,7 +67,11 @@ func TestToMarkdownFull(t *testing.T) {
|
|||||||
app *cli.App
|
app *cli.App
|
||||||
want string
|
want string
|
||||||
}{
|
}{
|
||||||
{"normal branch", testApp(), "testdata/expected-doc-full.md"},
|
{
|
||||||
|
"normal branch",
|
||||||
|
testApp(),
|
||||||
|
"testdata/expected-doc-full.md",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tt := range tests {
|
for _, tt := range tests {
|
||||||
@ -65,3 +83,63 @@ func TestToMarkdownFull(t *testing.T) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestToData(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
app *cli.App
|
||||||
|
want *CliTemplate
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
"normal branch",
|
||||||
|
testApp(),
|
||||||
|
&CliTemplate{
|
||||||
|
Name: "test",
|
||||||
|
Description: "test description",
|
||||||
|
GlobalArgs: []*PluginArg{
|
||||||
|
{
|
||||||
|
Name: "dummy_flag",
|
||||||
|
Description: "dummy flag desc",
|
||||||
|
Default: "\"test\"",
|
||||||
|
Type: "string",
|
||||||
|
Required: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Name: "dummy_flag_int",
|
||||||
|
Description: "dummy int flag desc",
|
||||||
|
Default: "10",
|
||||||
|
Type: "number",
|
||||||
|
Required: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Name: "slice_flag",
|
||||||
|
Description: "slice flag",
|
||||||
|
Default: "",
|
||||||
|
Type: "list",
|
||||||
|
Required: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Name: "x_simple_flag",
|
||||||
|
Type: "string",
|
||||||
|
Required: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
Name: "z_other_flag",
|
||||||
|
Description: "other flag with desc",
|
||||||
|
Type: "string",
|
||||||
|
Required: false,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tt := range tests {
|
||||||
|
got := GetTemplateData(tt.app)
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
if diff := cmp.Diff(tt.want, got); diff != "" {
|
||||||
|
t.Errorf("data mismatch (-want +got):\n%s", diff)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
2
docs/templates/markdown.md.tmpl
vendored
2
docs/templates/markdown.md.tmpl
vendored
@ -7,7 +7,7 @@
|
|||||||
|
|
||||||
## Parameters
|
## Parameters
|
||||||
{{ range $v := .GlobalArgs }}
|
{{ range $v := .GlobalArgs }}
|
||||||
**_{{ $v.Name }}_**{{ with $v.Default }} (defaut: {{ . }}){{ end }}{{ if $v.Description }}{{ "\\" }}{{ end }}
|
**_{{ $v.Name }}_**{{ with $v.Default }}{{ if $v.Required }} _required_{{ end }} (defaut: {{ . }}){{ end }}{{ if $v.Description }}{{ "\\" }}{{ end }}
|
||||||
{{- with $v.Description }}
|
{{- with $v.Description }}
|
||||||
 {{ . }}
|
 {{ . }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
8
docs/testdata/expected-doc-full.md
vendored
8
docs/testdata/expected-doc-full.md
vendored
@ -4,9 +4,15 @@ test description
|
|||||||
|
|
||||||
## Parameters
|
## Parameters
|
||||||
|
|
||||||
**_dummy_flag_** (defaut: "test")\
|
**_dummy_flag_** _required_ (defaut: "test")\
|
||||||
 dummy flag desc
|
 dummy flag desc
|
||||||
|
|
||||||
|
**_dummy_flag_int_** _required_ (defaut: 10)\
|
||||||
|
 dummy int flag desc
|
||||||
|
|
||||||
|
**_slice_flag_**\
|
||||||
|
 slice flag
|
||||||
|
|
||||||
**_x_simple_flag_**
|
**_x_simple_flag_**
|
||||||
|
|
||||||
**_z_other_flag_**\
|
**_z_other_flag_**\
|
||||||
|
1
go.mod
1
go.mod
@ -5,6 +5,7 @@ go 1.21
|
|||||||
require (
|
require (
|
||||||
github.com/Masterminds/semver/v3 v3.2.1
|
github.com/Masterminds/semver/v3 v3.2.1
|
||||||
github.com/Masterminds/sprig/v3 v3.2.3
|
github.com/Masterminds/sprig/v3 v3.2.3
|
||||||
|
github.com/google/go-cmp v0.6.0
|
||||||
github.com/joho/godotenv v1.5.1
|
github.com/joho/godotenv v1.5.1
|
||||||
github.com/rs/zerolog v1.31.0
|
github.com/rs/zerolog v1.31.0
|
||||||
github.com/urfave/cli/v2 v2.27.1
|
github.com/urfave/cli/v2 v2.27.1
|
||||||
|
2
go.sum
2
go.sum
@ -12,6 +12,8 @@ github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSs
|
|||||||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
||||||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
|
github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
|
||||||
|
github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI=
|
||||||
|
github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
|
||||||
github.com/google/uuid v1.1.1 h1:Gkbcsh/GbpXz7lPftLA3P6TYMwjCLYm83jiFQZF/3gY=
|
github.com/google/uuid v1.1.1 h1:Gkbcsh/GbpXz7lPftLA3P6TYMwjCLYm83jiFQZF/3gY=
|
||||||
github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
|
||||||
github.com/huandu/xstrings v1.3.3 h1:/Gcsuc1x8JVbJ9/rlye4xZnVAbEkGauT8lbebqcQws4=
|
github.com/huandu/xstrings v1.3.3 h1:/Gcsuc1x8JVbJ9/rlye4xZnVAbEkGauT8lbebqcQws4=
|
||||||
|
Loading…
Reference in New Issue
Block a user