Skip to content

Commit

Permalink
fix(tasks): fake flux deps
Browse files Browse the repository at this point in the history
  • Loading branch information
gavincabbage committed Nov 1, 2019
1 parent 2ccd93d commit f5c81ec
Show file tree
Hide file tree
Showing 4 changed files with 94 additions and 9 deletions.
11 changes: 11 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,13 @@
## v2.0.0-alpha.20 [2019-10-30]

### Features

### UI Improvements

### Bug Fixes

1. [15713](https://github.com/influxdata/influxdb/pull/15713): Mock missing Flux dependencies when creating tasks

## v2.0.0-alpha.19 [2019-10-30]

### Features
Expand All @@ -6,6 +16,7 @@
1. [15650](https://github.com/influxdata/influxdb/pull/15650): Expose last run status and last run error in task API

### UI Improvements

1. [15503](https://github.com/influxdata/influxdb/pull/15503): Redesign page headers to be more space efficient
1. [15426](https://github.com/influxdata/influxdb/pull/15426): Add 403 handler that redirects back to the sign-in page on oats-generated routes.

Expand Down
62 changes: 62 additions & 0 deletions task/options/flux_deps.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
package options

import (
"bytes"
"context"
"io/ioutil"
"net/http"
"net/url"
"os"
"time"

"github.com/influxdata/flux/dependencies/filesystem"
fluxhttp "github.com/influxdata/flux/dependencies/http"
"github.com/influxdata/flux/dependencies/secret"
fluxurl "github.com/influxdata/flux/dependencies/url"
)

var (
_ fluxhttp.Client = httpClient{}
_ filesystem.Service = fileSystem{}
_ secret.Service = secretService{}
_ fluxurl.Validator = urlValidator{}
)

type httpClient struct{}

func (httpClient) Do(*http.Request) (*http.Response, error) {
return &http.Response{
Body: ioutil.NopCloser(&bytes.Reader{}),
}, nil
}

type secretService struct{}

func (secretService) LoadSecret(ctx context.Context, k string) (string, error) { return "", nil }

type urlValidator struct{}

func (urlValidator) Validate(*url.URL) error { return nil }

type fileSystem struct{}

func (fileSystem) Open(_ string) (filesystem.File, error) { return file{}, nil }
func (fileSystem) Create(_ string) (filesystem.File, error) { return file{}, nil }
func (fileSystem) Stat(_ string) (os.FileInfo, error) { return nil, nil }

type file struct{}

func (file) Read(_ []byte) (int, error) { return 0, nil }
func (file) Write(_ []byte) (int, error) { return 0, nil }
func (file) Close() error { return nil }
func (file) Seek(_ int64, _ int) (int64, error) { return 0, nil }
func (file) Stat() (os.FileInfo, error) { return info{}, nil }

type info struct{}

func (info) Name() string { return "" }
func (info) Size() int64 { return 0 }
func (info) Mode() os.FileMode { return 0 }
func (info) ModTime() time.Time { return time.Now() }
func (info) IsDir() bool { return false }
func (info) Sys() interface{} { return nil }
13 changes: 4 additions & 9 deletions task/options/options.go
Original file line number Diff line number Diff line change
Expand Up @@ -200,17 +200,12 @@ func grabTaskOptionAST(p *ast.Package, keys ...string) map[string]ast.Expression
return res
}

type constantSecretService struct{}

func (s constantSecretService) LoadSecret(ctx context.Context, k string) (string, error) {
return "", nil
}

func newDeps() flux.Dependencies {
deps := flux.NewDefaultDependencies()
deps.Deps.HTTPClient = nil
deps.Deps.URLValidator = nil
deps.Deps.SecretService = constantSecretService{}
deps.Deps.HTTPClient = httpClient{}
deps.Deps.URLValidator = urlValidator{}
deps.Deps.SecretService = secretService{}
deps.Deps.FilesystemService = fileSystem{}
return deps
}

Expand Down
17 changes: 17 additions & 0 deletions ui/cypress/e2e/tasks.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,23 @@ from(bucket: "${name}")
.and('contain', taskName)
})

it('can create a task using http.post', () => {
const taskName = 'Task'
createFirstTask(taskName, ({}) => {
return `import "http"
http.post(
url: "https://foo.bar/baz",
data: bytes(v: "body")
)`
})

cy.contains('Save').click()

cy.getByTestID('task-card')
.should('have.length', 1)
.and('contain', taskName)
})

describe('When tasks already exist', () => {
beforeEach(() => {
cy.get('@org').then(({id}: Organization) => {
Expand Down

0 comments on commit f5c81ec

Please sign in to comment.