const apiUrl = Cypress.env('apiUrl'); describe('Forms', () => { it('Opens forms page', () => { cy.resetDB(); cy.loginAndVisit('/lists/forms'); }); it('Checks form URL', () => { cy.get('a[data-cy=url]').contains('http://localhost:9000'); }); it('Checks public lists', () => { cy.get('ul[data-cy=lists] li') .should('contain', 'Opt-in list') .its('length') .should('eq', 1); cy.get('[data-cy=form] pre').should('not.exist'); }); it('Selects public list', () => { // Click the list checkbox. cy.get('ul[data-cy=lists] .checkbox').click(); // Make sure the
form HTML has appeared. cy.get('[data-cy=form] pre').then(($pre) => { // Check that the ID of the list in the checkbox appears in the HTML. cy.get('ul[data-cy=lists] input').then(($inp) => { cy.wrap($pre).contains($inp.val()); }); }); // Click the list checkbox. cy.get('ul[data-cy=lists] .checkbox').click(); cy.get('[data-cy=form] pre').should('not.exist'); }); it('Subscribes from public form page', () => { // Create a public test list. cy.request('POST', `${apiUrl}/api/lists`, { name: 'test-list', type: 'public', optin: 'single' }); // Open the public page and subscribe to alternating lists multiple times. // There should be no errors and two new subscribers should be subscribed to two lists. for (let i = 0; i < 2; i++) { for (let j = 0; j < 2; j++) { cy.loginAndVisit(`${apiUrl}/subscription/form`); cy.get('input[name=email]').clear().type(`test${i}@test.com`); cy.get('input[name=name]').clear().type(`test${i}`); cy.get('input[type=checkbox]').eq(j).click(); cy.get('button').click(); cy.wait(250); cy.get('.wrap').contains(/has been sent|successfully/); } } // Verify form subscriptions. cy.request(`${apiUrl}/api/subscribers`).should((response) => { const { data } = response.body; // Two new + two dummy subscribers that are there by default. expect(data.total).to.equal(4); // The two new subscribers should each have two list subscriptions. for (let i = 0; i < 2; i++) { expect(data.results.find((s) => s.email === `test${i}@test.com`).lists.length).to.equal(2); } }); }); it('Unsubscribes', () => { // Add all lists to the dummy campaign. cy.request('PUT', `${apiUrl}/api/campaigns/1`, { 'lists': [2] }); cy.request('GET', `${apiUrl}/api/subscribers`).then((response) => { let subUUID = response.body.data.results[0].uuid; cy.request('GET', `${apiUrl}/api/campaigns`).then((response) => { let campUUID = response.body.data.results[0].uuid; cy.loginAndVisit(`${apiUrl}/subscription/${campUUID}/${subUUID}`); }); }); cy.wait(500); // Unsubscribe from one list. cy.get('button').click(); cy.request('GET', `${apiUrl}/api/subscribers`).then((response) => { const { data } = response.body; expect(data.results[0].lists.find((s) => s.id === 2).subscription_status).to.equal('unsubscribed'); expect(data.results[0].lists.find((s) => s.id === 3).subscription_status).to.equal('unconfirmed'); }); // Go back. cy.url().then((u) => { cy.loginAndVisit(u); }); // Unsubscribe from all. cy.get('#privacy-blocklist').click(); cy.get('button').click(); cy.request('GET', `${apiUrl}/api/subscribers`).then((response) => { const { data } = response.body; expect(data.results[0].status).to.equal('blocklisted'); expect(data.results[0].lists.find((s) => s.id === 2).subscription_status).to.equal('unsubscribed'); expect(data.results[0].lists.find((s) => s.id === 3).subscription_status).to.equal('unsubscribed'); }); }); it('Manages subscription preferences', () => { cy.request('GET', `${apiUrl}/api/subscribers`).then((response) => { let subUUID = response.body.data.results[1].uuid; cy.request('GET', `${apiUrl}/api/campaigns`).then((response) => { let campUUID = response.body.data.results[0].uuid; cy.loginAndVisit(`${apiUrl}/subscription/${campUUID}/${subUUID}?manage=1`); }); }); // Change name and unsubscribe from one list. cy.get('input[name=name]').clear().type('new-name'); cy.get('ul.lists input:first').click(); cy.get('button:first').click(); cy.request('GET', `${apiUrl}/api/subscribers`).then((response) => { const { data } = response.body; expect(data.results[1].name).to.equal('new-name'); expect(data.results[1].lists.find((s) => s.id === 2).subscription_status).to.equal('unsubscribed'); expect(data.results[1].lists.find((s) => s.id === 3).subscription_status).to.equal('unconfirmed'); }); }); });