|
| 1 | +/** |
| 2 | + * External dependencies |
| 3 | + */ |
| 4 | +import { expect } from 'chai'; |
| 5 | + |
| 6 | +/** |
| 7 | + * Internal dependencies |
| 8 | + */ |
| 9 | +import accept from '../'; |
| 10 | + |
| 11 | +describe( '#accept()', () => { |
| 12 | + beforeEach( () => { |
| 13 | + document.body.innerHTML = ''; |
| 14 | + } ); |
| 15 | + |
| 16 | + it( 'should render a dialog to the document body', () => { |
| 17 | + const message = 'Are you sure?'; |
| 18 | + |
| 19 | + accept( message, () => {} ); |
| 20 | + |
| 21 | + const dialog = document.querySelector( '.utils-accept__dialog-content' ); |
| 22 | + expect( dialog ).to.be.an.instanceof( window.Element ); |
| 23 | + expect( dialog.textContent ).to.equal( message ); |
| 24 | + } ); |
| 25 | + |
| 26 | + it( 'should trigger the callback with an accepted prompt', ( done ) => { |
| 27 | + accept( 'Are you sure?', ( accepted ) => { |
| 28 | + expect( accepted ).to.be.be.true(); |
| 29 | + done(); |
| 30 | + } ); |
| 31 | + |
| 32 | + document.querySelector( '.components-button.button-primary' ).click(); |
| 33 | + } ); |
| 34 | + |
| 35 | + it( 'should trigger the callback with a denied prompt', ( done ) => { |
| 36 | + accept( 'Are you sure?', ( accepted ) => { |
| 37 | + expect( accepted ).to.be.be.false(); |
| 38 | + done(); |
| 39 | + } ); |
| 40 | + |
| 41 | + document.querySelector( '.components-button:not( .button-primary )' ).click(); |
| 42 | + } ); |
| 43 | + |
| 44 | + it( 'should clean up after itself once the prompt is closed', ( done ) => { |
| 45 | + accept( 'Are you sure?', () => { |
| 46 | + process.nextTick( () => { |
| 47 | + expect( document.querySelector( '.utils-accept__dialog' ) ).to.be.null(); |
| 48 | + |
| 49 | + done(); |
| 50 | + } ); |
| 51 | + } ); |
| 52 | + |
| 53 | + document.querySelector( '.components-button.button-primary' ).click(); |
| 54 | + } ); |
| 55 | +} ); |
0 commit comments