add federated/local timeline tests

This commit is contained in:
Nolan Lawson 2018-02-18 16:43:39 -08:00
parent 03073ac846
commit babd3c7b84
2 changed files with 55 additions and 28 deletions

View File

@ -1,40 +1,55 @@
const times = require('lodash/times')
describe('Basic timeline spec', () => { describe('Basic timeline spec', () => {
before(() => {
cy.login('foobar@localhost:3000', 'foobarfoobar')
})
beforeEach(() => { beforeEach(() => {
cy.login('foobar@localhost:3000', 'foobarfoobar')
cy.visit('/') cy.visit('/')
}) })
it('Shows some articles', () => { const homeTimeline = [
{content: 'this is unlisted'},
{content: 'this is followers-only'},
{content: 'direct'},
{spoiler: 'kitten CW'},
{content: 'secret video'},
{content: "here's a video"},
{spoiler: 'CW'},
{content: "here's a secret animated kitten gif"},
{content: "here's an animated kitten gif"},
{content: "here's 2 kitten photos"},
{content: "here's a secret kitten"},
{content: "here's a kitten"},
{content: 'hello admin'},
{content: 'hello foobar'},
{content: 'hello world'}
].concat(times(30, i => ({content: (30 - i).toString()})))
const localTimeline = homeTimeline.slice()
localTimeline.splice(0, 3)
localTimeline.splice(9, 2)
it('Shows the home timeline', () => {
cy.get('.virtual-list-item[aria-hidden=false] .status-article:first').should('have.attr', 'aria-setsize') cy.get('.virtual-list-item[aria-hidden=false] .status-article:first').should('have.attr', 'aria-setsize')
cy.get('.virtual-list-item[aria-hidden=false] .status-article:first').should('have.attr', 'aria-posinset', '0') cy.get('.virtual-list-item[aria-hidden=false] .status-article:first').should('have.attr', 'aria-posinset', '0')
cy.getNthVirtualArticle(0).get('.status-content p').should('contain', 'this is unlisted')
cy.getNthVirtualArticle(1).get('.status-content p').should('contain', 'this is followers-only') cy.validateTimeline(homeTimeline)
cy.getNthVirtualArticle(2).get('.status-content p').should('contain', 'direct')
cy.getNthVirtualArticle(3).get('.status-spoiler p').should('contain', 'kitten CW')
cy.getNthVirtualArticle(4).get('.status-content p').should('contain', 'secret video')
cy.getNthVirtualArticle(4).scrollIntoView()
cy.getNthVirtualArticle(5).get('.status-content p').should('contain', "here's a video")
cy.getNthVirtualArticle(6).get('.status-spoiler p').should('contain', 'CW')
cy.getNthVirtualArticle(7).get('.status-content p').should('contain', "here's a secret animated kitten gif")
cy.getNthVirtualArticle(8).get('.status-content p').should('contain', "here's an animated kitten gif")
cy.getNthVirtualArticle(8).scrollIntoView()
cy.getNthVirtualArticle(9).get('.status-content p').should('contain', "here's 2 kitten photos")
cy.getNthVirtualArticle(10).get('.status-content p').should('contain', "here's a secret kitten")
cy.getNthVirtualArticle(11).get('.status-content p').should('contain', "here's a kitten")
cy.getNthVirtualArticle(11).scrollIntoView()
cy.getNthVirtualArticle(12).get('.status-content p').should('contain', 'hello admin')
cy.getNthVirtualArticle(13).get('.status-content p').should('contain', 'hello foobar')
cy.getNthVirtualArticle(14).get('.status-content p').should('contain', 'hello world')
cy.getNthVirtualArticle(14).scrollIntoView()
for (let i = 0; i < 30; i++) {
cy.getNthVirtualArticle(15 + i).scrollIntoView()
cy.getNthVirtualArticle(15 + i).get('.status-content p').should('contain', (30 - i).toString())
}
cy.get('.virtual-list-item[aria-hidden=false] .status-article:first').should('have.attr', 'aria-setsize', (30 + 15).toString()) cy.get('.virtual-list-item[aria-hidden=false] .status-article:first').should('have.attr', 'aria-setsize', (30 + 15).toString())
}) })
it('Shows the local timeline', () => {
cy.get('nav a').contains('Local').click()
cy.url().should('contain', '/local')
cy.validateTimeline(localTimeline)
})
it('Shows the federated timeline', () => {
cy.get('nav a').contains('Community').click()
cy.url().should('contain', '/community')
cy.get('a').contains('Federated').click()
cy.url().should('contain', '/federated')
cy.validateTimeline(localTimeline) // local is same as federated in this case
})
}) })

View File

@ -50,3 +50,15 @@ Cypress.Commands.add('login', (email, password) => {
Cypress.Commands.add('getNthVirtualArticle', (n) => { Cypress.Commands.add('getNthVirtualArticle', (n) => {
return cy.get(`.virtual-list-item[aria-hidden=false] .status-article[aria-posinset=${n}]`) return cy.get(`.virtual-list-item[aria-hidden=false] .status-article[aria-posinset=${n}]`)
}) })
Cypress.Commands.add('validateTimeline', (timeline) => {
timeline.forEach((status, i) => {
if (status.content) {
cy.getNthVirtualArticle(i).get('.status-content p').should('contain', status.content)
}
if (status.spoiler) {
cy.getNthVirtualArticle(i).get('.status-spoiler p').should('contain', status.spoiler)
}
cy.getNthVirtualArticle(i).scrollIntoView()
})
})