import editor from '../selectors/editor.sel' import article from '../selectors/article.sel' describe('Article', () => { const articleLink = 'https://github.com/helenanull/cypress-example' beforeEach(() => { cy.register().then((email) => { cy.login(email) }) }) it('can create a new article', () => { cy.visit('/editor/') cy.get(editor.titleField).type('My post title') cy.get(editor.aboutField).type('Cypress') cy.get(editor.bodyField).type(`Cypress is so cool awyeah! ${articleLink}`) cy.get(editor.publishButton).click() cy.get(article.title).should('be.visible') .and('have.text', 'My post title') }) it('can add tags to article', () => { cy.visit('/editor/') cy.get(editor.titleField).type('My post title') cy.get(editor.aboutField).type('Cypress') cy.get(editor.bodyField).type(`Cypress is so cool awyeah! ${articleLink}`) cy.get(editor.tagsField).type('cypress{enter}') cy.get(editor.tagsField).should('have.value', '') cy.get(editor.addedTags).should('be.visible') .and('have.length', 1) .and('contain', 'cypress') cy.get(editor.tagsField).type('test-automation{enter}') cy.get(editor.tagsField).should('have.value', '') cy.get(editor.addedTags).should('be.visible') .and('have.length', 2) .and('contain', 'cypress') .and('contain', 'test-automation') cy.get(editor.publishButton).click() cy.get(article.title).should('be.visible') .and('have.text', 'My post title') cy.get(article.tags).should('be.visible') .and('have.length', 2) .and('contain', 'cypress') .and('contain', 'test-automation') }) it('can edit an article', () => { // we already know if creating an article works or not from the first test // we can now use shortcut (cy.createArticle() command) to test other scenarios cy.createArticle().then((link) => { cy.visit(`/editor/${link}`) }) cy.get(editor.titleField).should('be.visible') // to check field value, use have.value not have.text .and('have.value', 'My Cypress article') cy.get(editor.aboutField).should('be.visible') .and('have.value', articleLink) cy.get(editor.bodyField) .should('have.value', 'This article is created by createArticle Cypress command') .clear() .type('This is modified body') cy.get(editor.publishButton).click() cy.url().should('contain', '/article/my-cypress-article-') cy.get(article.title).should('be.visible') cy.get(article.body).should('be.visible') .and('have.text', 'This is modified body') }) it('can delete an article', () => { cy.intercept('DELETE', '/api/articles/**').as('deleteRequest') cy.createArticle().then((link) => { cy.visit(`/article/${link}`) }) cy.get(article.title).should('be.visible') cy.get(article.deleteButton).click() cy.wait('@deleteRequest').then((req) => { expect(req.response.statusCode).to.eq(200) }) cy.url().should('eq', `${Cypress.config('baseUrl')}/`) }) })