Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: promote algorithm W to master #17900

Merged
merged 106 commits into from
May 27, 2020
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
106 commits
Select commit Hold shift + click to select a range
0f3aabc
refactor(query): let influxdb build against algo-w branch (#16673)
Jan 24, 2020
2bc8d49
chore(go.mod): update go.mod to point at latest flux@feat/use-algo-w
Jan 31, 2020
d25c56c
chore: merge commit 'e472b013d93d' into feat/use-algo-w
Feb 10, 2020
337595c
chore: update to latest flux@feat/use-algo-w
Feb 10, 2020
2e073fd
chore: update to latest flux@feat/use-algo-w
Feb 11, 2020
d676696
test(query): skip tests that are not passing in feat/use-algo-w (#16813)
Feb 11, 2020
16fc8df
build: remove -tags libflux and FLUX_PARSER_TYPE from build and circl…
Feb 19, 2020
766aa23
chore: update flux dependency
Feb 21, 2020
b01e194
chore: update flux dependency in promqltests
Feb 21, 2020
2c184ea
chore: update flux dependency and unskip notification tests
Feb 21, 2020
935180e
refactor: update flux for the runtime package (#17002)
jsternberg Feb 27, 2020
ff848bc
refactor(repl): remove the querier from the repl (#17031)
jsternberg Feb 27, 2020
25b0e37
feat: add support for pkg-config (#17036)
jsternberg Feb 28, 2020
0872af8
refactor: update semantic builtin lookups to use runtime now (#17066)
jsternberg Mar 2, 2020
03cfdba
fix(stdlib): unskip flux end to end tests
Mar 2, 2020
a84df74
feat(stdlib): add influxdb source (#17047)
jsternberg Mar 3, 2020
3250fb1
fix(stdlib): update flux dependency and unskip test
Mar 5, 2020
a907e05
refactor(http): modify query handler to use a language service (#17074)
jsternberg Mar 5, 2020
bcbb9df
refactor(task): tasks will now use the flux language service (#17104)
jsternberg Mar 5, 2020
0d6e4e3
Merge branch 'master' into feat/use-algo-w
jsternberg Mar 6, 2020
400d710
refactor(storage/reads): remove the storage dependency on libflux (#1…
jsternberg Mar 7, 2020
8d2ba69
refactor(http): remove the spec and update lang usage (#17148)
jsternberg Mar 9, 2020
4d68385
Merge branch 'master' into feat/use-algo-w
jsternberg Mar 9, 2020
92f121d
fix: change variable name to match new clockface variable names
hoorayimhelping Mar 9, 2020
2374717
refactor(kv): when no session length is set, use the default
jsternberg Mar 9, 2020
7012470
Merge branch 'master' into feat/use-algo-w
jsternberg Mar 10, 2020
07c9a7c
fix(stdlib): unskip stateChanges end to end test
Mar 12, 2020
790661c
test(query/stdlib/influxdata/influxdb): update rules_test to use algo…
Mar 16, 2020
5f30466
feat(query): update buckets and v1.databases calls (#17294)
jsternberg Mar 17, 2020
6c8125b
chore: update flux dependency
Mar 19, 2020
20c2439
refactor(http): change *ast.Package to json.RawMessage in query reque…
Mar 23, 2020
e9689b7
chore: update to latest flux algo-w (#17408)
Mar 24, 2020
e57c28d
chore: update to latest algo-w flux (#17422)
Mar 25, 2020
7d885fb
chore: update flux
Mar 26, 2020
4c5ef96
refactor: add pkg-config package to tools.go (#17493)
jsternberg Mar 30, 2020
469c584
Merge branch 'master' into feat/use-algo-w
jsternberg Apr 3, 2020
4ade845
chore: update flux to latest algow
Apr 3, 2020
27f7f4c
chore: update flux to latest algow
Apr 3, 2020
d3fa609
Merge branch 'master' into chore/merge-master
jsternberg Apr 6, 2020
bf15ba7
chore: update flux to latest algow
Apr 6, 2020
17c244d
chore: fix the promqltests go module file (#17631)
jsternberg Apr 6, 2020
1bb08ce
refactor(query/stdlib): modify storage filters to use the predicate d…
jsternberg Apr 7, 2020
687ab70
refactor(query): update semantic graph usage for function expression …
jsternberg Apr 7, 2020
5c99219
chore: update flux to latest algow
Apr 14, 2020
b9df72c
chore: update flux to latest algow
Apr 14, 2020
7541af8
chore: merge master into algow
Apr 15, 2020
0bac09d
Merge pull request #17759 from influxdata/chore/merge-master
Apr 15, 2020
90fb754
Merge branch 'master' into chore/merge-master
Apr 16, 2020
8e098b5
Merge pull request #17777 from influxdata/chore/merge-master
Apr 16, 2020
9857ae1
feat: release a nightly image of algow
Apr 16, 2020
9c67148
chore: update flux to latest algow revision
Apr 20, 2020
335968a
Merge branch 'master' into chore/merge-master
Apr 20, 2020
e076b61
fix: planner rewrite rules take a context
Apr 20, 2020
34bcbd8
Merge pull request #17807 from influxdata/chore/merge-master
Apr 20, 2020
63fd365
Merge branch 'master' into chore/merge-master-into-algo-w
Apr 22, 2020
54ac783
refactor(query): move ReadWindowAggregateSpec to query package
Apr 22, 2020
c6ffeac
test: skip flux end to end test for writing null values
Apr 22, 2020
ff2a2cc
chore: update flux to latest algo-w revision
Apr 23, 2020
d60b877
Merge branch 'master' into chore/merge-master-into-algo-w
Apr 23, 2020
77fb838
Merge pull request #17848 from influxdata/chore/merge-master-into-algo-w
Apr 23, 2020
3079d2a
Merge branch 'master' into chore/merge-master-into-algo-w
Apr 24, 2020
3f4368d
chore: update flux to latest algo-w revision
Apr 24, 2020
40398b7
Merge pull request #17867 from influxdata/chore/merge-master-into-algo-w
Apr 24, 2020
f5cf024
chore: update flux to latest algo-w revision
Apr 28, 2020
457637e
Merge branch 'master' into chore/merge-master
Apr 28, 2020
d6b4728
Merge pull request #17884 from influxdata/chore/merge-master
Apr 28, 2020
6d885c7
Merge branch 'master' into chore/update-flux
Apr 29, 2020
f2478a1
chore: update flux to latest revision
Apr 29, 2020
4884f71
Merge pull request #17904 from influxdata/chore/update-flux
Apr 29, 2020
2ef9999
Merge branch 'master' into chore/merge-master
Apr 30, 2020
1db0fcc
Merge pull request #17920 from influxdata/chore/merge-master
Apr 30, 2020
83b90c3
Merge branch 'master' into chore/merge-master
Apr 30, 2020
4fba49f
Merge pull request #17925 from influxdata/chore/merge-master
Apr 30, 2020
22c7d09
feat: frontend consumption of feature flags (#17926)
drdelambre Apr 30, 2020
2b58cbf
fix: safari rendering bug in checks (#17929)
drdelambre May 1, 2020
aac3a4e
fix: show buckets in alerting (#17930)
drdelambre May 1, 2020
89e3436
feat(pkger): add the ability to remove a stack and all its associated…
jsteenb2 May 1, 2020
28aa464
chore(httpc): refactor inputs to eliminate required path
jsteenb2 May 2, 2020
ffddeb4
fix(zero_value_checks): checks can now have a value set to 0 (#17933)
asalem1 May 4, 2020
1d027cf
feat(pkger): enforce metadata.name dns name compliance
jsteenb2 May 3, 2020
8bb5065
refactor: unify WindowAggregateCapability (#17901)
ethanyzhang May 5, 2020
e341a51
fix: fmt
ethanyzhang May 5, 2020
7c1b735
Merge branch 'master' into chore/update-flux
May 5, 2020
02c8e02
chore: update flux to latest revision
May 5, 2020
2faac6a
Merge pull request #17962 from influxdata/chore/update-flux
May 5, 2020
7cb599c
feat(storage): convert ResultSet to table stream for aggregate window
May 4, 2020
e51a2b8
feat: added PushDownWindowAggregate planner rewrite rule (#17898)
adrian-thurston May 6, 2020
6dd385d
chore: update flux to latest revision
May 6, 2020
4aec0dc
Merge branch 'master' into chore/update-flux
May 6, 2020
c380ff6
Merge pull request #17974 from influxdata/chore/update-flux
May 6, 2020
f3320c7
Merge branch 'master' into chore/update-flux
May 7, 2020
9a1e31a
chore: update flux to latest revision
May 7, 2020
8bf2d34
Merge pull request #18002 from influxdata/chore/update-flux
May 7, 2020
7379e78
fix(storage/flux): fix a race condition in the tags cache (#17977)
jsternberg May 7, 2020
34e581c
Merge branch 'master' into chore/merge-master
May 12, 2020
20a583d
chore: update flux to latest revision
May 12, 2020
2124d84
Merge pull request #18061 from influxdata/chore/merge-master
May 12, 2020
09b8e40
fix(query/stdlib): update to function to use the refactored row funct…
jsternberg May 13, 2020
b43f79b
fix: need to rebuild the query request before the second e2e test run…
adrian-thurston May 15, 2020
342c3c2
fix(query): do not free the column reader in the no content encoders …
jsternberg May 15, 2020
0c8d19e
Merge branch 'master' into feat/use-algo-w
jsternberg May 18, 2020
b776cf4
feat: added PushDownGroupAggregate planner rewrite rule (#18085)
adrian-thurston May 20, 2020
0bb847b
Merge branch 'master' into feat/use-algo-w
jsternberg May 21, 2020
53165bf
feat(query): add a planner rule to push down bare aggregates (#18144)
May 22, 2020
7db9f4c
Merge branch 'master' into chore/merge-master
May 26, 2020
de1b1b3
Merge pull request #18216 from influxdata/chore/merge-master
May 26, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
refactor(http): remove the spec and update lang usage (#17148)
This removes the spec and updates the lang package usage to make use of
passing in the runtime as a parameter.

It removes all direct dependendencies on the flux runtime from the http
package.
  • Loading branch information
jsternberg authored Mar 9, 2020
commit 8d2ba699a09c6064853341f18f8b7123e0aea6c7
2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ require (
github.com/hashicorp/raft v1.0.0 // indirect
github.com/hashicorp/vault/api v1.0.2
github.com/influxdata/cron v0.0.0-20191203200038-ded12750aac6
github.com/influxdata/flux v0.60.1-0.20200305155158-1add321ebf7a
github.com/influxdata/flux v0.60.1-0.20200309174638-0dbc38c3785a
github.com/influxdata/httprouter v1.3.1-0.20191122104820-ee83e2772f69
github.com/influxdata/influxql v0.0.0-20180925231337-1cbfca8e56b6
github.com/influxdata/usage-client v0.0.0-20160829180054-6d3895376368
Expand Down
4 changes: 2 additions & 2 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -240,8 +240,8 @@ github.com/inconshreveable/mousetrap v1.0.0 h1:Z8tu5sraLXCXIcARxBp/8cbvlwVa7Z1NH
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
github.com/influxdata/cron v0.0.0-20191203200038-ded12750aac6 h1:OtjKkeWDjUbyMi82C7XXy7Tvm2LXMwiBBXyFIGNPaGA=
github.com/influxdata/cron v0.0.0-20191203200038-ded12750aac6/go.mod h1:XabtPPW2qsCg0tl+kjaPU+cFS+CjQXEXbT1VJvHT4og=
github.com/influxdata/flux v0.60.1-0.20200305155158-1add321ebf7a h1:Dczh6cTotsat9rt7GzD7EhGzpGFO5h0L3zAkQ1sJSds=
github.com/influxdata/flux v0.60.1-0.20200305155158-1add321ebf7a/go.mod h1:BRxpm1xTUAZ+s+Mq6t0NZyaYtlGrw/8YoHoifso9vS8=
github.com/influxdata/flux v0.60.1-0.20200309174638-0dbc38c3785a h1:VUxuayL83N9Fj3re2mOAgHWKCqRJFKRqqXK2mihLXMI=
github.com/influxdata/flux v0.60.1-0.20200309174638-0dbc38c3785a/go.mod h1:BRxpm1xTUAZ+s+Mq6t0NZyaYtlGrw/8YoHoifso9vS8=
github.com/influxdata/goreleaser v0.97.0-influx h1:jT5OrcW7WfS0e2QxfwmTBjhLvpIC9CDLRhNgZJyhj8s=
github.com/influxdata/goreleaser v0.97.0-influx/go.mod h1:MnjA0e0Uq6ISqjG1WxxMAl+3VS1QYjILSWVnMYDxasE=
github.com/influxdata/httprouter v1.3.1-0.20191122104820-ee83e2772f69 h1:WQsmW0fXO4ZE/lFGIE84G6rIV5SJN3P3sjIXAP1a8eU=
Expand Down
5 changes: 0 additions & 5 deletions http/influxdb/source_proxy_query_service.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ import (
"github.com/influxdata/flux"
"github.com/influxdata/flux/csv"
"github.com/influxdata/flux/lang"
"github.com/influxdata/flux/repl"
platform "github.com/influxdata/influxdb"
platformhttp "github.com/influxdata/influxdb/http"
"github.com/influxdata/influxdb/kit/check"
Expand Down Expand Up @@ -43,7 +42,6 @@ func (s *SourceProxyQueryService) fluxQuery(ctx context.Context, w io.Writer, re
span, ctx := tracing.StartSpanFromContext(ctx)
defer span.Finish()
request := struct {
Spec *flux.Spec `json:"spec"`
Query string `json:"query"`
Type string `json:"type"`
Dialect flux.Dialect `json:"dialect"`
Expand All @@ -53,9 +51,6 @@ func (s *SourceProxyQueryService) fluxQuery(ctx context.Context, w io.Writer, re
case lang.FluxCompiler:
request.Query = c.Query
request.Type = lang.FluxCompilerType
case repl.Compiler:
request.Spec = c.Spec
request.Type = repl.CompilerType
default:
return flux.Statistics{}, tracing.LogError(span, fmt.Errorf("compiler type not supported: %s", c.CompilerType()))
}
Expand Down
20 changes: 1 addition & 19 deletions http/query.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ import (
"github.com/influxdata/flux/ast"
"github.com/influxdata/flux/csv"
"github.com/influxdata/flux/lang"
"github.com/influxdata/flux/repl"
"github.com/influxdata/influxdb"
"github.com/influxdata/influxdb/jsonweb"
"github.com/influxdata/influxdb/query"
Expand All @@ -33,7 +32,6 @@ type QueryRequest struct {

// Flux fields
Extern *ast.File `json:"extern,omitempty"`
Spec *flux.Spec `json:"spec,omitempty"`
AST *ast.Package `json:"ast,omitempty"`
Dialect QueryDialect `json:"dialect"`

Expand Down Expand Up @@ -89,19 +87,10 @@ func (r QueryRequest) WithDefaults() QueryRequest {

// Validate checks the query request and returns an error if the request is invalid.
func (r QueryRequest) Validate() error {
// TODO(jsternberg): Remove this, but we are going to not mention
// the spec in the error if it is being used.
if r.Query == "" && r.Spec == nil && r.AST == nil {
if r.Query == "" && r.AST == nil {
return errors.New(`request body requires either query or AST`)
}

if r.Spec != nil && r.Extern != nil {
return &influxdb.Error{
Code: influxdb.EInvalid,
Msg: "request body cannot specify both a spec and external declarations",
}
}

if r.Type != "flux" && r.Type != "influxql" {
return fmt.Errorf(`unknown query type: %s`, r.Type)
}
Expand Down Expand Up @@ -283,10 +272,6 @@ func (r QueryRequest) proxyRequest(now func() time.Time) (*query.ProxyRequest, e
c.PrependFile(r.Extern)
}
compiler = c
} else if r.Spec != nil {
compiler = repl.Compiler{
Spec: r.Spec,
}
}

delimiter, _ := utf8.DecodeRuneInString(r.Dialect.Delimiter)
Expand Down Expand Up @@ -341,9 +326,6 @@ func QueryRequestFromProxyRequest(req *query.ProxyRequest) (*QueryRequest, error
qr.Type = "flux"
qr.Query = c.Query
qr.Extern = c.Extern
case repl.Compiler:
qr.Type = "flux"
qr.Spec = c.Spec
case lang.ASTCompiler:
qr.Type = "flux"
qr.AST = c.AST
Expand Down
13 changes: 6 additions & 7 deletions http/query_handler.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ import (
"github.com/NYTimes/gziphandler"
"github.com/influxdata/flux"
"github.com/influxdata/flux/ast"
"github.com/influxdata/flux/complete"
"github.com/influxdata/flux/csv"
"github.com/influxdata/flux/iocounter"
"github.com/influxdata/httprouter"
Expand Down Expand Up @@ -80,7 +79,7 @@ type FluxHandler struct {
Now func() time.Time
OrganizationService influxdb.OrganizationService
ProxyQueryService query.ProxyQueryService
LanguageService influxdb.FluxLanguageService
FluxLanguageService influxdb.FluxLanguageService

EventRecorder metric.EventRecorder
}
Expand All @@ -101,7 +100,7 @@ func NewFluxHandler(log *zap.Logger, b *FluxBackend) *FluxHandler {
ProxyQueryService: b.ProxyQueryService,
OrganizationService: b.OrganizationService,
EventRecorder: b.QueryEventRecorder,
LanguageService: b.FluxLanguageService,
FluxLanguageService: b.FluxLanguageService,
}

// query reponses can optionally be gzip encoded
Expand Down Expand Up @@ -224,7 +223,7 @@ func (h *FluxHandler) postFluxAST(w http.ResponseWriter, r *http.Request) {
return
}

pkg, err := query.Parse(h.LanguageService, request.Query)
pkg, err := query.Parse(h.FluxLanguageService, request.Query)
if err != nil {
h.HandleHTTPError(ctx, &influxdb.Error{
Code: influxdb.EInvalid,
Expand Down Expand Up @@ -261,7 +260,7 @@ func (h *FluxHandler) postQueryAnalyze(w http.ResponseWriter, r *http.Request) {
return
}

a, err := req.Analyze(h.LanguageService)
a, err := req.Analyze(h.FluxLanguageService)
if err != nil {
h.HandleHTTPError(ctx, err, w)
return
Expand Down Expand Up @@ -292,7 +291,7 @@ func (h *FluxHandler) getFluxSuggestions(w http.ResponseWriter, r *http.Request)
defer span.Finish()

ctx := r.Context()
completer := complete.DefaultCompleter()
completer := h.FluxLanguageService.Completer()
names := completer.FunctionNames()
var functions []suggestionResponse
for _, name := range names {
Expand Down Expand Up @@ -331,7 +330,7 @@ func (h *FluxHandler) getFluxSuggestion(w http.ResponseWriter, r *http.Request)

ctx := r.Context()
name := httprouter.ParamsFromContext(ctx).ByName("name")
completer := complete.DefaultCompleter()
completer := h.FluxLanguageService.Completer()

suggestion, err := completer.FunctionSuggestion(name)
if err != nil {
Expand Down
4 changes: 2 additions & 2 deletions http/query_handler_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -260,8 +260,8 @@ func TestFluxHandler_postFluxAST(t *testing.T) {
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
h := &FluxHandler{
HTTPErrorHandler: kithttp.ErrorHandler(0),
LanguageService: fluxlang.DefaultService,
HTTPErrorHandler: kithttp.ErrorHandler(0),
FluxLanguageService: fluxlang.DefaultService,
}
h.postFluxAST(tt.w, tt.r)
if got := tt.w.Body.String(); got != tt.want {
Expand Down
47 changes: 0 additions & 47 deletions http/query_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ import (
"github.com/influxdata/flux/ast"
"github.com/influxdata/flux/csv"
"github.com/influxdata/flux/lang"
"github.com/influxdata/flux/repl"
platform "github.com/influxdata/influxdb"
"github.com/influxdata/influxdb/mock"
"github.com/influxdata/influxdb/query"
Expand Down Expand Up @@ -60,7 +59,6 @@ func TestQueryRequest_WithDefaults(t *testing.T) {
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
r := QueryRequest{
Spec: tt.fields.Spec,
AST: tt.fields.AST,
Query: tt.fields.Query,
Type: tt.fields.Type,
Expand All @@ -77,7 +75,6 @@ func TestQueryRequest_WithDefaults(t *testing.T) {
func TestQueryRequest_Validate(t *testing.T) {
type fields struct {
Extern *ast.File
Spec *flux.Spec
AST *ast.Package
Query string
Type string
Expand All @@ -96,19 +93,6 @@ func TestQueryRequest_Validate(t *testing.T) {
},
wantErr: true,
},
{
name: "query cannot have both extern and spec",
fields: fields{
Extern: &ast.File{},
Spec: &flux.Spec{},
Type: "flux",
Dialect: QueryDialect{
Delimiter: ",",
DateTimeFormat: "RFC3339",
},
},
wantErr: true,
},
{
name: "requires flux type",
fields: fields{
Expand Down Expand Up @@ -190,7 +174,6 @@ func TestQueryRequest_Validate(t *testing.T) {
t.Run(tt.name, func(t *testing.T) {
r := QueryRequest{
Extern: tt.fields.Extern,
Spec: tt.fields.Spec,
AST: tt.fields.AST,
Query: tt.fields.Query,
Type: tt.fields.Type,
Expand Down Expand Up @@ -332,41 +315,11 @@ func TestQueryRequest_proxyRequest(t *testing.T) {
},
},
},
{
name: "valid spec",
fields: fields{
Type: "flux",
Spec: &flux.Spec{
Now: time.Unix(0, 0).UTC(),
},
Dialect: QueryDialect{
Delimiter: ",",
DateTimeFormat: "RFC3339",
},
org: &platform.Organization{},
},
want: &query.ProxyRequest{
Request: query.Request{
Compiler: repl.Compiler{
Spec: &flux.Spec{
Now: time.Unix(0, 0).UTC(),
},
},
},
Dialect: &csv.Dialect{
ResultEncoderConfig: csv.ResultEncoderConfig{
NoHeader: false,
Delimiter: ',',
},
},
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
r := QueryRequest{
Extern: tt.fields.Extern,
Spec: tt.fields.Spec,
AST: tt.fields.AST,
Query: tt.fields.Query,
Type: tt.fields.Type,
Expand Down
5 changes: 0 additions & 5 deletions http/source_service.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ import (
"github.com/influxdata/flux"
"github.com/influxdata/flux/csv"
"github.com/influxdata/flux/lang"
"github.com/influxdata/flux/repl"
"github.com/influxdata/httprouter"
platform "github.com/influxdata/influxdb"
"github.com/influxdata/influxdb/pkg/httpc"
Expand Down Expand Up @@ -168,10 +167,6 @@ func decodeSourceQueryRequest(r *http.Request) (*query.ProxyRequest, error) {
req.Request.Compiler = lang.FluxCompiler{
Query: request.Query,
}
case repl.CompilerType:
req.Request.Compiler = repl.Compiler{
Spec: request.Spec,
}
case influxql.CompilerType:
req.Request.Compiler = &influxql.Compiler{
Cluster: request.Cluster,
Expand Down
4 changes: 4 additions & 0 deletions query.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"context"

"github.com/influxdata/flux/ast"
"github.com/influxdata/flux/complete"
"github.com/influxdata/flux/interpreter"
"github.com/influxdata/flux/values"
)
Expand All @@ -28,4 +29,7 @@ type FluxLanguageService interface {

// EvalAST will evaluate and run an AST.
EvalAST(ctx context.Context, astPkg *ast.Package) ([]interpreter.SideEffect, values.Scope, error)

// Completer will return a flux completer.
Completer() complete.Completer
}
3 changes: 2 additions & 1 deletion query/control/controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ import (
"github.com/influxdata/flux/codes"
"github.com/influxdata/flux/lang"
"github.com/influxdata/flux/memory"
"github.com/influxdata/flux/runtime"
"github.com/influxdata/influxdb"
"github.com/influxdata/influxdb/kit/errors"
"github.com/influxdata/influxdb/kit/prom"
Expand Down Expand Up @@ -338,7 +339,7 @@ func (c *Controller) compileQuery(q *Query, compiler flux.Compiler) (err error)
}
}

prog, err := compiler.Compile(ctx)
prog, err := compiler.Compile(ctx, runtime.Default)
if err != nil {
return &flux.Error{
Msg: "compilation failed",
Expand Down
5 changes: 5 additions & 0 deletions query/fluxlang/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import (
"context"

"github.com/influxdata/flux/ast"
"github.com/influxdata/flux/complete"
"github.com/influxdata/flux/interpreter"
"github.com/influxdata/flux/parser"
"github.com/influxdata/flux/runtime"
Expand All @@ -28,3 +29,7 @@ func (d defaultService) Parse(source string) (pkg *ast.Package, err error) {
func (d defaultService) EvalAST(ctx context.Context, astPkg *ast.Package) ([]interpreter.SideEffect, values.Scope, error) {
return runtime.EvalAST(ctx, astPkg)
}

func (d defaultService) Completer() complete.Completer {
return complete.NewCompleter(runtime.Prelude())
}
4 changes: 2 additions & 2 deletions query/influxql/compiler.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ func NewCompiler(dbrpMappingSvc platform.DBRPMappingService) *Compiler {
}

// Compile transpiles the query into a Program.
func (c *Compiler) Compile(ctx context.Context) (flux.Program, error) {
func (c *Compiler) Compile(ctx context.Context, runtime flux.Runtime) (flux.Program, error) {
var now time.Time
if c.Now != nil {
now = *c.Now
Expand All @@ -64,7 +64,7 @@ func (c *Compiler) Compile(ctx context.Context) (flux.Program, error) {
return nil, err
}
compileOptions := lang.WithLogPlanOpts(c.logicalPlannerOptions...)
return lang.CompileAST(astPkg, now, compileOptions), nil
return lang.CompileAST(astPkg, runtime, now, compileOptions), nil
}

func (c *Compiler) CompilerType() flux.CompilerType {
Expand Down
2 changes: 1 addition & 1 deletion query/promql/internal/promqltests/go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ require (
github.com/glycerine/goconvey v0.0.0-20190410193231-58a59202ab31 // indirect
github.com/gogo/protobuf v1.3.0 // indirect
github.com/google/go-cmp v0.3.1
github.com/influxdata/flux v0.60.1-0.20200305155158-1add321ebf7a
github.com/influxdata/flux v0.60.1-0.20200309174638-0dbc38c3785a
github.com/influxdata/influxdb v0.0.0-20190925213338-8af36d5aaedd
github.com/influxdata/influxql v1.0.1 // indirect
github.com/influxdata/promql/v2 v2.12.0
Expand Down
6 changes: 2 additions & 4 deletions query/promql/internal/promqltests/go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -174,8 +174,6 @@ github.com/gogo/protobuf v1.3.0 h1:G8O7TerXerS4F6sx9OV7/nRfJdnXgHZu/S/7F2SN+UE=
github.com/gogo/protobuf v1.3.0/go.mod h1:SlYgWuQ5SjCEi6WLHjHCa1yvBfUnHcTbrrZtXPKa29o=
github.com/golang/gddo v0.0.0-20181116215533-9bd4a3295021 h1:HYV500jCgk+IC68L5sWrLFIWMpaUFfXXpJSAb7XOoBk=
github.com/golang/gddo v0.0.0-20181116215533-9bd4a3295021/go.mod h1:xEhNfoBDX1hzLm2Nf80qUvZ2sVwoMZ8d6IE2SrsQfh4=
github.com/golang/geo v0.0.0-20190916061304-5b978397cfec h1:lJwO/92dFXWeXOZdoGXgptLmNLwynMSHUmU6besqtiw=
github.com/golang/geo v0.0.0-20190916061304-5b978397cfec/go.mod h1:QZ0nwyI2jOfgRAoBvP+ab5aRr7c9x7lhGEJrKvBwjWI=
github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b h1:VKtxabqXZkF25pY9ekfRL6a582T4P37/31XEstQ5p58=
github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q=
github.com/golang/groupcache v0.0.0-20180924190550-6f2cf27854a4/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
Expand Down Expand Up @@ -288,8 +286,8 @@ github.com/inconshreveable/mousetrap v1.0.0 h1:Z8tu5sraLXCXIcARxBp/8cbvlwVa7Z1NH
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
github.com/influxdata/cron v0.0.0-20191203200038-ded12750aac6 h1:OtjKkeWDjUbyMi82C7XXy7Tvm2LXMwiBBXyFIGNPaGA=
github.com/influxdata/cron v0.0.0-20191203200038-ded12750aac6/go.mod h1:XabtPPW2qsCg0tl+kjaPU+cFS+CjQXEXbT1VJvHT4og=
github.com/influxdata/flux v0.60.1-0.20200305155158-1add321ebf7a h1:Dczh6cTotsat9rt7GzD7EhGzpGFO5h0L3zAkQ1sJSds=
github.com/influxdata/flux v0.60.1-0.20200305155158-1add321ebf7a/go.mod h1:BRxpm1xTUAZ+s+Mq6t0NZyaYtlGrw/8YoHoifso9vS8=
github.com/influxdata/flux v0.60.1-0.20200309174638-0dbc38c3785a h1:VUxuayL83N9Fj3re2mOAgHWKCqRJFKRqqXK2mihLXMI=
github.com/influxdata/flux v0.60.1-0.20200309174638-0dbc38c3785a/go.mod h1:BRxpm1xTUAZ+s+Mq6t0NZyaYtlGrw/8YoHoifso9vS8=
github.com/influxdata/httprouter v1.3.1-0.20191122104820-ee83e2772f69 h1:WQsmW0fXO4ZE/lFGIE84G6rIV5SJN3P3sjIXAP1a8eU=
github.com/influxdata/httprouter v1.3.1-0.20191122104820-ee83e2772f69/go.mod h1:pwymjR6SrP3gD3pRj9RJwdl1j5s3doEEV8gS4X9qSzA=
github.com/influxdata/influxql v0.0.0-20180925231337-1cbfca8e56b6/go.mod h1:KpVI7okXjK6PRi3Z5B+mtKZli+R1DnZgb3N+tzevNgo=
Expand Down
2 changes: 1 addition & 1 deletion query/service_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ type compilerA struct {
A string `json:"a"`
}

func (c compilerA) Compile(ctx context.Context) (flux.Program, error) {
func (c compilerA) Compile(ctx context.Context, runtime flux.Runtime) (flux.Program, error) {
panic("not implemented")
}

Expand Down