Skip to content

Commit

Permalink
Improve documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
majori committed Oct 31, 2023
1 parent 0adbdb5 commit ea57836
Show file tree
Hide file tree
Showing 20 changed files with 127 additions and 58 deletions.
2 changes: 1 addition & 1 deletion cmd/docs/templates/main.tmpl
Original file line number Diff line number Diff line change
Expand Up @@ -13,4 +13,4 @@ title: API Reference
---
{{- end}}

{{ template "recipe-schema" .RecipeSchema }}
{{ template "schema" . }}
Original file line number Diff line number Diff line change
@@ -1,37 +1,44 @@
{{- define "recipe-schema" }}
{{- define "schema" }}
## Recipe schema (`recipe.yml`)

| Attribute | Type | Default | Description |
| --- | --- | --- | --- |
| `apiVersion` | `string` | `v1` | Version of the recipe metadata API schema. Currently should have value "v1" |
| `name` | `string` | | Name of the recipe |
| `version` | `string` | | Version of the recipe. Must be valid [semver](https://semver.org/) |
| `apiVersion` | `string` | `v1` | Version of the recipe metadata API schema. Currently should have value "v1". |
| `name` | `string` | | Name of the recipe. |
| `version` | `string` | | Version of the recipe. Must be valid [semver](https://semver.org/). |
| `description` | `string` | | Description of what the recipe does |
| `sources` | `[]string` | | A list of URLs to source code for this recipe |
| `initHelp` | `string` | | A message which will be showed to an user after a succesful recipe execution. Can be used to guide the user what should be done next in the project directory |
| `ignorePatterns` | `[]string` | | Glob patterns for ignoring generated files from future recipe upgrades. Ignored files will not be regenerated even if their templates change in future versions of the recipe |
| `vars` | `[]Variable` | | An array of variables which can be used in templates |
| `sources` | `[]string` | | A list of URLs to source code for this recipe. |
| `initHelp` | `string` | | A message which will be showed to an user after a succesful recipe execution. Can be used to guide the user what should be done next in the project directory. |
| `ignorePatterns` | `[]string` | | Glob patterns for ignoring generated files from future recipe upgrades. Ignored files will not be regenerated even if their templates change in future versions of the recipe. |
| `vars` | `[]Variable` | | An array of variables which can be used in templates. |

### Variable

| Attribute | Type | Default | Description |
| --- | --- | --- | --- |
| `name` | `string` | | The name of the variable. It is also used as unique identifier |
| `description` | `string` | | Description of the variable. Will be shown to the user when "show help" is activated |
| `default` | `string` | | Default value of the variable |
| `confirm` | `bool` | `false` | If set to true, the prompt will be yes/no question, and the value type will be boolean |
| `optional` | `bool` | `false` | If set to true, the variable can be left empty |
| `options` | `[]string` | | The user selects the value from a list of options |
| `validators` | `[]Validator` | | Validators for the variable |
| `if` | `string` | | Makes the variable conditional based on the result of the expression. The result of the evaluation needs to be a boolean value. Uses https://github.com/antonmedv/expr |
| `columns` | `[]string` | | Set the variable as a table type with columns defined by this property |
| `name` | `string` | | The name of the variable. It is also used as unique identifier. |
| `description` | `string` | | Description of the variable. Will be shown to the user when "show help" is activated. |
| `default` | `string` | | Default value of the variable. |
| `confirm` | `bool` | `false` | If set to true, the prompt will be yes/no question, and the value type will be boolean. |
| `optional` | `bool` | `false` | If set to true, the variable can be left empty. |
| `options` | `[]string` | | The user selects the value from a list of options. |
| `validators` | `[]Validator` | | Validators for the variable. |
| `if` | `string` | | Makes the variable conditional based on the result of the expression. The result of the evaluation needs to be a boolean value. Uses https://github.com/antonmedv/expr. |
| `columns` | `[]string` | | Set the variable as a table type with columns defined by this property. |

### Validator

| Attribute | Type | Default | Description |
| --- | --- | --- | --- |
| `pattern` | `string` | | Regular expression pattern to match the input against |
| `help` | `string` | | If the regular expression validation fails, this help message will be shown to the user |
| `column` | `string` | | Apply the validator to a column if the variable type is table |
| `pattern` | `string` | | Regular expression pattern to match the input against. |
| `help` | `string` | | If the regular expression validation fails, this help message will be shown to the user. |
| `column` | `string` | | Apply the validator to a column if the variable type is table. |

## Test (`test.yml`)

| Attribute | Type | Default | Description |
| --- | --- | --- | --- |
| `values` | `map[string]any` | | Values to use to render the recipe templates. Map key is the name of the variable and value is the variable value. |
| `ignoreExtraFiles` | `bool` | | If true, test will pass even though templates generated more files than the test specifies. This is useful when creating specific test cases for large recipes. |

{{- end }}
2 changes: 1 addition & 1 deletion docs/site/docs/usage.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ slug: /usage/
title: Usage
---

# Usage
# Usage [WIP]

## Getting started

Expand Down
2 changes: 1 addition & 1 deletion examples/minimal/recipe.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
apiVersion: v1
name: minimal
version: v0.0.1
version: v0.0.0
description: Minimal recipe which just creates a README.md
6 changes: 6 additions & 0 deletions examples/with-tests/recipe.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
apiVersion: v1
name: with-tests
version: v0.0.0
description: This recipe has tests which you can run with `jalapeno test .`
vars:
- name: MY_VAR
1 change: 1 addition & 0 deletions examples/with-tests/templates/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
.Variables.MY_VAR is {{ .Variables.MY_VAR }}
1 change: 1 addition & 0 deletions examples/with-tests/tests/bar/files/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
.Variables.MY_VAR is bar
3 changes: 3 additions & 0 deletions examples/with-tests/tests/bar/test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
values:
MY_VAR: bar
ignoreExtraFiles: false
1 change: 1 addition & 0 deletions examples/with-tests/tests/foo/files/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
.Variables.MY_VAR is foo
3 changes: 3 additions & 0 deletions examples/with-tests/tests/foo/test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
values:
MY_VAR: foo
ignoreExtraFiles: false
5 changes: 5 additions & 0 deletions internal/cli/check.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,11 @@ func NewCheckCmd() *cobra.Command {
Run: func(cmd *cobra.Command, args []string) {
runCheck(cmd, opts)
},
Example: `# Check updates for all recipes in the project
jalapeno check
# Check updates for a single recipe
jalapeno check --recipe my-recipe`,
}

cmd.Flags().StringVar(&opts.RecipeName, "recipe", "", "Name of the recipe to check for new versions")
Expand Down
1 change: 1 addition & 0 deletions internal/cli/eject.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ func NewEjectCmd() *cobra.Command {
Run: func(cmd *cobra.Command, args []string) {
runEject(cmd, opts)
},
Example: `jalapeno eject`,
}

if err := option.ApplyFlags(&opts, cmd.Flags()); err != nil {
Expand Down
18 changes: 18 additions & 0 deletions internal/cli/execute.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,24 @@ func NewExecuteCmd() *cobra.Command {
Run: func(cmd *cobra.Command, args []string) {
runExecute(cmd, opts)
},
Example: `# Execute local recipe
jalapeno execute path/to/recipe
# Execute recipe from OCI repository
jalapeno execute oci://ghcr.io/user/my-recipe:latest
# Execute recipe from OCI repository with inline authentication
jalapeno execute oci://ghcr.io/user/my-recipe:latest --username user --password pass
# Execute recipe from OCI repository with Docker authentication
docker login ghcr.io
jalapeno execute oci://ghcr.io/user/my-recipe:latest
# Execute recipe to different directory
jalapeno execute path/to/recipe --dir other/dir
# Predefine variable values
jalapeno execute path/to/recipe --set MY_VAR=foo --set MY_OTHER_VAR=bar`,
}

if err := option.ApplyFlags(&opts, cmd.Flags()); err != nil {
Expand Down
28 changes: 13 additions & 15 deletions internal/cli/pull.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,18 @@ func NewPullCmd() *cobra.Command {
Run: func(cmd *cobra.Command, args []string) {
runPull(cmd, opts)
},
Example: `# Pull recipe from OCI repository
jalapeno pull ghcr.io/user/recipe:latest
# Pull recipe from OCI repository with inline authentication
jalapeno pull oci://ghcr.io/user/my-recipe:latest --username user --password pass
# Pull recipe from OCI repository with Docker authentication
docker login ghcr.io
jalapeno pull oci://ghcr.io/user/my-recipe:latest
# Pull recipe to different directory
jalapeno pull oci://ghcr.io/user/my-recipe:latest --dir other/dir`,
}

if err := option.ApplyFlags(&opts, cmd.Flags()); err != nil {
Expand All @@ -43,21 +55,7 @@ func NewPullCmd() *cobra.Command {
func runPull(cmd *cobra.Command, opts pullOptions) {
ctx := context.Background()

err := oci.SaveRemoteRecipe(ctx, opts.Dir,
oci.Repository{
Reference: opts.TargetRef,
PlainHTTP: opts.PlainHTTP,
Credentials: oci.Credentials{
Username: opts.Username,
Password: opts.Password,
DockerConfigs: opts.Configs,
},
TLS: oci.TLSConfig{
CACertFilePath: opts.CACertFilePath,
Insecure: opts.Insecure,
},
},
)
err := oci.SaveRemoteRecipe(ctx, opts.Dir, opts.Repository(opts.TargetRef))

if err != nil {
if strings.Contains(err.Error(), "not found") {
Expand Down
27 changes: 12 additions & 15 deletions internal/cli/push.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import (

type pushOptions struct {
RecipePath string
TargetRef string
TargetURL string
option.OCIRepository
option.Common
}
Expand All @@ -24,12 +24,21 @@ func NewPushCmd() *cobra.Command {
Args: cobra.ExactArgs(2),
PreRunE: func(cmd *cobra.Command, args []string) error {
opts.RecipePath = args[0]
opts.TargetRef = args[1]
opts.TargetURL = args[1]
return option.Parse(&opts)
},
Run: func(cmd *cobra.Command, args []string) {
runPush(cmd, opts)
},
Example: `# Push recipe to OCI repository
jalapeno push path/to/recipe ghcr.io/user/recipe:latest
# Push recipe to OCI repository with inline authentication
jalapeno push path/to/recipe oci://ghcr.io/user/my-recipe:latest --username user --password pass
# Push recipe to OCI repository with Docker authentication
docker login ghcr.io
jalapeno push path/to/recipe oci://ghcr.io/user/my-recipe:latest`,
}

if err := option.ApplyFlags(&opts, cmd.Flags()); err != nil {
Expand All @@ -42,19 +51,7 @@ func NewPushCmd() *cobra.Command {
func runPush(cmd *cobra.Command, opts pushOptions) {
ctx := context.Background()

err := oci.PushRecipe(ctx, opts.RecipePath, oci.Repository{
Reference: opts.TargetRef,
PlainHTTP: opts.PlainHTTP,
Credentials: oci.Credentials{
Username: opts.Username,
Password: opts.Password,
DockerConfigs: opts.Configs,
},
TLS: oci.TLSConfig{
CACertFilePath: opts.CACertFilePath,
Insecure: opts.Insecure,
},
})
err := oci.PushRecipe(ctx, opts.RecipePath, opts.Repository(opts.TargetURL))

if err != nil {
cmd.PrintErrf("Error: %s\n", err)
Expand Down
8 changes: 8 additions & 0 deletions internal/cli/test.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,14 @@ func NewTestCmd() *cobra.Command {
Run: func(cmd *cobra.Command, args []string) {
runTest(cmd, opts)
},
Example: `# Run recipe tests
jalapeno test path/to/recipe
# Bootstrap a new test case
jalapeno test path/to/recipe --create
# Update test file snapshots with the current outputs
jalapeno test path/to/recipe --update-snapshots`,
}

cmd.Flags().BoolVarP(&opts.UpdateSnapshots, "update-snapshots", "u", false, "Update test file snapshots")
Expand Down
18 changes: 18 additions & 0 deletions internal/cli/upgrade.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,24 @@ func NewUpgradeCmd() *cobra.Command {
Run: func(cmd *cobra.Command, args []string) {
runUpgrade(cmd, opts)
},
Example: `# Upgrade recipe with local recipe
jalapeno upgrade path/to/recipe
# Upgrade recipe with remote recipe from OCI repository
jalapeno upgrade oci://ghcr.io/user/my-recipe:v2.0.0
# Upgrade recipe with remote recipe from OCI repository with inline authentication
jalapeno upgrade oci://ghcr.io/user/my-recipe:v2.0.0 --username user --password pass
# Upgrade recipe with remote recipe from OCI repository with Docker authentication
docker login ghcr.io
jalapeno upgrade oci://ghcr.io/user/my-recipe:v2.0.0
# Upgrade recipe to different directory
jalapeno upgrade path/to/recipe --dir other/dir
# Predefine values for new variables introduced in the upgrade
jalapeno upgrade path/to/recipe --set NEW_VAR=foo`,
}

if err := option.ApplyFlags(&opts, cmd.Flags()); err != nil {
Expand Down
9 changes: 5 additions & 4 deletions internal/cli/validate.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import (
)

type validateOptions struct {
TargetPath string
RecipePath string
option.Common
}

Expand All @@ -18,13 +18,14 @@ func NewValidateCmd() *cobra.Command {
Short: "Validate a recipe",
Long: "Validate a recipe in a local path.",
PreRunE: func(cmd *cobra.Command, args []string) error {
opts.TargetPath = args[0]
opts.RecipePath = args[0]
return option.Parse(&opts)
},
Run: func(cmd *cobra.Command, args []string) {
runValidate(cmd, opts)
},
Args: cobra.ExactArgs(1),
Args: cobra.ExactArgs(1),
Example: `jalapeno validate path/to/recipe`,
}

if err := option.ApplyFlags(&opts, cmd.Flags()); err != nil {
Expand All @@ -35,7 +36,7 @@ func NewValidateCmd() *cobra.Command {
}

func runValidate(cmd *cobra.Command, opts validateOptions) {
r, err := recipe.LoadRecipe(opts.TargetPath)
r, err := recipe.LoadRecipe(opts.RecipePath)
if err != nil {
cmd.PrintErrf("Error: could not load the recipe: %s\n", err)
}
Expand Down
1 change: 1 addition & 0 deletions internal/cli/why.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ func NewWhyCmd() *cobra.Command {
Run: func(cmd *cobra.Command, args []string) {
runWhy(cmd, opts)
},
Example: `jalapeno why path/to/file`,
}

if err := option.ApplyFlags(&opts, cmd.Flags()); err != nil {
Expand Down
2 changes: 1 addition & 1 deletion pkg/recipe/test.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import (
)

type Test struct {
// Name of the test case. Defined by the test filename
// Name of the test case. Defined by directory name of the test case
Name string `yaml:"-"`

// Values to use to render the recipe templates
Expand Down

0 comments on commit ea57836

Please sign in to comment.