'use strict'; const assert = require( 'assert' ), EditPage = require( '../pageobjects/edit.page' ), FixtureContent = require( '../fixturecontent' ), LoginPage = require( 'wdio-mediawiki/LoginPage' ), UserPreferences = require( '../userpreferences' ), Util = require( 'wdio-mediawiki/Util' ); describe( 'CodeMirror textSelection for the wikitext 2010 editor', () => { let title; before( async () => { title = Util.getTestString( 'CodeMirror-fixture1-' ); await LoginPage.loginAdmin(); await FixtureContent.createFixturePage( title ); await UserPreferences.enableWikitext2010EditorWithCodeMirror(); await EditPage.openForEditing( title ); await EditPage.wikiEditorToolbar.waitForDisplayed(); await EditPage.clickText(); } ); // Content is "[]{{template}}" it( 'sets and gets the correct text when using setContents and getContents', async () => { await browser.execute( () => $( '.cm-editor' ).textSelection( 'setContents', 'foobar' ) ); assert.strictEqual( await browser.execute( () => $( '.cm-editor' ).textSelection( 'getContents' ) ), 'foobar' ); } ); // Content is now "foobar" it( 'sets and gets the correct selection when using setSelection and getSelection', async () => { await browser.execute( () => { $( '.cm-editor' ).textSelection( 'setSelection', { start: 3, end: 6 } ); } ); assert.strictEqual( await browser.execute( () => $( '.cm-editor' ).textSelection( 'getSelection' ) ), 'bar' ); } ); it( 'correctly replaces the selected text when using replaceSelection', async () => { await browser.execute( () => $( '.cm-editor' ).textSelection( 'replaceSelection', 'baz' ) ); assert.strictEqual( await browser.execute( () => $( '.cm-editor' ).textSelection( 'getContents' ) ), 'foobaz' ); } ); // Content is now "foobaz" it( 'returns the correct values for getCaretPosition', async () => { await browser.execute( () => { $( '.cm-editor' ).textSelection( 'setSelection', { start: 3, end: 6 } ); } ); assert.strictEqual( await browser.execute( () => $( '.cm-editor' ).textSelection( 'getCaretPosition' ) ), 6 ); assert.deepStrictEqual( await browser.execute( () => $( '.cm-editor' ).textSelection( 'getCaretPosition', { startAndEnd: true } ) ), [ 3, 6 ] ); } ); it( 'correctly wraps the selected text when using encapsulateSelection', async () => { await browser.execute( () => { $( '.cm-editor' ).textSelection( 'setContents', 'foobaz' ) .textSelection( 'encapsulateSelection', { selectionStart: 0, selectionEnd: 6, pre: '