mirror of
https://github.com/PostHog/posthog.git
synced 2024-11-24 09:14:46 +01:00
140 lines
5.4 KiB
TypeScript
140 lines
5.4 KiB
TypeScript
import { decideResponse } from '../fixtures/api/decide'
|
|
import { createInsight, createInsightWithBreakdown } from '../productAnalytics'
|
|
|
|
describe('Alerts', () => {
|
|
beforeEach(() => {
|
|
cy.intercept('**/decide/*', (req) =>
|
|
req.reply(
|
|
decideResponse({
|
|
alerts: true,
|
|
})
|
|
)
|
|
)
|
|
createInsight('insight')
|
|
})
|
|
|
|
const createAlert = (
|
|
name: string = 'Alert name',
|
|
lowerThreshold: string = '100',
|
|
upperThreshold: string = '200',
|
|
condition?: string
|
|
): void => {
|
|
cy.contains('Alerts').click()
|
|
cy.contains('New alert').click()
|
|
|
|
cy.get('[data-attr=alertForm-name]').clear().type(name)
|
|
cy.get('[data-attr=subscribed-users').click().type('{downarrow}{enter}')
|
|
|
|
if (condition) {
|
|
cy.get('[data-attr=alertForm-condition').click()
|
|
cy.contains(condition).click()
|
|
cy.contains('%').click()
|
|
}
|
|
|
|
cy.get('[data-attr=alertForm-lower-threshold').clear().type(lowerThreshold)
|
|
cy.get('[data-attr=alertForm-upper-threshold').clear().type(upperThreshold)
|
|
cy.contains('Create alert').click()
|
|
cy.get('.Toastify__toast-body').should('contain', 'Alert created.')
|
|
cy.url().should('not.include', '/new')
|
|
cy.get('[data-attr=alert-list-item]').contains(name).should('exist')
|
|
|
|
cy.contains('span', 'Close').click()
|
|
}
|
|
|
|
const setInsightDisplayTypeAndSave = (displayType: string): void => {
|
|
// Only the Number representation supports alerts, so change the insight
|
|
cy.get('[data-attr=insight-edit-button]').click()
|
|
cy.get('[data-attr=chart-filter]').click()
|
|
cy.contains(displayType).click()
|
|
cy.get('[data-attr=insight-save-button]').contains('Save').click()
|
|
cy.url().should('not.include', '/edit')
|
|
}
|
|
|
|
it('Should allow create and delete an alert', () => {
|
|
// Alerts should be disabled for trends represented with graphs
|
|
cy.contains('Alerts').should('have.attr', 'aria-disabled', 'true')
|
|
|
|
setInsightDisplayTypeAndSave('Number')
|
|
|
|
createAlert()
|
|
cy.reload()
|
|
|
|
// Check the alert has the same values as when it was created
|
|
cy.contains('Alerts').click()
|
|
cy.get('[data-attr=alert-list-item]').contains('Alert name').click()
|
|
cy.get('[data-attr=alertForm-name]').should('have.value', 'Alert name')
|
|
cy.get('[data-attr=alertForm-lower-threshold').should('have.value', '100')
|
|
cy.get('[data-attr=alertForm-upper-threshold').should('have.value', '200')
|
|
cy.contains('Delete alert').click()
|
|
cy.wait(2000)
|
|
|
|
cy.reload()
|
|
cy.contains('Alert name').should('not.exist')
|
|
})
|
|
|
|
it('Should warn about an alert deletion', () => {
|
|
setInsightDisplayTypeAndSave('Area chart')
|
|
|
|
createAlert('Alert to be deleted because of a changed insight')
|
|
|
|
cy.get('[data-attr=insight-edit-button]').click()
|
|
cy.contains('span', 'Funnels').click()
|
|
|
|
cy.contains('the existing alerts will be deleted').should('exist')
|
|
|
|
// Assert that reverting the display type removes the banner
|
|
cy.contains('span', 'Trends').click()
|
|
cy.contains('the existing alerts will be deleted').should('not.exist')
|
|
|
|
// Assert that saving an insight in an incompatible state removes alerts
|
|
cy.contains('span', 'Funnels').click()
|
|
cy.get('[data-attr=insight-save-button]').contains('Save').click()
|
|
|
|
cy.contains('Alerts').click()
|
|
cy.contains('Alert to be deleted because of a changed insight').should('not.exist')
|
|
})
|
|
|
|
it('Should allow create and delete a relative alert', () => {
|
|
// Alerts should be disabled for trends represented with graphs
|
|
cy.contains('Alerts').should('have.attr', 'aria-disabled', 'true')
|
|
|
|
setInsightDisplayTypeAndSave('Bar chart')
|
|
|
|
createAlert('Alert name', '10', '20', 'increases by')
|
|
cy.reload()
|
|
|
|
// Check the alert has the same values as when it was created
|
|
cy.contains('Alerts').click()
|
|
cy.get('[data-attr=alert-list-item]').contains('Alert name').click()
|
|
cy.get('[data-attr=alertForm-name]').should('have.value', 'Alert name')
|
|
cy.get('[data-attr=alertForm-lower-threshold').should('have.value', '10')
|
|
cy.get('[data-attr=alertForm-upper-threshold').should('have.value', '20')
|
|
cy.contains('Delete alert').click()
|
|
cy.wait(2000)
|
|
|
|
cy.reload()
|
|
cy.contains('Alert name').should('not.exist')
|
|
})
|
|
|
|
it('Should allow creating alerts on trends with breakdowns', () => {
|
|
createInsightWithBreakdown('insight with breakdown')
|
|
setInsightDisplayTypeAndSave('Bar chart')
|
|
|
|
createAlert('Alert name', '10', '20', 'increases by')
|
|
cy.reload()
|
|
|
|
// Check the alert has the same values as when it was created
|
|
cy.contains('Alerts').click()
|
|
cy.get('[data-attr=alert-list-item]').contains('Alert name').click()
|
|
cy.contains('any breakdown value').should('exist')
|
|
cy.get('[data-attr=alertForm-name]').should('have.value', 'Alert name')
|
|
cy.get('[data-attr=alertForm-lower-threshold').should('have.value', '10')
|
|
cy.get('[data-attr=alertForm-upper-threshold').should('have.value', '20')
|
|
cy.contains('Delete alert').click()
|
|
cy.wait(2000)
|
|
|
|
cy.reload()
|
|
cy.contains('Alert name').should('not.exist')
|
|
})
|
|
})
|