carbon/cypress/integration/localStorage.spec.js

49 lines
1.1 KiB
JavaScript

/* global cy */
import { editorVisible } from '../support'
// usually we can visit the page before each test
// but these tests use the url, which means wasted page load
// so instead visit the desired url in each test
describe('localStorage', () => {
const themeDropdown = () => cy.get('.toolbar .dropdown-container').first()
const pickTheme = (name = 'Blackboard') =>
themeDropdown()
.click()
.contains(name)
.click()
it.skip('is empty initially', () => {
cy.visit('/')
editorVisible()
cy.window()
.its('localStorage')
.should('have.length', 0)
})
it('saves on theme change', () => {
cy.visit('/')
editorVisible()
pickTheme('Blackboard')
themeDropdown()
.click()
.contains('Blackboard')
cy.wait(1500) // URL updates are debounced
cy.window()
.its('localStorage.CARBON_STATE')
.then(JSON.parse)
.its('theme')
.should('equal', 'blackboard')
// visiting page again restores theme from localStorage
cy.visit('/')
pickTheme('Cobalt')
cy.wait(1500) // URL updates are debounced
cy.url().should('contain', 't=cobalt')
})
})