@glidejs/glide
Version:
Glide.js is a dependency-free JavaScript ES6 slider and carousel. It’s lightweight, flexible and fast. Designed to slide. No less, no more
84 lines (55 loc) • 2.5 kB
JavaScript
import html from '../fixtures/html'
import { query } from '../fixtures/query'
import { afterTransition } from '../fixtures/transition'
import defaults from '../../src/defaults'
import Glide from '../../entry/entry-complete'
describe('Class', () => {
beforeEach(() => {
document.body.innerHTML = html
})
test('`classes.slider` should be applied on the root element', () => {
let { root } = query(document)
new Glide('#glide').mount()
expect(root.classList.contains(defaults.classes.slider)).toBe(true)
})
test('`classes.carousel` should be applied on the root element', () => {
let { root } = query(document)
new Glide('#glide', { type: 'carousel' }).mount()
expect(root.classList.contains(defaults.classes.carousel)).toBe(true)
})
test('`classes.activeSlide` should be applied on the 0 indexed slide element by default', () => {
let { slides } = query(document)
new Glide('#glide').mount()
expect(slides[0].classList.contains(defaults.classes.activeSlide)).toBe(true)
})
test('`classes.activeSlide` should be applied on the `startAt` indexed slide element', () => {
let { slides } = query(document)
new Glide('#glide', { startAt: 2 }).mount()
expect(slides[2].classList.contains(defaults.classes.activeSlide)).toBe(true)
})
test('`classes.activeSlide` should be applied to the new slide element after moving', (done) => {
let { slides } = query(document)
let glide = new Glide('#glide', { startAt: 0 }).mount()
glide.go('>')
afterTransition(() => {
expect(slides[0].classList.contains(defaults.classes.activeSlide)).toBe(false)
expect(slides[1].classList.contains(defaults.classes.activeSlide)).toBe(true)
done()
})
})
test('`classes.swipeable` should be applied on the root element', () => {
let { root } = query(document)
new Glide('#glide').mount()
expect(root.classList.contains(defaults.classes.swipeable)).toBe(true)
})
test('`classes.direction.ltr` should be applied on the root element in `ltr` mode', () => {
let { root } = query(document)
new Glide('#glide').mount()
expect(root.classList.contains(defaults.classes.direction.ltr)).toBe(true)
})
test('`classes.direction.rtl` should be applied on the root element in `rtl` mode', () => {
let { root } = query(document)
new Glide('#glide', { direction: 'rtl' }).mount()
expect(root.classList.contains(defaults.classes.direction.rtl)).toBe(true)
})
})