0
0
mirror of https://github.com/PostHog/posthog.git synced 2024-11-25 11:17:50 +01:00
posthog/cypress/e2e/signup.cy.ts
Paul D'Ambra 5da50e633a
fix: throw error so test failures are not swallowed (#17926)
So obvious in retrospect

If you listen to the Cypress fail event without re-throwing then you swallow all test failures

"fun"

When reviewing #17919 I knew the Cypress tests would have to be failing which is what prompted me to check

Introduced in bbb7ed9 (July 10th!)
2023-10-12 00:51:47 +01:00

102 lines
4.9 KiB
TypeScript

import { decideResponse } from '../fixtures/api/decide'
describe('Signup', () => {
beforeEach(() => {
cy.get('[data-attr=top-menu-toggle]').click()
cy.get('[data-attr=top-menu-item-logout]').click()
cy.location('pathname').should('include', '/login')
cy.visit('/signup')
})
it('Cannot create account with existing email', () => {
cy.get('[data-attr=signup-email]').type('test@posthog.com').should('have.value', 'test@posthog.com')
cy.get('[data-attr=password]').type('12345678').should('have.value', '12345678')
cy.get('[data-attr=signup-start]').click()
cy.get('[data-attr=signup-first-name]').type('Jane').should('have.value', 'Jane')
cy.get('[data-attr=signup-organization-name]').type('Hogflix Movies').should('have.value', 'Hogflix Movies')
cy.get('[data-attr=signup-role-at-organization]').click()
cy.get('.Popover li:first-child').click()
cy.get('[data-attr=signup-role-at-organization]').contains('Engineering')
cy.get('[data-attr=signup-submit]').click()
cy.get('.LemonBanner').should('contain', 'There is already an account with this email address.')
})
it('Cannot signup without required attributes', () => {
cy.get('[data-attr=signup-start]').click()
cy.get('.text-danger').should('contain', 'Please enter your email to continue')
cy.get('.text-danger').should('contain', 'Please enter your password to continue')
})
it('Cannot signup with invalid attributes', () => {
cy.get('[data-attr=password]').type('123').should('have.value', '123')
cy.get('.text-danger').should('not.exist') // Validation errors not shown until first submission
cy.get('[data-attr=signup-start]').click()
cy.get('.text-danger').should('contain', 'Please enter your email to continue')
cy.get('.text-danger').should('contain', 'Password must be at least 8 characters')
cy.get('[data-attr=password]').type('45678901')
cy.get('.text-danger').should('not.contain', 'Password must be at least 8 characters') // Validation error removed on keystroke
})
it('Can create user account', () => {
const email = `new_user+${Math.floor(Math.random() * 10000)}@posthog.com`
cy.get('[data-attr=signup-email]').type(email).should('have.value', email)
cy.get('[data-attr=password]').type('12345678').should('have.value', '12345678')
cy.get('[data-attr=signup-start]').click()
cy.get('[data-attr=signup-first-name]').type('Alice').should('have.value', 'Alice')
cy.get('[data-attr=signup-organization-name]').type('Hogflix SpinOff').should('have.value', 'Hogflix SpinOff')
cy.get('[data-attr=signup-role-at-organization]').click()
cy.get('.Popover li:first-child').click()
cy.get('[data-attr=signup-role-at-organization]').contains('Engineering')
cy.get('[data-attr=signup-submit]').click()
// lazy regex for a guid
cy.location('pathname').should('match', /\/verify_email\/[a-zA-Z0-9_.-]*/)
})
it('Can fill out all the fields on social login', () => {
// We can't actually test the social login feature.
// But, we can make sure the form exists as it should, and that upon submit
// we get the expected error that no social session exists.
cy.visit('/logout')
cy.location('pathname').should('include', '/login')
cy.visit('/organization/confirm-creation?organization_name=&first_name=Test&email=test%40posthog.com')
cy.get('[name=email]').should('have.value', 'test@posthog.com')
cy.get('[name=first_name]').should('have.value', 'Test')
cy.get('[name=organization_name]').type('Hogflix SpinOff').should('have.value', 'Hogflix SpinOff')
cy.get('[data-attr=signup-role-at-organization]').click()
cy.get('.Popover li:first-child').click()
cy.get('[data-attr=signup-role-at-organization]').contains('Engineering')
cy.get('[type=submit]').click()
// if there are other form issues, we'll get errors on the form, not this toast
cy.get('.Toastify [data-attr="error-toast"]').contains('Inactive social login session.')
})
it('Shows redirect notice if redirecting for maintenance', () => {
cy.intercept('https://app.posthog.com/decide/*', (req) =>
req.reply(
decideResponse({
'redirect-signups-to-instance': 'us',
})
)
)
cy.visit('/logout')
cy.location('pathname').should('include', '/login')
cy.visit('/signup?maintenanceRedirect=true', {
onLoad(win: Cypress.AUTWindow) {
win.POSTHOG_APP_CONTEXT.preflight.cloud = true
},
})
cy.get('[data-attr="info-toast"]')
.contains(
`You've been redirected to signup on our US instance while we perform maintenance on our other instance.`
)
.should('be.visible')
})
})