0
0
mirror of https://github.com/PostHog/posthog.git synced 2024-12-01 12:21:02 +01:00
posthog/cypress/integration/featureFlags.js
Marius Andra 3e65af436d
Frontend Models (persistent logic) (#4627)
* move event and property definitions to models, refactor models to import via component if user present

* rename Logic to Model

* add personPropertiesModel

* refactor sessionFilters to use personPropertiesModel

* remove personProperties from inside propertyFilterLogic and use the model

* break ternary

* fix cohort and feature flag tests (for virutalized lists)
2021-06-08 15:16:10 +02:00

61 lines
2.9 KiB
JavaScript

describe('Feature Flags', () => {
beforeEach(() => {
cy.visit('/feature_flags')
})
it('Create feature flag', () => {
// ensure unique names to avoid clashes
const name = 'beta-feature' + Math.floor(Math.random() * 10000000)
cy.get('h1').should('contain', 'Feature Flags')
cy.get('[data-attr=new-feature-flag]').click()
cy.get('[data-attr=feature-flag-key]').type(name).should('have.value', name)
cy.get('[data-attr=feature-flag-description]')
.type('This is a new feature.')
.should('have.value', 'This is a new feature.')
// select "add filter" and "property"
cy.get('[data-attr=new-prop-filter-feature-flag-null-0-1').click()
// select the first property
cy.get('[data-attr=property-filter-dropdown]').click()
cy.get('[data-attr=property-filter-dropdown]').type('is_demo')
cy.get('[data-attr=prop-filter-person-0]').click({ force: true })
// selects the first value
cy.get('[data-attr=prop-val]').click()
cy.get('[data-attr=prop-val-0]').click({ force: true })
cy.get('[data-attr=feature-flag-submit]').click()
cy.get('.Toastify__toast-body').click() // clicking the toast gets you back to the list
cy.get('[data-attr=feature-flag-table]').should('contain', name)
cy.get('[data-attr=feature-flag-table]').should('not.contain', '%') // By default it's released to everyone, if a % is not specified
cy.get('[data-attr=feature-flag-table]').should('contain', 'is_demo')
cy.get('[data-attr=feature-flag-table] tr:first-child td:nth-child(2)').click()
cy.get('[data-attr=feature-flag-key]')
.type('-updated')
.should('have.value', name + '-updated')
cy.get('[data-attr=feature-flag-submit]').click()
cy.get('.Toastify__toast-body').click() // clicking the toast gets you back to the list
cy.get('[data-attr=feature-flag-table]').should('contain', name + '-updated')
cy.get('[data-attr=feature-flag-table] tr:first-child [data-attr=usage]').click()
cy.location().should((loc) => {
expect(loc.pathname.toString()).to.contain('/insight')
})
})
it('Delete feature flag', () => {
const name = 'to-be-deleted' + Math.floor(Math.random() * 10000000)
cy.get('h1').should('contain', 'Feature Flags')
cy.get('[data-attr=new-feature-flag]').click()
cy.get('[data-attr=feature-flag-key]').type(name).should('have.value', name)
cy.get('[data-attr=feature-flag-submit]').click()
cy.get('.Toastify__toast-body').click() // clicking the toast gets you back to the list
cy.get('[data-attr=feature-flag-table]').should('contain', name)
cy.get('[data-row-key="' + name + '"]').click()
cy.get('[data-attr=delete-flag]').click()
cy.contains('Click to undo').should('exist')
})
})