chore(hydrate-variable-test): added a test to ensure variable hydration happens correctly in nested queries (#18790)

pull/18793/head
Ariel Salem 2020-06-29 13:44:03 -07:00 committed by GitHub
parent 849927158e
commit 9bd5de23bd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 100 additions and 6 deletions

View File

@ -449,12 +449,12 @@ describe('Dashboard', () => {
.clear() .clear()
.type( .type(
`from(bucket: v.bucketsCSV) `from(bucket: v.bucketsCSV)
|> range(start: v.timeRangeStart, stop: v.timeRangeStop) |> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|> filter(fn: (r) => r["_measurement"] == "m") |> filter(fn: (r) => r["_measurement"] == "m")
|> filter(fn: (r) => r["_field"] == "v") |> filter(fn: (r) => r["_field"] == "v")
|> filter(fn: (r) => r["tk1"] == "tv1") |> filter(fn: (r) => r["tk1"] == "tv1")
|> aggregateWindow(every: v.windowPeriod, fn: max) |> aggregateWindow(every: v.windowPeriod, fn: max)
|> yield(name: "max")`, |> yield(name: "max")`,
{force: true, delay: 1} {force: true, delay: 1}
) )
@ -475,6 +475,100 @@ describe('Dashboard', () => {
}) })
}) })
it('ensures that dependent variables load one another accordingly', () => {
cy.get('@org').then(({id: orgID}: Organization) => {
cy.createDashboard(orgID).then(({body: dashboard}) => {
const now = Date.now()
cy.writeData([
`test,container_name=cool dopeness=12 ${now - 1000}000000`,
`test,container_name=beans dopeness=18 ${now - 1200}000000`,
`test,container_name=cool dopeness=14 ${now - 1400}000000`,
`test,container_name=beans dopeness=10 ${now - 1600}000000`,
])
cy.createCSVVariable(orgID, 'static', ['beans', 'defbuck'])
cy.createQueryVariable(
orgID,
'dependent',
`import "influxdata/influxdb/v1"
v1.tagValues(bucket: v.static, tag: "container_name") |> keep(columns: ["_value"])`
)
cy.createQueryVariable(
orgID,
'build',
`import "influxdata/influxdb/v1"
import "strings"
v1.tagValues(bucket: v.static, tag: "container_name") |> filter(fn: (r) => strings.hasSuffix(v: r._value, suffix: v.dependent))`
)
cy.fixture('routes').then(({orgs}) => {
cy.visit(`${orgs}/${orgID}/dashboards/${dashboard.id}`)
})
})
cy.getByTestID('add-cell--button').click()
cy.getByTestID('switch-to-script-editor').should('be.visible')
cy.getByTestID('switch-to-script-editor').click()
cy.getByTestID('toolbar-tab').click()
cy
.getByTestID('flux-editor')
.should('be.visible')
.click()
.focused().type(`// v.build
from(bucket: v.static)
|> range(start: v.timeRangeStart, stop: v.timeRangeStop)
|> filter(fn: (r) => r["_measurement"] == "test")
|> filter(fn: (r) => r["_field"] == "dopeness")
|> filter(fn: (r) => r["container_name"] == v.dependent)`)
cy.getByTestID('save-cell--button').click()
// the default bucket selection should have no results
cy.getByTestID('variable-dropdown')
.should('have.length', 3)
.eq(0)
.should('contain', 'beans')
// and cause the rest to exist in loading states
cy.getByTestID('variable-dropdown')
.eq(1)
.should('contain', 'Loading')
cy.getByTestIDSubStr('cell--view-empty')
// But selecting a nonempty bucket should load some data
cy.getByTestID('variable-dropdown--button')
.eq(0)
.click()
cy.get(`#defbuck`).click()
// default select the first result
cy.getByTestID('variable-dropdown')
.eq(1)
.should('contain', 'beans')
// and also load the second result
cy.getByTestID('variable-dropdown--button')
.eq(1)
.click()
cy.get(`#cool`).click()
// and also load the third result
cy.getByTestID('variable-dropdown')
.eq(2)
.should('contain', 'cool')
// updating the second variable should update the third
cy.getByTestID('variable-dropdown--button')
.eq(1)
.click()
cy.get(`#beans`).click()
cy.getByTestID('variable-dropdown')
.eq(2)
.should('contain', 'beans')
})
})
/*\ /*\
built to approximate an instance with docker metrics, built to approximate an instance with docker metrics,
operating with the variables: operating with the variables: