context('/src/Extensions/TextAlign/React/', () => { before(() => { cy.visit('/src/Extensions/TextAlign/React/') }) beforeEach(() => { cy.get('.tiptap').then(([{ editor }]) => { editor.commands.setContent('

Example Text

') }) }) it('should parse a null alignment correctly', () => { cy.get('.tiptap').then(([{ editor }]) => { editor.commands.setContent('

Example Text

') expect(editor.getHTML()).to.eq('

Example Text

') }) }) it('should parse left align text correctly', () => { cy.get('.tiptap').then(([{ editor }]) => { editor.commands.setContent('

Example Text

') expect(editor.getHTML()).to.eq('

Example Text

') }) }) it('should parse center align text correctly', () => { cy.get('.tiptap').then(([{ editor }]) => { editor.commands.setContent('

Example Text

') expect(editor.getHTML()).to.eq('

Example Text

') }) }) it('should parse right align text correctly', () => { cy.get('.tiptap').then(([{ editor }]) => { editor.commands.setContent('

Example Text

') expect(editor.getHTML()).to.eq('

Example Text

') }) }) it('should parse left justify text correctly', () => { cy.get('.tiptap').then(([{ editor }]) => { editor.commands.setContent('

Example Text

') expect(editor.getHTML()).to.eq('

Example Text

') }) }) it('should keep the text aligned when toggling headings', () => { const alignments = ['center', 'right', 'justify'] const headings = [1, 2] cy.get('.tiptap').then(([{ editor }]) => { alignments.forEach(alignment => { headings.forEach(level => { editor.commands.setContent(`

Example Text

`) editor.commands.toggleHeading({ level }) expect(editor.getHTML()).to.eq(`Example Text`) }) }) }) }) it('aligns the text left on the 1st button', () => { cy.get('button:nth-child(1)').click() cy.get('.tiptap').find('p').should('have.css', 'text-align', 'left') }) it('aligns the text center on the 2nd button', () => { cy.get('button:nth-child(2)').click() cy.get('.tiptap').find('p').should('have.css', 'text-align', 'center') }) it('aligns the text right on the 3rd button', () => { cy.get('button:nth-child(3)').click() cy.get('.tiptap').find('p').should('have.css', 'text-align', 'right') }) it('aligns the text justified on the 4th button', () => { cy.get('button:nth-child(4)').click() cy.get('.tiptap').find('p').should('have.css', 'text-align', 'justify') }) it('aligns the text default on the 5th button', () => { cy.get('button:nth-child(5)').click() cy.get('.tiptap').find('p').should('not.have.css', 'text-align', 'left') }) it('toggle the text to right on the 6th button', () => { cy.get('button:nth-child(6)').click() cy.get('.tiptap').find('p').should('have.css', 'text-align', 'right') cy.get('button:nth-child(6)').click() cy.get('.tiptap').find('p').should('not.have.css', 'text-align', 'right') }) it('aligns the text left when pressing the keyboard shortcut', () => { cy.get('.tiptap') .trigger('keydown', { modKey: true, shiftKey: true, key: 'l' }) .find('p') .should('have.css', 'text-align', 'left') }) it('aligns the text center when pressing the keyboard shortcut', () => { cy.get('.tiptap') .trigger('keydown', { modKey: true, shiftKey: true, key: 'e' }) .find('p') .should('have.css', 'text-align', 'center') }) it('aligns the text right when pressing the keyboard shortcut', () => { cy.get('.tiptap') .trigger('keydown', { modKey: true, shiftKey: true, key: 'r' }) .find('p') .should('have.css', 'text-align', 'right') }) it('aligns the text justified when pressing the keyboard shortcut', () => { cy.get('.tiptap') .trigger('keydown', { modKey: true, shiftKey: true, key: 'j' }) .find('p') .should('have.css', 'text-align', 'justify') }) })