Skip to content

Commit

Permalink
Merge pull request #717 from carolynvs/expect-multiple-commands
Browse files Browse the repository at this point in the history
Add testing page for mixin developers
  • Loading branch information
carolynvs-msft authored Oct 10, 2019
2 parents 8e2cc93 + a531991 commit 35ee341
Show file tree
Hide file tree
Showing 11 changed files with 79 additions and 22 deletions.
2 changes: 1 addition & 1 deletion cmd/porter/mixins.go
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,7 @@ bin/
├── mymixin-linux-amd64
└── mymixin-windows-amd64.exe
See https://porter.sh/mixin-distribution more details.
See https://porter.sh/mixin-dev-guide/distribution more details.
`,
Example: ` porter mixin feed generate
porter mixin feed generate --dir bin --file bin/atom.xml --template porter-atom-template.xml`,
Expand Down
14 changes: 10 additions & 4 deletions docs/config.toml
Original file line number Diff line number Diff line change
Expand Up @@ -242,25 +242,31 @@ defaultContentLanguage = "en"
weight = 350
[[menu.main]]
name = "Overview"
url = "/mixin-dev-guide"
url = "/mixin-dev-guide/"
identifier = "mixin-dev-guide"
weight = 351
parent = "developing-mixins"
[[menu.main]]
name = "Commands"
url = "/mixin-commands"
url = "/mixin-dev-guide/commands/"
identifier = "mixin-commands"
weight = 353
parent = "developing-mixins"
[[menu.main]]
name = "Testing"
url = "/mixin-dev-guide/testing/"
identifier = "mixin-testing"
weight = 355
parent = "developing-mixins"
[[menu.main]]
name = "Mixin Architecture"
url = "/mixin-architecture"
url = "/mixin-dev-guide/architecture/"
identifier = "mixin-architecture"
weight = 360
parent = "developing-mixins"
[[menu.main]]
name = "Distributing Mixins"
url = "/mixin-distribution"
url = "/mixin-dev-guide/distribution/"
identifier = "mixin-distribution"
weight = 361
parent = "developing-mixins"
Expand Down
2 changes: 1 addition & 1 deletion docs/content/architecture-buildtime.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ if you would like to add content for this page.
# Next

* [Dependencies](/dependencies/)
* [Mixin Architecture](/mixin-architecture/)
* [Mixin Architecture](/mixin-dev-guide/architecture/)
* [Building the Invocation Image](/build-image/)

[contrib]: https://github.com/deislabs/porter/blob/master/CONTRIBUTING.md#documentation
2 changes: 1 addition & 1 deletion docs/content/cli/mixins_feed_generate.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ bin/
├── mymixin-linux-amd64
└── mymixin-windows-amd64.exe

See https://porter.sh/mixin-distribution more details.
See https://porter.sh/mixin-dev-guide/distribution more details.


```
Expand Down
14 changes: 0 additions & 14 deletions docs/content/mixin-dev-guide.md

This file was deleted.

14 changes: 14 additions & 0 deletions docs/content/mixin-dev-guide/_index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
---
title: Developing Mixins
description: Creating and Extending Mixins for Porter
layout: single
---

The easiest way to make a mixin right now is to use start from our template repository:

<https://github.com/deislabs/porter-skeletor>

## See Also
* [Mixin Commands](./commands/)
* [Mixin Architecture](./architecture/)
* [Mixin Distribution](./distribution/)
File renamed without changes.
File renamed without changes.
File renamed without changes.
51 changes: 51 additions & 0 deletions docs/content/mixin-dev-guide/testing.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
---
title: Testing a Mixin
description: How to test a Porter mixin
---

We are working on filling this doc out more, until then this is more of a FAQ than a proscriptive guide. If you have
a tip, please submit a PR and help us fill this out!

## How do I unit test that my mixin is executing the right commands?

Here is a [full working example][example] of a unit test that validates the commands executed by a mixin.

Make sure that your package has a `TestMain` that calls `github.com/deislabs/porter/pkg/test.TestMainWithMockedCommandHandlers`

```go
import "github.com/deislabs/porter/pkg/test"

func TestMain(m *testing.M) {
test.TestMainWithMockedCommandHandlers(m)
}
```

Then you instantiate your mixin in test mode (the skeletor template generates this method for you):

```go
m := NewTestMixin(t)
```

This sets up your test binary to assert that expected command(s) were called. You tell it what command to expect with

```go
os.Setenv(test.ExpectedCommandEnv, "helm install")
defer os.Unsetenv(test.ExpectedCommandEnv)
```

If your mixin action executes multiple commands, separate them with a newline `\n` like so

```go
os.Setenv(test.ExpectedCommandEnv, "helm install\nhelm upgrade")
```

Now execute your mixin action:

```go
err = m.Execute()
```

Instead of os calls to the real commands, the test mixin mode calls back into your test binary. The `TestMain` handles
asserting that the expected commands were made and fails the test if they weren't.

[example]: https://github.com/deislabs/porter-gcloud/blob/v0.2.1-beta.1/pkg/gcloud/execute_test.go
2 changes: 1 addition & 1 deletion docs/content/using-mixins.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,6 @@ if you would like to add content for this page.

# Next

* [Mixin Architecture](/mixin-architecture/)
* [Mixin Architecture](/mixin-dev-guide/architecture/)

[contrib]: https://github.com/deislabs/porter/blob/master/CONTRIBUTING.md#documentation

0 comments on commit 35ee341

Please sign in to comment.