mirror of
https://github.com/IT4Change/Ocelot-Social.git
synced 2025-12-13 07:45:56 +00:00
155 lines
4.3 KiB
JavaScript
155 lines
4.3 KiB
JavaScript
import { Given, When, Then } from 'cypress-cucumber-preprocessor/steps'
|
|
import find from 'lodash/find'
|
|
import { eq } from 'semver';
|
|
|
|
/* global cy */
|
|
|
|
const baseUrl = 'http://localhost:3000'
|
|
const username = 'Peter Lustig'
|
|
|
|
const locales = require('../../../locales')
|
|
// TODO: use the native locale files
|
|
const localeStrings = {
|
|
login: {
|
|
English: 'Login',
|
|
Deutsch: 'Einloggen',
|
|
Français: 'Connexion'
|
|
}
|
|
}
|
|
|
|
const getLangByName = function(name) {
|
|
return find(locales, { name })
|
|
}
|
|
|
|
const openPage = function(page) {
|
|
if (page === 'landing') {
|
|
page = ''
|
|
}
|
|
cy.visit(`${baseUrl}/${page}`)
|
|
cy.get('html[data-n-head]')
|
|
}
|
|
|
|
const login = (email, password) => {
|
|
cy.visit(`${baseUrl}/login`)
|
|
cy.get('input[name=email]')
|
|
.trigger('focus')
|
|
.type(email)
|
|
cy.get('input[name=password]')
|
|
.trigger('focus')
|
|
.type(password)
|
|
cy.get('button[name=submit]')
|
|
.as('submitButton')
|
|
.click()
|
|
cy.location('pathname').should('eq', '/') // we're in!
|
|
}
|
|
|
|
const logout = () => {
|
|
cy.visit(`${baseUrl}/logout`)
|
|
cy.location('pathname').should('contain', '/login') // we're out
|
|
}
|
|
|
|
Given('I am logged in', () => {
|
|
login('admin@example.org', 1234)
|
|
})
|
|
|
|
Given('we have a selection of tags and categories as well as posts', () => {
|
|
// TODO: use db factories instead of seed data
|
|
})
|
|
|
|
Given('my account has the following details:', (table) => {
|
|
// TODO: use db factories instead of seed data
|
|
})
|
|
|
|
Given('my user account has the role {string}', (role) => {
|
|
// TODO: use db factories instead of seed data
|
|
})
|
|
|
|
When('I log out', logout)
|
|
|
|
When('I visit the {string} page', page => {
|
|
openPage(page)
|
|
})
|
|
Given('I am on the {string} page', page => {
|
|
openPage(page)
|
|
})
|
|
|
|
When('I fill in my email and password combination and click submit', () => {
|
|
login('admin@example.org', 1234)
|
|
})
|
|
|
|
When('I refresh the page', () => {
|
|
cy.reload()
|
|
})
|
|
|
|
When('I log out through the menu in the top right corner', () => {
|
|
cy.get('.avatar-menu').click()
|
|
cy.get('.avatar-menu-popover')
|
|
.find('a')
|
|
.contains('Logout')
|
|
.click()
|
|
})
|
|
|
|
Then('I can click on my profile picture in the top right corner', () => {
|
|
cy.get('.avatar-menu').click()
|
|
cy.get('.avatar-menu-popover')
|
|
})
|
|
|
|
Then('I can see my name {string} in the dropdown menu', () => {
|
|
cy.get('.avatar-menu-popover').should('contain', username)
|
|
})
|
|
|
|
Then('I see the login screen again', () => {
|
|
cy.location('pathname').should('contain', '/login')
|
|
cy.contains('If you already have a human-connection account, login here.')
|
|
})
|
|
|
|
Then('I am still logged in', () => {
|
|
cy.get('.avatar-menu').click()
|
|
cy.get('.avatar-menu-popover').contains(username)
|
|
})
|
|
|
|
When('I select {string} in the language menu', name => {
|
|
cy.get('.login-locale-switch a').click()
|
|
cy.contains('.locale-menu-popover a', name).click()
|
|
})
|
|
Then('the whole user interface appears in {string}', name => {
|
|
const lang = getLangByName(name)
|
|
cy.get(`html[lang=${lang.code}]`)
|
|
cy.contains('button', localeStrings.login[name])
|
|
cy.get(`html[lang=${getLangByName(name).code}]`).as('lang')
|
|
cy.getCookie('locale').should('have.property', 'value', lang.code)
|
|
})
|
|
|
|
When('I navigate to the administration dashboard', () => {
|
|
cy.get('.avatar-menu').click()
|
|
cy.get('.avatar-menu-popover')
|
|
.contains('Admin')
|
|
.click()
|
|
})
|
|
|
|
When('I click on {string}', linkOrButton => {
|
|
cy.contains(linkOrButton).click()
|
|
})
|
|
|
|
Then('I can see a list of categories ordered by post count:', table => {
|
|
// TODO: match the table in the feature with the html table
|
|
cy.get('thead').find('tr th').should('have.length', 3)
|
|
const last_column = cy.get('tbody').find('tr td:last-child').then((last_column) => {
|
|
cy.wrap(last_column)
|
|
const values = last_column.map((i, td) => parseInt(td.textContent)).toArray()
|
|
const ordered_descending = values.slice(0).sort((a,b) => b - a)
|
|
return cy.wrap(values).should('deep.eq', ordered_descending)
|
|
})
|
|
})
|
|
|
|
Then('I can see a list of tags ordered by user and post count:', table => {
|
|
// TODO: match the table in the feature with the html table
|
|
cy.get('thead').find('tr th').should('have.length', 4)
|
|
const last_column = cy.get('tbody').find('tr td:last-child').then((last_column) => {
|
|
cy.wrap(last_column)
|
|
const values = last_column.map((i, td) => parseInt(td.textContent)).toArray()
|
|
const ordered_descending = values.slice(0).sort((a,b) => b - a)
|
|
return cy.wrap(values).should('deep.eq', ordered_descending)
|
|
})
|
|
})
|