import ClassicEditor from '@ckeditor/ckeditor5-editor-classic/src/classiceditor';
import { getData as getModelData, setData as setModelData } from '@ckeditor/ckeditor5-engine/src/dev-utils/model';
import { Paragraph } from '@ckeditor/ckeditor5-paragraph';
import MermaidPreviewCommand from '../../src/commands/mermaidPreviewCommand';
import MermaidEditing from '../../src/mermaidediting';
/* global document */
describe( 'MermaidPreviewCommand', () => {
	let domElement, editor, model, command;
	beforeEach( async () => {
		domElement = document.createElement( 'div' );
		document.body.appendChild( domElement );
		editor = await ClassicEditor.create( domElement, {
			plugins: [
				MermaidEditing,
				Paragraph
			]
		} );
		model = editor.model;
		command = new MermaidPreviewCommand( editor );
	} );
	afterEach( () => {
		domElement.remove();
		return editor.destroy();
	} );
	describe( '#value', () => {
		it( 'should be true when mermaid element has displayMode attribute equal to "preview"', () => {
			setModelData( model, '' );
			expect( command.value ).to.equal( true );
		} );
		it( 'should be false when mermaid element has displayMode attribute equal to "split"', () => {
			setModelData( model, '' );
			expect( command.value ).to.equal( false );
		} );
		it( 'should be false when mermaid element has displayMode attribute equal to "source"', () => {
			setModelData( model, '' );
			expect( command.value ).to.equal( false );
		} );
	} );
	describe( '#isEnabled', () => {
		describe( 'should be false', () => {
			it( 'when text is selected', () => {
				setModelData( model,
					'[foo]' +
					''
				);
				expect( command.isEnabled ).to.be.false;
			} );
			it( 'when mermaid is part of the selection', () => {
				setModelData( model,
					'[foo' +
					'' +
					'b]az'
				);
				expect( command.isEnabled ).to.be.false;
			} );
		} );
		describe( 'should be true', () => {
			it( 'when selection is inside mermaid', () => {
				setModelData( model,
					'foo' +
					'[]'
				);
				expect( command.isEnabled ).to.be.true;
			} );
			it( 'when mermaid is selected', () => {
				setModelData( model,
					'foo' +
					'[]'
				);
				expect( command.isEnabled ).to.be.true;
			} );
		} );
	} );
	describe( 'execute()', () => {
		it( 'should change displayMode to "preview" for mermaid', () => {
			setModelData( model,
				'[]'
			);
			command.execute();
			expect( getModelData( model ) ).to.equal(
				'[]'
			);
		} );
	} );
} );