2021-02-20 16:19:14 +08:00
|
|
|
describe('Templates', () => {
|
|
|
|
it('Opens templates page', () => {
|
|
|
|
cy.resetDB();
|
|
|
|
cy.loginAndVisit('/campaigns/templates');
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it('Counts default templates', () => {
|
2022-07-02 19:24:52 +08:00
|
|
|
cy.get('tbody td[data-label=Name]').should('have.length', 2);
|
2021-02-20 16:19:14 +08:00
|
|
|
});
|
|
|
|
|
2022-07-02 19:24:52 +08:00
|
|
|
it('Clones campaign template', () => {
|
2021-02-20 16:19:14 +08:00
|
|
|
cy.get('[data-cy=btn-clone]').first().click();
|
|
|
|
cy.get('.modal input').clear().type('cloned').click();
|
|
|
|
cy.get('.modal button.is-primary').click();
|
|
|
|
cy.wait(250);
|
|
|
|
|
|
|
|
// Verify the newly created row.
|
2022-07-02 19:24:52 +08:00
|
|
|
cy.get('tbody td[data-label="Name"]').eq(2).contains('cloned');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Clones tx template', () => {
|
|
|
|
cy.get('tbody tr:nth-child(2) [data-cy=btn-clone]').click();
|
|
|
|
cy.get('.modal input').clear().type('cloned').click();
|
|
|
|
cy.get('.modal button.is-primary').click();
|
|
|
|
cy.wait(250);
|
|
|
|
|
|
|
|
// Verify the newly created row.
|
|
|
|
cy.get('tbody td[data-label="Name"]').eq(3).contains('cloned');
|
2021-02-20 16:19:14 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it('Edits template', () => {
|
|
|
|
cy.get('tbody td.actions [data-cy=btn-edit]').first().click();
|
|
|
|
cy.wait(250);
|
|
|
|
cy.get('input[name=name]').clear().type('edited');
|
2021-09-26 22:43:12 +08:00
|
|
|
cy.get('code-flask').shadow().find('.codeflask textarea').invoke('val', '<span>test</span> {{ template "content" . }}').trigger('input');
|
|
|
|
|
2021-05-16 17:56:38 +08:00
|
|
|
cy.get('.modal-card-foot button.is-primary').click();
|
2021-02-20 16:19:14 +08:00
|
|
|
cy.wait(250);
|
|
|
|
cy.get('tbody td[data-label="Name"] a').contains('edited');
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it('Previews templates', () => {
|
|
|
|
// Edited one sould have a bare body.
|
|
|
|
cy.get('tbody [data-cy=btn-preview').eq(0).click();
|
|
|
|
cy.wait(500);
|
|
|
|
cy.get('.modal-card-body iframe').iframe(() => {
|
|
|
|
cy.get('span').first().contains('test');
|
|
|
|
cy.get('p').first().contains('Hi there');
|
|
|
|
});
|
2021-05-16 17:56:38 +08:00
|
|
|
cy.get('.modal-card-foot button').click();
|
2021-02-20 16:19:14 +08:00
|
|
|
|
|
|
|
// Cloned one should have the full template.
|
2022-07-02 19:24:52 +08:00
|
|
|
cy.get('tbody [data-cy=btn-preview').eq(2).click();
|
2021-02-20 16:19:14 +08:00
|
|
|
cy.wait(500);
|
|
|
|
cy.get('.modal-card-body iframe').iframe(() => {
|
|
|
|
cy.get('.wrap p').first().contains('Hi there');
|
|
|
|
cy.get('.footer a').first().contains('Unsubscribe');
|
|
|
|
});
|
2021-05-16 17:56:38 +08:00
|
|
|
cy.get('.modal-card-foot button').click();
|
2021-02-20 16:19:14 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
it('Sets default', () => {
|
2022-07-02 19:24:52 +08:00
|
|
|
cy.get('tbody td.actions').eq(2).find('[data-cy=btn-set-default]').click();
|
2021-02-20 16:19:14 +08:00
|
|
|
cy.get('.modal button.is-primary').click();
|
|
|
|
|
|
|
|
// The original default shouldn't have default and the new one should have.
|
|
|
|
cy.get('tbody td.actions').eq(0).then((el) => {
|
|
|
|
cy.wrap(el).find('[data-cy=btn-delete]').should('exist');
|
|
|
|
cy.wrap(el).find('[data-cy=btn-set-default]').should('exist');
|
|
|
|
});
|
2022-07-02 19:24:52 +08:00
|
|
|
cy.get('tbody td.actions').eq(2).then((el) => {
|
2021-02-20 16:19:14 +08:00
|
|
|
cy.wrap(el).find('[data-cy=btn-delete]').should('not.exist');
|
|
|
|
cy.wrap(el).find('[data-cy=btn-set-default]').should('not.exist');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it('Deletes template', () => {
|
2021-05-16 17:56:38 +08:00
|
|
|
cy.wait(250);
|
2022-07-02 19:24:52 +08:00
|
|
|
|
|
|
|
[1, 1, 2].forEach((n) => {
|
|
|
|
cy.get(`tbody tr:nth-child(${n}) td.actions [data-cy=btn-delete]`).click();
|
|
|
|
cy.get('.modal button.is-primary').click();
|
|
|
|
cy.wait(250);
|
|
|
|
})
|
|
|
|
|
2021-02-20 16:19:14 +08:00
|
|
|
cy.get('tbody td.actions').should('have.length', 1);
|
|
|
|
});
|
|
|
|
});
|