%PDF-1.5 %���� ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY
Server IP : 49.231.201.246 / Your IP : 216.73.216.41 Web Server : Apache/2.4.18 (Ubuntu) System : Linux 246 4.4.0-210-generic #242-Ubuntu SMP Fri Apr 16 09:57:56 UTC 2021 x86_64 User : root ( 0) PHP Version : 7.0.33-0ubuntu0.16.04.16 Disable Function : exec,passthru,shell_exec,system,proc_open,popen,pcntl_exec MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /var/www/html/ppaobm/vendor/bower-asset/sweetalert2/test/qunit/ |
Upload File : |
const { $, Swal, SwalWithoutAnimation, triggerKeydownEvent, isVisible, isHidden, TIMEOUT } = require('./helpers') const { toArray } = require('../../src/utils/utils') const { measureScrollbar } = require('../../src/utils/dom/measureScrollbar') const sinon = require('sinon/pkg/sinon') QUnit.test('version is correct semver', (assert) => { assert.ok(Swal.version.match(/\d+\.\d+\.\d+/)) }) QUnit.test('modal shows up', (assert) => { Swal('Hello world!') assert.ok(Swal.isVisible()) }) QUnit.test('modal scrolled to top on open', (assert) => { const done = assert.async() Swal({ imageUrl: 'https://placeholder.pics/svg/300x1500', imageHeight: 1500, imageAlt: 'A tall image', onOpen: () => { setTimeout(() => { assert.equal(Swal.getContainer().scrollTop, 0) done() }) } }) }) QUnit.test('should throw console warning about invalid params', (assert) => { const _consoleWarn = console.warn const spy = sinon.spy(console, 'warn') Swal({ invalidParam: 'oops' }) console.warn = _consoleWarn assert.ok(spy.calledWith('SweetAlert2: Unknown parameter "invalidParam"')) }) QUnit.test('should throw console error about unexpected params', (assert) => { const _consoleError = console.error const spy = sinon.spy(console, 'error') Swal('Hello world!', { type: 'success' }) console.error = _consoleError assert.ok(spy.calledWith('SweetAlert2: Unexpected type of html! Expected "string", got object')) }) QUnit.test('should not throw console error about undefined params and treat them as empty strings', (assert) => { const _consoleError = console.error const spy = sinon.spy(console, 'error') Swal(undefined, 'Hello world!', undefined) console.error = _consoleError assert.ok(spy.notCalled) }) QUnit.test('should not throw console error when <svg> tags are present (#1289)', (assert) => { const svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg') document.body.appendChild(svg) const _consoleError = console.error const spy = sinon.spy(console, 'error') Swal({}) console.error = _consoleError assert.ok(spy.notCalled) }) QUnit.test('should show the popup with OK button in case of empty object passed as an argument', (assert) => { Swal({}) assert.ok(isVisible(Swal.getConfirmButton())) assert.ok(isHidden(Swal.getCancelButton())) assert.equal(Swal.getTitle().textContent, '') assert.equal(Swal.getContent().textContent, '') assert.ok(isHidden(Swal.getFooter())) }) QUnit.test('the vertical scrollbar should be hidden and the according padding-right should be set', (assert) => { const talltDiv = document.createElement('div') talltDiv.innerHTML = Array(100).join('<div>lorem ipsum</div>') document.body.appendChild(talltDiv) document.body.style.paddingRight = '30px' const scrollbarWidth = measureScrollbar() Swal('The body has visible scrollbar, I will hide it and adjust padding-right on body') const bodyStyles = window.getComputedStyle(document.body); assert.equal(bodyStyles.paddingRight, (scrollbarWidth + 30) + 'px') assert.equal(bodyStyles.overflow, 'hidden') document.body.removeChild(talltDiv) }) QUnit.test('modal width', (assert) => { Swal({ text: '300px', width: 300 }) assert.equal($('.swal2-modal').style.width, '300px') Swal({ text: '400px', width: '400px' }) assert.equal($('.swal2-modal').style.width, '400px') Swal({ text: '90%', width: '90%' }) assert.equal($('.swal2-modal').style.width, '90%') }) QUnit.test('heightAuto', (assert) => { Swal('I should set .swal2-height-auto class to html and body') assert.ok(document.documentElement.classList.contains('swal2-height-auto')) Swal({ title: 'I am modeless and should not set .swal2-height-auto', backdrop: false }) assert.ok(document.documentElement.classList.contains('swal2-height-auto')) Swal({ title: 'I am toast and should not set .swal2-height-auto', toast: true }) assert.ok(document.documentElement.classList.contains('swal2-height-auto')) }) QUnit.test('custom class', (assert) => { Swal({ customClass: 'custom-class' }) assert.ok(Swal.getPopup().classList.contains('custom-class')) }) QUnit.test('custom container class', (assert) => { Swal({ customContainerClass: 'custom-class' }) assert.ok(Swal.getContainer().classList.contains('custom-class')) }) QUnit.test('getters', (assert) => { Swal('Title', 'Content') assert.equal(Swal.getTitle().innerText, 'Title') assert.equal(Swal.getContent().innerText.trim(), 'Content') Swal({ showCancelButton: true, imageUrl: '/assets/swal2-logo.png', confirmButtonText: 'Confirm button', confirmButtonAriaLabel: 'Confirm button aria-label', cancelButtonText: 'Cancel button', cancelButtonAriaLabel: 'Cancel button aria-label', footer: '<b>Footer</b>' }) assert.ok(Swal.getImage().src.indexOf('/assets/swal2-logo.png')) assert.equal(Swal.getActions().textContent, 'Confirm buttonCancel button') assert.equal(Swal.getConfirmButton().innerText, 'Confirm button') assert.equal(Swal.getCancelButton().innerText, 'Cancel button') assert.equal(Swal.getConfirmButton().getAttribute('aria-label'), 'Confirm button aria-label') assert.equal(Swal.getCancelButton().getAttribute('aria-label'), 'Cancel button aria-label') assert.equal(Swal.getFooter().innerHTML, '<b>Footer</b>') Swal({ input: 'text' }) $('.swal2-input').value = 'input text' assert.equal(Swal.getInput().value, 'input text') Swal({ input: 'radio', inputOptions: { 'one': 'one', 'two': 'two' } }) $('.swal2-radio input[value="two"]').setAttribute('checked', true) assert.equal(Swal.getInput().value, 'two') }) QUnit.test('custom buttons classes', (assert) => { Swal({ text: 'Modal with custom buttons classes', confirmButtonClass: 'btn btn-success ', cancelButtonClass: 'btn btn-warning ' }) assert.ok($('.swal2-confirm').classList.contains('btn')) assert.ok($('.swal2-confirm').classList.contains('btn-success')) assert.ok($('.swal2-cancel').classList.contains('btn')) assert.ok($('.swal2-cancel').classList.contains('btn-warning')) Swal('Modal with default buttons classes') assert.notOk($('.swal2-confirm').classList.contains('btn')) assert.notOk($('.swal2-confirm').classList.contains('btn-success')) assert.notOk($('.swal2-cancel').classList.contains('btn')) assert.notOk($('.swal2-cancel').classList.contains('btn-warning')) }) QUnit.test('content/title is set (html)', (assert) => { Swal({ title: '<strong>Strong</strong>, <em>Emphasis</em>', html: '<p>Paragraph</p><img /><button></button>' }) assert.equal($('.swal2-title').querySelectorAll('strong, em').length, 2) assert.equal($('.swal2-content').querySelectorAll('p, img, button').length, 3) }) QUnit.test('content/title is set (text)', (assert) => { Swal({ titleText: '<strong>Strong</strong>, <em>Emphasis</em>', text: '<p>Paragraph</p><img /><button></button>' }) assert.equal($('.swal2-title').innerHTML, '<strong>Strong</strong>, <em>Emphasis</em>') assert.equal($('#swal2-content').innerHTML, '<p>Paragraph</p><img /><button></button>') assert.equal($('.swal2-title').querySelectorAll('strong, em').length, 0) assert.equal($('.swal2-content').querySelectorAll('p, img, button').length, 0) }) QUnit.test('JS element as html param', (assert) => { const p = document.createElement('p') p.textContent = 'js element' Swal({ html: p }) assert.equal($('#swal2-content').innerHTML, '<p>js element</p>') }) QUnit.test('set and reset defaults', (assert) => { Swal.setDefaults({ confirmButtonText: 'Next >', showCancelButton: true }) Swal('Modal with changed defaults') assert.equal($('.swal2-confirm').textContent, 'Next >') assert.ok(isVisible($('.swal2-cancel'))) Swal.resetDefaults() Swal('Modal after resetting defaults') assert.equal($('.swal2-confirm').textContent, 'OK') assert.ok(isHidden($('.swal2-cancel'))) Swal.clickCancel() }) QUnit.test('validation message', (assert) => { const done = assert.async() const inputValidator = (value) => Promise.resolve(!value && 'no falsy values') SwalWithoutAnimation({ input: 'text', inputValidator }) assert.ok(isHidden(Swal.getValidationMessage())) setTimeout(() => { const initialModalHeight = $('.swal2-modal').offsetHeight Swal.clickConfirm() setTimeout(() => { assert.ok(isVisible(Swal.getValidationMessage())) assert.equal(Swal.getValidationMessage().textContent, 'no falsy values') assert.ok($('.swal2-input').getAttribute('aria-invalid')) assert.ok($('.swal2-modal').offsetHeight > initialModalHeight) $('.swal2-input').value = 'blah-blah' // setting the value programmatically will not trigger the 'input' event, // doing that manually const event = document.createEvent('Event') event.initEvent('input', true, true) $('.swal2-input').dispatchEvent(event) assert.ok(isHidden(Swal.getValidationMessage())) assert.notOk($('.swal2-input').getAttribute('aria-invalid')) assert.ok($('.swal2-modal').offsetHeight === initialModalHeight) done() }, TIMEOUT) }, TIMEOUT) }) QUnit.test('should throw console error about unexpected type of InputOptions', (assert) => { const _consoleError = console.error const spy = sinon.spy(console, 'error') Swal({ input: 'select', inputOptions: 'invalid-input-options' }) console.error = _consoleError assert.ok(spy.calledWith('SweetAlert2: Unexpected type of inputOptions! Expected object, Map or Promise, got string')) }) QUnit.test('queue', (assert) => { const done = assert.async() const steps = ['Step 1', 'Step 2'] assert.equal(Swal.getQueueStep(), null) SwalWithoutAnimation.queue(steps).then(() => { SwalWithoutAnimation('All done!') }) assert.equal($('.swal2-modal h2').textContent, 'Step 1') assert.equal(Swal.getQueueStep(), 0) SwalWithoutAnimation.clickConfirm() setTimeout(() => { assert.equal($('.swal2-modal h2').textContent, 'Step 2') assert.equal(Swal.getQueueStep(), 1) SwalWithoutAnimation.clickConfirm() setTimeout(() => { assert.equal($('.swal2-modal h2').textContent, 'All done!') assert.equal(SwalWithoutAnimation.getQueueStep(), null) SwalWithoutAnimation.clickConfirm() // test queue is cancelled on first step, other steps shouldn't be shown SwalWithoutAnimation.queue(steps) SwalWithoutAnimation.clickCancel() assert.notOk(SwalWithoutAnimation.isVisible()) done() }, TIMEOUT) }, TIMEOUT) }) QUnit.test('dymanic queue', (assert) => { const done = assert.async() const steps = [ { title: 'Step 1', preConfirm: () => { return new Promise((resolve) => { // insert to the end by default Swal.insertQueueStep('Step 3') // step to be deleted Swal.insertQueueStep('Step to be deleted') // insert with positioning Swal.insertQueueStep({ title: 'Step 2', preConfirm: () => { return new Promise((resolve) => { Swal.deleteQueueStep(3) resolve() }) } }, 1) resolve() }) } } ] Swal.setDefaults({ animation: false }) setTimeout(() => { Swal.queue(steps).then(() => { Swal('All done!') }) assert.equal($('.swal2-modal h2').textContent, 'Step 1') Swal.clickConfirm() setTimeout(() => { assert.equal($('.swal2-modal h2').textContent, 'Step 2') assert.equal(Swal.getQueueStep(), 1) Swal.clickConfirm() setTimeout(() => { assert.equal($('.swal2-modal h2').textContent, 'Step 3') assert.equal(Swal.getQueueStep(), 2) Swal.clickConfirm() setTimeout(() => { assert.equal($('.swal2-modal h2').textContent, 'All done!') assert.equal(Swal.getQueueStep(), null) Swal.clickConfirm() done() }, TIMEOUT) }, TIMEOUT) }, TIMEOUT) }, TIMEOUT) }) QUnit.test('showLoading and hideLoading', (assert) => { Swal.showLoading() assert.ok($('.swal2-actions').classList.contains('swal2-loading')) assert.ok($('.swal2-cancel').disabled) Swal.hideLoading() assert.notOk($('.swal2-actions').classList.contains('swal2-loading')) assert.notOk($('.swal2-cancel').disabled) Swal({ title: 'test loading state', showConfirmButton: false }) Swal.showLoading() assert.ok(isVisible($('.swal2-actions'))) assert.ok($('.swal2-actions').classList.contains('swal2-loading')) Swal.hideLoading() assert.notOk(isVisible($('.swal2-actions'))) assert.notOk($('.swal2-actions').classList.contains('swal2-loading')) }) QUnit.test('disable/enable buttons', (assert) => { Swal('test disable/enable buttons') Swal.disableButtons() assert.ok($('.swal2-confirm').disabled) assert.ok($('.swal2-cancel').disabled) Swal.enableButtons() assert.notOk($('.swal2-confirm').disabled) assert.notOk($('.swal2-cancel').disabled) Swal.disableConfirmButton() assert.ok($('.swal2-confirm').disabled) Swal.enableConfirmButton() assert.notOk($('.swal2-confirm').disabled) }) QUnit.test('disable/enable input', (assert) => { Swal('(disable/enable)Input should not fail if there is no input') Swal.disableInput() Swal.enableInput() Swal({ input: 'text' }) Swal.disableInput() assert.ok($('.swal2-input').disabled) Swal.enableInput() assert.notOk($('.swal2-input').disabled) Swal({ input: 'radio', inputOptions: { 'one': 'one', 'two': 'two' } }) Swal.disableInput() toArray($('.swal2-radio').querySelectorAll('radio')).forEach((radio) => { assert.ok(radio.disabled) }) Swal.enableInput() toArray($('.swal2-radio').querySelectorAll('radio')).forEach((radio) => { assert.notOk(radio.disabled) }) }) QUnit.test('reversed buttons', (assert) => { Swal({ text: 'Modal with reversed buttons', showCancelButton: true, reverseButtons: true }) assert.equal($('.swal2-confirm').previousSibling, $('.swal2-cancel')) Swal('Modal with buttons') assert.equal($('.swal2-cancel').previousSibling, $('.swal2-confirm')) }) QUnit.test('image alt text and custom class', (assert) => { Swal({ text: 'Custom class is set', imageUrl: '/assets/swal2-logo.png', imageAlt: 'Custom icon', imageClass: 'image-custom-class' }) assert.ok($('.swal2-image').classList.contains('image-custom-class')) assert.equal($('.swal2-image').getAttribute('alt'), 'Custom icon') Swal({ text: 'Custom class isn\'t set', imageUrl: '/assets/swal2-logo.png' }) assert.notOk($('.swal2-image').classList.contains('image-custom-class')) }) QUnit.test('modal vertical offset', (assert) => { const done = assert.async(1) // create a modal with dynamic-height content SwalWithoutAnimation({ imageUrl: '', title: 'Title', html: '<hr><div style="height: 50px"></div><p>Text content</p>', type: 'warning', input: 'text' }) // listen for image load $('.swal2-image').addEventListener('load', () => { const box = $('.swal2-modal').getBoundingClientRect() const delta = box.top - (box.bottom - box.height) // allow 1px difference, in case of uneven height assert.ok(Math.abs(delta) <= 1) done() }) }) QUnit.test('target', (assert) => { const warn = console.warn // Suppress the warnings console.warn = () => true // Suppress the warnings Swal('Default target') assert.equal(document.body, document.querySelector('.swal2-container').parentNode) Swal.close() const dummyTargetElement = Object.assign(document.createElement('div'), { id: 'dummy-target' }) document.body.appendChild(dummyTargetElement) Swal({ title: 'Custom valid target (string)', target: '#dummy-target' }) // switch targets assert.equal(document.querySelector('.swal2-container').parentNode, dummyTargetElement) Swal.close() Swal({ title: 'Custom invalid target (string)', target: 'lorem_ipsum' }) // switch targets assert.equal(document.querySelector('.swal2-container').parentNode, document.body) Swal.close() Swal({ title: 'Custom valid target (element)', target: dummyTargetElement }) assert.equal(document.querySelector('.swal2-container').parentNode, dummyTargetElement) Swal.close() Swal({ title: 'Custom invalid target (element)', target: true }) assert.equal(document.body, document.querySelector('.swal2-container').parentNode) Swal.close() console.warn = warn // Suppress the warnings }) QUnit.test('onOpen', (assert) => { const done = assert.async() // create a modal with an onOpen callback Swal({ title: 'onOpen test', onOpen: (modal) => { assert.equal($('.swal2-modal'), modal) done() } }) }) QUnit.test('onBeforeOpen', (assert) => { const done = assert.async() // create a modal with an onBeforeOpen callback Swal({ title: 'onBeforeOpen test', onBeforeOpen: (modal) => { assert.equal($('.swal2-modal'), modal) } }) // check that onBeforeOpen calls properly const dynamicTitle = 'Set onBeforeOpen title' Swal({ title: 'onBeforeOpen test', onBeforeOpen: () => { $('.swal2-title').innerHTML = dynamicTitle }, onOpen: () => { assert.equal($('.swal2-title').innerHTML, dynamicTitle) done() } }) }) QUnit.test('onAfterClose', (assert) => { const done = assert.async() let onCloseFinished = false // create a modal with an onAfterClose callback Swal({ title: 'onAfterClose test', onClose: () => { onCloseFinished = true }, onAfterClose: () => { assert.ok(onCloseFinished) assert.notOk($('.swal2-container')) done() } }) $('.swal2-close').click() }) QUnit.test('onClose', (assert) => { const done = assert.async() // create a modal with an onClose callback Swal({ title: 'onClose test', onClose: (_modal) => { assert.ok(modal, _modal) assert.ok($('.swal2-container')) done() } }) const modal = $('.swal2-modal') $('.swal2-close').click() }) QUnit.test('esc key', (assert) => { const done = assert.async() document.body.addEventListener('keydown', () => { throw new Error('Should not propagate keydown event to body!') }) SwalWithoutAnimation({ title: 'Esc me', onOpen: () => triggerKeydownEvent(Swal.getPopup(), 'Escape') }).then((result) => { assert.deepEqual(result, { dismiss: Swal.DismissReason.esc }) done() }) }) QUnit.test('allowEscapeKey as a function', (assert) => { const done = assert.async() let functionWasCalled = false SwalWithoutAnimation({ title: 'allowEscapeKey as a function', allowEscapeKey: () => { functionWasCalled = true return false }, onOpen: () => { assert.equal(functionWasCalled, false) triggerKeydownEvent(Swal.getPopup(), 'Escape') setTimeout(() => { assert.equal(functionWasCalled, true) assert.ok(Swal.isVisible()) done() }) } }) }) QUnit.test('close button', (assert) => { const done = assert.async() Swal({ title: 'Close button test', showCloseButton: true }).then((result) => { assert.deepEqual(result, { dismiss: Swal.DismissReason.close }) done() }) const closeButton = $('.swal2-close') assert.ok(isVisible(closeButton)) assert.equal(closeButton.getAttribute('aria-label'), 'Close this dialog') closeButton.click() }) QUnit.test('cancel button', (assert) => { const done = assert.async() Swal({ title: 'Cancel me' }).then((result) => { assert.deepEqual(result, { dismiss: Swal.DismissReason.cancel }) done() }) Swal.clickCancel() }) QUnit.test('timer', (assert) => { const done = assert.async() SwalWithoutAnimation({ title: 'Timer test', timer: 10 }).then((result) => { assert.deepEqual(result, { dismiss: Swal.DismissReason.timer }) done() }) }) QUnit.test('confirm button', (assert) => { const done = assert.async() Swal({ input: 'radio', inputOptions: { 'one': 'one', 'two': 'two' } }).then((result) => { assert.deepEqual(result, { value: 'two' }) done() }) $('.swal2-radio').querySelector('input[value="two"]').checked = true Swal.clickConfirm() }) QUnit.test('on errors in *async* user-defined functions, cleans up and propagates the error', (assert) => { const done = assert.async() const expectedError = new Error('my bad') const erroringFunction = () => { return Promise.reject(expectedError) } // inputValidator const rejectedPromise = Swal({ input: 'text', expectRejections: false, inputValidator: erroringFunction }) Swal.clickConfirm() rejectedPromise.catch((error) => { assert.equal(error, expectedError) // error is bubbled up back to user code setTimeout(() => { assert.notOk(Swal.isVisible()) // display is cleaned up // preConfirm const rejectedPromise = Swal({ expectRejections: false, preConfirm: erroringFunction }) Swal.clickConfirm() rejectedPromise.catch((error) => { assert.equal(error, expectedError) // error is bubbled up back to user code setTimeout(() => { assert.notOk(Swal.isVisible()) // display is cleaned up done() }) }) }) }) }) QUnit.test('params validation', (assert) => { assert.ok(Swal.isValidParameter('title')) assert.notOk(Swal.isValidParameter('foobar')) }) QUnit.test('addition and removal of backdrop', (assert) => { Swal({ backdrop: false }) assert.ok(document.body.classList.contains('swal2-no-backdrop')) assert.ok(document.documentElement.classList.contains('swal2-no-backdrop')) Swal({ title: 'test' }) assert.notOk(document.body.classList.contains('swal2-no-backdrop')) assert.notOk(document.documentElement.classList.contains('swal2-no-backdrop')) }) QUnit.test('footer', (assert) => { Swal({ title: 'Modal with footer', footer: 'I am footer' }) assert.ok(isVisible($('.swal2-footer'))) Swal('Modal w/o footer') assert.ok(isHidden($('.swal2-footer'))) }) QUnit.test('visual apperarance', (assert) => { Swal({ padding: '2em', background: 'red', confirmButtonColor: 'green', cancelButtonColor: 'blue' }) assert.equal(Swal.getPopup().style.padding, '2em') assert.equal(window.getComputedStyle(Swal.getPopup()).backgroundColor, 'rgb(255, 0, 0)') assert.equal(Swal.getConfirmButton().style.backgroundColor, 'green') assert.equal(Swal.getCancelButton().style.backgroundColor, 'blue') }) QUnit.test('null values', (assert) => { const defaultParams = require('../../src/utils/params').default const params = {} Object.keys(defaultParams).forEach(key => { params[key] = null }) Swal(params) assert.ok(Swal.isVisible()) }) QUnit.test('backdrop accepts css background param', (assert) => { let backdrop = 'rgb(123, 123, 123)' Swal({ title: 'I have no backdrop', backdrop: false }) assert.notOk($('.swal2-container').style.background) Swal({ title: 'I have a custom backdrop', backdrop: backdrop }) assert.ok($('.swal2-container').style.background.includes(backdrop)) }) QUnit.test('preConfirm return false', (assert) => { SwalWithoutAnimation({ preConfirm: () => { return false } }) Swal.clickConfirm() assert.ok(Swal.isVisible()) }) QUnit.test('animation param evaluates a function', (assert) => { Swal({ animation: () => false }) assert.ok($('.swal2-popup').classList.contains('swal2-noanimation')) Swal({ animation: () => true }) assert.notOk($('.swal2-popup').classList.contains('swal2-noanimation')) }) QUnit.test('Custom content', (assert) => { const done = assert.async() Swal({ showCancelButton: true, onOpen: () => { Swal.getContent().textContent = 'Custom content' Swal.clickConfirm() }, preConfirm: () => { return 'Some data from custom control' } }).then(result => { assert.ok(result.value) done() }) })