This repository has been archived by the owner on Feb 8, 2024. It is now read-only.
/
sidebar.spec.js
51 lines (44 loc) · 1.78 KB
/
sidebar.spec.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
/// <reference types="cypress" />
describe('Sidebar', () => {
const sidebarSelector = '[data-test=sidebar] [data-test=sidebar-entry]'
const toggleSidebarSelector = '[data-test=sidebar-button-toggle]'
it('can be toggled on a laptop', () => {
cy.viewport('macbook-15')
cy.visit('/course/ch-prerequisites')
cy.get(sidebarSelector).should('be.visible')
cy.get(toggleSidebarSelector).click()
cy.get(sidebarSelector).should('be.not.visible')
cy.get(toggleSidebarSelector).click()
cy.get(sidebarSelector).should('be.visible')
})
it('can be toggled on a tablet', () => {
cy.viewport('ipad-2')
cy.visit('/course/ch-prerequisites')
cy.get(sidebarSelector).should('be.not.visible')
cy.get(toggleSidebarSelector).click()
cy.get(sidebarSelector).should('be.visible')
cy.get(toggleSidebarSelector).click()
cy.get(sidebarSelector).should('be.not.visible')
})
it('can be toggled on a smartphone', () => {
const showMobileSidebarSelector = '[data-test=sidebar-button-toggle-mobile]'
cy.viewport('iphone-x')
cy.visit('/course/ch-prerequisites')
cy.get(sidebarSelector).should('be.not.visible')
cy.get(showMobileSidebarSelector).click()
cy.get(sidebarSelector).should('be.visible')
cy.get(toggleSidebarSelector).click()
cy.get(sidebarSelector).should('be.not.visible')
})
it('back to home link links to textbook home', () => {
const viewports = ['ipad-2', 'macbook-15']
const linkSelector = '[data-test=back-to-home-link]'
const textbookHomeUrl = 'https://qiskit.org/learn'
viewports.forEach((viewport) => {
cy.viewport(viewport)
cy.visit('/course/ch-prerequisites')
cy.get(linkSelector).should('be.visible')
cy.get(linkSelector).should('have.attr', 'href', textbookHomeUrl)
})
})
})