File "general.test.ts"

Full path: /home/fsibplc/public_html/sommilito-bank2/splide-4.1.3/src/js/components/Clones/test/general.test.ts
File size: 2.4 B (2.4 KB bytes)
MIME-type: text/x-java
Charset: utf-8

Download   Open   Edit   Advanced Editor   Back

import { CLASS_CLONE } from '../../../constants/classes';
import { init } from '../../../test';
import { MULTIPLIER } from '../Clones';


describe( 'Clones', () => {
  // This test must be the first because of uniqueId().
  test( 'can generate clones with unique IDs.', () => {
    const splide = init( { type: 'loop', perPage: 3 } );
    const clones = splide.root.getElementsByClassName( CLASS_CLONE );

    expect( clones[ 0 ].id ).toBe( 'splide01-clone01' );
    expect( clones[ 1 ].id ).toBe( 'splide01-clone02' );
    expect( clones[ 2 ].id ).toBe( 'splide01-clone03' );
  } );

  test( 'can generate clones.', () => {
    const splide = init( { type: 'loop', perPage: 3 } );
    const clones = splide.root.getElementsByClassName( CLASS_CLONE );
    const Slides = splide.Components.Slides.get( true );
    const count  = clones.length / 2; // each side.

    expect( count ).toBe( splide.options.perPage * MULTIPLIER );
    expect( clones[ count - 1 ].nextElementSibling ).toBe( Slides[ 0 ].slide );
    expect( clones[ count ].previousElementSibling ).toBe( Slides[ Slides.length - 1 ].slide );
  } );

  test( 'can generate clones according to the perPage option.', () => {
    const splide = init( { type: 'loop', perPage: 3 } );
    const clones = splide.root.getElementsByClassName( CLASS_CLONE );
    const { perPage } = splide.options;

    expect( clones.length / 2 ).toBe( perPage * MULTIPLIER );
  } );

  test( 'should register clones to Slides component.', () => {
    const splide      = init( { type: 'loop' } );
    const clones      = splide.root.getElementsByClassName( CLASS_CLONE );
    const Slides      = splide.Components.Slides.get();
    const cloneSlides = Slides.filter( Slide => Slide.isClone );

    expect( clones.length ).toBe( cloneSlides.length );
  } );

  test( 'should assign indices.', () => {
    const splide       = init( { type: 'loop' } );
    const Slides       = splide.Components.Slides.get();
    const cloneSlides  = Slides.filter( Slide => Slide.isClone );
    const clonesBefore = cloneSlides.filter( ( Slide, index ) => index < cloneSlides.length / 2 );
    const clonesAfter  = cloneSlides.filter( ( Slide, index ) => index >= cloneSlides.length / 2 );

    clonesBefore.forEach( ( Slide, index ) => {
      expect( Slide.index ).toBe( index - clonesBefore.length );
    } );

    clonesAfter.forEach( ( Slide, index ) => {
      expect( Slide.index ).toBe( splide.length + index );
    } );
  } );
} );