2024-04-15 23:00:35 +02:00
|
|
|
import NarratorCard from './NarratorCard.vue'
|
|
|
|
|
|
|
|
describe('<NarratorCard />', () => {
|
|
|
|
const narrator = {
|
|
|
|
name: 'John Doe',
|
|
|
|
numBooks: 5
|
|
|
|
}
|
|
|
|
const propsData = {
|
|
|
|
narrator,
|
|
|
|
width: 200,
|
|
|
|
height: 150,
|
|
|
|
sizeMultiplier: 1.2
|
|
|
|
}
|
|
|
|
const mocks = {
|
|
|
|
$store: {
|
|
|
|
getters: {
|
|
|
|
'user/getUserCanUpdate': true
|
|
|
|
},
|
|
|
|
state: {
|
|
|
|
libraries: {
|
|
|
|
currentLibraryId: 'library-123'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
$encode: (value) => value
|
|
|
|
}
|
|
|
|
|
|
|
|
it('renders the component', () => {
|
|
|
|
let mountOptions = { propsData, mocks }
|
|
|
|
// see: https://on.cypress.io/mounting-vue
|
|
|
|
cy.mount(NarratorCard, mountOptions)
|
|
|
|
})
|
|
|
|
|
|
|
|
it('renders the narrator name correctly', () => {
|
|
|
|
let mountOptions = { propsData, mocks }
|
|
|
|
cy.mount(NarratorCard, mountOptions)
|
|
|
|
|
2024-04-29 07:30:14 +02:00
|
|
|
cy.get('&name').should('have.text', 'John Doe')
|
2024-04-15 23:00:35 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
it('renders the number of books correctly', () => {
|
|
|
|
let mountOptions = { propsData, mocks }
|
|
|
|
cy.mount(NarratorCard, mountOptions)
|
|
|
|
|
2024-04-29 07:30:14 +02:00
|
|
|
cy.get('&numBooks').should('have.text', '5 Books')
|
2024-04-15 23:00:35 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
it('renders 1 book correctly', () => {
|
|
|
|
let propsData = { narrator: { name: 'John Doe', numBooks: 1 }, width: 200, height: 150, sizeMultiplier: 1.2 }
|
|
|
|
let mountOptions = { propsData, mocks }
|
|
|
|
cy.mount(NarratorCard, mountOptions)
|
|
|
|
|
2024-04-29 07:30:14 +02:00
|
|
|
cy.get('&numBooks').should('have.text', '1 Book')
|
2024-04-15 23:00:35 +02:00
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
it('renders the default name and num-books when narrator is not provided', () => {
|
|
|
|
let propsData = { width: 200, height: 150, sizeMultiplier: 1.2 }
|
|
|
|
let mountOptions = { propsData, mocks }
|
|
|
|
cy.mount(NarratorCard, mountOptions)
|
2024-04-29 07:30:14 +02:00
|
|
|
cy.get('&name').should('have.text', '')
|
|
|
|
cy.get('&numBooks').should('have.text', '0 Books')
|
2024-04-15 23:00:35 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
it('has the correct width and height', () => {
|
|
|
|
let mountOptions = { propsData, mocks }
|
|
|
|
cy.mount(NarratorCard, mountOptions)
|
2024-04-29 07:30:14 +02:00
|
|
|
cy.get('&card').should('have.css', 'width', '200px')
|
|
|
|
cy.get('&card').should('have.css', 'height', '150px')
|
2024-04-15 23:00:35 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
it('has the correct width and height when not provided', () => {
|
|
|
|
let propsData = { narrator, sizeMultiplier: 1.2 }
|
|
|
|
let mountOptions = { propsData, mocks }
|
|
|
|
cy.mount(NarratorCard, mountOptions)
|
2024-04-29 07:30:14 +02:00
|
|
|
cy.get('&card').should('have.css', 'width', '150px')
|
|
|
|
cy.get('&card').should('have.css', 'height', '100px')
|
2024-04-15 23:00:35 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
it ('has the correct font sizes', () => {
|
|
|
|
let mountOptions = { propsData, mocks }
|
|
|
|
cy.mount(NarratorCard, mountOptions)
|
2024-04-29 07:30:14 +02:00
|
|
|
cy.get('&name').should('have.css', 'font-size', '14.4px') // 0.75 * 1.2 * 16
|
|
|
|
cy.get('&numBooks').should('have.css', 'font-size', '12.48px') // 0.65 * 1.2 * 16
|
2024-04-15 23:00:35 +02:00
|
|
|
})
|
|
|
|
})
|