mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
d2fb800174
[web] Display a message for custom personal subscriptions in React dash GitOrigin-RevId: c70986ffacfdfdeccd3675385e2e5dba1a2ad61f
148 lines
5 KiB
TypeScript
148 lines
5 KiB
TypeScript
import { expect } from 'chai'
|
|
import { screen } from '@testing-library/react'
|
|
import PersonalSubscription from '../../../../../../frontend/js/features/subscription/components/dashboard/personal-subscription'
|
|
import {
|
|
annualActiveSubscription,
|
|
canceledSubscription,
|
|
customSubscription,
|
|
pastDueExpiredSubscription,
|
|
} from '../../fixtures/subscriptions'
|
|
import {
|
|
cleanUpContext,
|
|
renderWithSubscriptionDashContext,
|
|
} from '../../helpers/render-with-subscription-dash-context'
|
|
|
|
describe('<PersonalSubscription />', function () {
|
|
afterEach(function () {
|
|
cleanUpContext()
|
|
})
|
|
|
|
describe('no subscription', function () {
|
|
it('returns empty container', function () {
|
|
const { container } = renderWithSubscriptionDashContext(
|
|
<PersonalSubscription />
|
|
)
|
|
expect(container.firstChild).to.be.null
|
|
})
|
|
})
|
|
|
|
describe('custom subscription', function () {
|
|
it('displays contact support message', function () {
|
|
renderWithSubscriptionDashContext(<PersonalSubscription />, {
|
|
metaTags: [{ name: 'ol-subscription', value: customSubscription }],
|
|
})
|
|
|
|
screen.getByText('Please', { exact: false })
|
|
screen.getByText('contact support', { exact: false })
|
|
screen.getByText('to make changes to your plan', { exact: false })
|
|
})
|
|
})
|
|
|
|
describe('subscription states ', function () {
|
|
it('renders the active dash', function () {
|
|
renderWithSubscriptionDashContext(<PersonalSubscription />, {
|
|
metaTags: [
|
|
{ name: 'ol-subscription', value: annualActiveSubscription },
|
|
],
|
|
})
|
|
|
|
screen.getByText('You are currently subscribed to the', { exact: false })
|
|
})
|
|
|
|
it('renders the canceled dash', function () {
|
|
renderWithSubscriptionDashContext(<PersonalSubscription />, {
|
|
metaTags: [{ name: 'ol-subscription', value: canceledSubscription }],
|
|
})
|
|
screen.getByText(
|
|
'Your subscription has been canceled and will terminate on',
|
|
{ exact: false }
|
|
)
|
|
screen.getByText(canceledSubscription.recurly!.nextPaymentDueAt, {
|
|
exact: false,
|
|
})
|
|
|
|
screen.getByText('No further payments will be taken.', { exact: false })
|
|
|
|
screen.getByText(
|
|
'Get the most out of your Overleaf subscription by checking out the list of',
|
|
{ exact: false }
|
|
)
|
|
|
|
screen.getByRole('link', { name: 'View Your Invoices' })
|
|
screen.getByRole('button', { name: 'Reactivate your subscription' })
|
|
})
|
|
|
|
it('renders the expired dash', function () {
|
|
renderWithSubscriptionDashContext(<PersonalSubscription />, {
|
|
metaTags: [
|
|
{ name: 'ol-subscription', value: pastDueExpiredSubscription },
|
|
],
|
|
})
|
|
screen.getByText('Your subscription has expired.')
|
|
})
|
|
|
|
it('renders error message when an unknown subscription state', function () {
|
|
const withStateDeleted = Object.assign(
|
|
{},
|
|
JSON.parse(JSON.stringify(annualActiveSubscription))
|
|
)
|
|
withStateDeleted.recurly.state = undefined
|
|
renderWithSubscriptionDashContext(<PersonalSubscription />, {
|
|
metaTags: [{ name: 'ol-subscription', value: withStateDeleted }],
|
|
})
|
|
screen.getByText(
|
|
'There is a problem with your subscription. Please contact us for more information.'
|
|
)
|
|
})
|
|
})
|
|
|
|
describe('past due subscription', function () {
|
|
it('renders error alert', function () {
|
|
renderWithSubscriptionDashContext(<PersonalSubscription />, {
|
|
metaTags: [
|
|
{ name: 'ol-subscription', value: pastDueExpiredSubscription },
|
|
],
|
|
})
|
|
screen.getByRole('alert')
|
|
screen.getByText(
|
|
'Your account currently has a past due invoice. You will not be able to change your plan until this is resolved.',
|
|
{ exact: false }
|
|
)
|
|
const invoiceLinks = screen.getAllByText('View Your Invoices', {
|
|
exact: false,
|
|
})
|
|
expect(invoiceLinks.length).to.equal(2)
|
|
})
|
|
})
|
|
|
|
describe('Recurly JS', function () {
|
|
const recurlyFailedToLoadText =
|
|
'Sorry, there was an error talking to our payment provider. Please try again in a few moments. If you are using any ad or script blocking extensions in your browser, you may need to temporarily disable them.'
|
|
|
|
it('shows an alert and hides "Change plan" option when Recurly did not load', function () {
|
|
renderWithSubscriptionDashContext(<PersonalSubscription />, {
|
|
metaTags: [
|
|
{ name: 'ol-subscription', value: annualActiveSubscription },
|
|
],
|
|
recurlyNotLoaded: true,
|
|
})
|
|
|
|
screen.getByRole('alert')
|
|
screen.getByText(recurlyFailedToLoadText)
|
|
|
|
expect(screen.queryByText('Change plan')).to.be.null
|
|
})
|
|
|
|
it('should not show an alert and should show "Change plan" option when Recurly did load', function () {
|
|
renderWithSubscriptionDashContext(<PersonalSubscription />, {
|
|
metaTags: [
|
|
{ name: 'ol-subscription', value: annualActiveSubscription },
|
|
],
|
|
})
|
|
|
|
expect(screen.queryByRole('alert')).to.be.null
|
|
|
|
screen.getByText('Change plan')
|
|
})
|
|
})
|
|
})
|