From 48a810d40a3515bf79262ecbda3618f6ff0bb2e3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tomek=20Wytr=C4=99bowicz?= Date: Fri, 17 Apr 2020 09:41:06 +0200 Subject: [PATCH] Other: Remove `env.isEdge`. Closes ckeditor/ckeditor5#6202. Remove some special cases for Edge, as since it's Chromium-based now, it behaves closer to others. --- src/imageupload/imageuploadprogress.js | 4 +-- tests/image.js | 4 --- tests/image/converters.js | 4 --- tests/image/imageediting.js | 4 --- tests/imagecaption/imagecaptionediting.js | 4 --- tests/imagestyle/imagestyleediting.js | 6 ---- .../ui/textalternativeformview.js | 3 -- tests/imagetoolbar.js | 4 --- tests/imageupload/imageuploadediting.js | 26 ++-------------- tests/imageupload/imageuploadprogress.js | 31 ------------------- tests/integration.js | 4 --- 11 files changed, 4 insertions(+), 90 deletions(-) diff --git a/src/imageupload/imageuploadprogress.js b/src/imageupload/imageuploadprogress.js index 1d6976ab..5a1ef306 100644 --- a/src/imageupload/imageuploadprogress.js +++ b/src/imageupload/imageuploadprogress.js @@ -12,7 +12,6 @@ import Plugin from '@ckeditor/ckeditor5-core/src/plugin'; import FileRepository from '@ckeditor/ckeditor5-upload/src/filerepository'; import uploadingPlaceholder from '../../theme/icons/image_placeholder.svg'; -import env from '@ckeditor/ckeditor5-utils/src/env'; import { getViewImgFromWidget } from '../image/utils'; import '../../theme/imageuploadprogress.css'; @@ -104,8 +103,7 @@ export default class ImageUploadProgress extends Plugin { return; } - // Because in Edge there is no way to show fancy animation of completeIcon we need to skip it. - if ( status == 'complete' && fileRepository.loaders.get( uploadId ) && !env.isEdge ) { + if ( status == 'complete' && fileRepository.loaders.get( uploadId ) ) { _showCompleteIcon( viewFigure, viewWriter, editor.editing.view ); } diff --git a/tests/image.js b/tests/image.js index 3fda9179..7f9780b0 100644 --- a/tests/image.js +++ b/tests/image.js @@ -11,7 +11,6 @@ import ImageTextAlternative from '../src/imagetextalternative'; import { setData as setModelData } from '@ckeditor/ckeditor5-engine/src/dev-utils/model'; import { getData as getViewData } from '@ckeditor/ckeditor5-engine/src/dev-utils/view'; import global from '@ckeditor/ckeditor5-utils/src/dom/global'; -import env from '@ckeditor/ckeditor5-utils/src/env'; import testUtils from '@ckeditor/ckeditor5-core/tests/_utils/utils'; describe( 'Image', () => { @@ -20,9 +19,6 @@ describe( 'Image', () => { testUtils.createSinonSandbox(); beforeEach( () => { - // Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`. - testUtils.sinon.stub( env, 'isEdge' ).get( () => false ); - editorElement = global.document.createElement( 'div' ); global.document.body.appendChild( editorElement ); diff --git a/tests/image/converters.js b/tests/image/converters.js index 96f7a92d..e24deb8f 100644 --- a/tests/image/converters.js +++ b/tests/image/converters.js @@ -13,7 +13,6 @@ import VirtualTestEditor from '@ckeditor/ckeditor5-core/tests/_utils/virtualtest import { getData as getViewData } from '@ckeditor/ckeditor5-engine/src/dev-utils/view'; import { setData as setModelData, getData as getModelData } from '@ckeditor/ckeditor5-engine/src/dev-utils/model'; -import env from '@ckeditor/ckeditor5-utils/src/env'; import testUtils from '@ckeditor/ckeditor5-core/tests/_utils/utils'; describe( 'Image converters', () => { @@ -22,9 +21,6 @@ describe( 'Image converters', () => { testUtils.createSinonSandbox(); beforeEach( () => { - // Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`. - testUtils.sinon.stub( env, 'isEdge' ).get( () => false ); - return VirtualTestEditor.create() .then( newEditor => { editor = newEditor; diff --git a/tests/image/imageediting.js b/tests/image/imageediting.js index f518845c..a9eabda1 100644 --- a/tests/image/imageediting.js +++ b/tests/image/imageediting.js @@ -14,7 +14,6 @@ import { getData as getModelData, setData as setModelData } from '@ckeditor/cked import { getData as getViewData } from '@ckeditor/ckeditor5-engine/src/dev-utils/view'; import { isImageWidget } from '../../src/image/utils'; import normalizeHtml from '@ckeditor/ckeditor5-utils/tests/_utils/normalizehtml'; -import env from '@ckeditor/ckeditor5-utils/src/env'; import testUtils from '@ckeditor/ckeditor5-core/tests/_utils/utils'; describe( 'ImageEditing', () => { @@ -23,9 +22,6 @@ describe( 'ImageEditing', () => { testUtils.createSinonSandbox(); beforeEach( () => { - // Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`. - testUtils.sinon.stub( env, 'isEdge' ).get( () => false ); - return VirtualTestEditor .create( { plugins: [ ImageEditing ] diff --git a/tests/imagecaption/imagecaptionediting.js b/tests/imagecaption/imagecaptionediting.js index 65cbc32b..a54997d3 100644 --- a/tests/imagecaption/imagecaptionediting.js +++ b/tests/imagecaption/imagecaptionediting.js @@ -13,7 +13,6 @@ import Paragraph from '@ckeditor/ckeditor5-paragraph/src/paragraph'; import { getData as getModelData, setData as setModelData } from '@ckeditor/ckeditor5-engine/src/dev-utils/model'; import { getData as getViewData } from '@ckeditor/ckeditor5-engine/src/dev-utils/view'; -import env from '@ckeditor/ckeditor5-utils/src/env'; import testUtils from '@ckeditor/ckeditor5-core/tests/_utils/utils'; describe( 'ImageCaptionEditing', () => { @@ -22,9 +21,6 @@ describe( 'ImageCaptionEditing', () => { testUtils.createSinonSandbox(); beforeEach( () => { - // Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`. - testUtils.sinon.stub( env, 'isEdge' ).get( () => false ); - return VirtualTestEditor .create( { plugins: [ ImageCaptionEditing, ImageEditing, UndoEditing, Paragraph ] diff --git a/tests/imagestyle/imagestyleediting.js b/tests/imagestyle/imagestyleediting.js index 7442e600..cf7b4ef5 100644 --- a/tests/imagestyle/imagestyleediting.js +++ b/tests/imagestyle/imagestyleediting.js @@ -12,18 +12,12 @@ import { getData as getModelData, setData as setModelData } from '@ckeditor/cked import { getData as getViewData } from '@ckeditor/ckeditor5-engine/src/dev-utils/view'; import testUtils from '@ckeditor/ckeditor5-core/tests/_utils/utils'; -import env from '@ckeditor/ckeditor5-utils/src/env'; describe( 'ImageStyleEditing', () => { let editor, model, document, viewDocument; testUtils.createSinonSandbox( 'ImageStyleEditing' ); - beforeEach( () => { - // Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`. - testUtils.sinon.stub( env, 'isEdge' ).get( () => false ); - } ); - afterEach( () => { editor.destroy(); } ); diff --git a/tests/imagetextalternative/ui/textalternativeformview.js b/tests/imagetextalternative/ui/textalternativeformview.js index d2fcda2c..6d1993a5 100644 --- a/tests/imagetextalternative/ui/textalternativeformview.js +++ b/tests/imagetextalternative/ui/textalternativeformview.js @@ -13,7 +13,6 @@ import FocusTracker from '@ckeditor/ckeditor5-utils/src/focustracker'; import FocusCycler from '@ckeditor/ckeditor5-ui/src/focuscycler'; import ViewCollection from '@ckeditor/ckeditor5-ui/src/viewcollection'; import testUtils from '@ckeditor/ckeditor5-core/tests/_utils/utils'; -import env from '@ckeditor/ckeditor5-utils/src/env'; describe( 'TextAlternativeFormView', () => { let view; @@ -21,8 +20,6 @@ describe( 'TextAlternativeFormView', () => { testUtils.createSinonSandbox(); beforeEach( () => { - testUtils.sinon.stub( env, 'isEdge' ).get( () => false ); - view = new TextAlternativeFormView( { t: () => {} } ); } ); diff --git a/tests/imagetoolbar.js b/tests/imagetoolbar.js index 38ac4e82..54209000 100644 --- a/tests/imagetoolbar.js +++ b/tests/imagetoolbar.js @@ -14,7 +14,6 @@ import ButtonView from '@ckeditor/ckeditor5-ui/src/button/buttonview'; import Paragraph from '@ckeditor/ckeditor5-paragraph/src/paragraph'; import View from '@ckeditor/ckeditor5-ui/src/view'; import { setData } from '@ckeditor/ckeditor5-engine/src/dev-utils/model'; -import env from '@ckeditor/ckeditor5-utils/src/env'; import testUtils from '@ckeditor/ckeditor5-core/tests/_utils/utils'; describe( 'ImageToolbar', () => { @@ -23,9 +22,6 @@ describe( 'ImageToolbar', () => { testUtils.createSinonSandbox(); beforeEach( () => { - // Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`. - testUtils.sinon.stub( env, 'isEdge' ).get( () => false ); - editorElement = global.document.createElement( 'div' ); global.document.body.appendChild( editorElement ); diff --git a/tests/imageupload/imageuploadediting.js b/tests/imageupload/imageuploadediting.js index 097e10f5..8a38c83f 100644 --- a/tests/imageupload/imageuploadediting.js +++ b/tests/imageupload/imageuploadediting.js @@ -23,13 +23,11 @@ import { UploadAdapterMock, createNativeFileMock, NativeFileReaderMock } from '@ import { setData as setModelData, getData as getModelData } from '@ckeditor/ckeditor5-engine/src/dev-utils/model'; import { getData as getViewData, stringify as stringifyView } from '@ckeditor/ckeditor5-engine/src/dev-utils/view'; -import env from '@ckeditor/ckeditor5-utils/src/env'; import Notification from '@ckeditor/ckeditor5-ui/src/notification/notification'; describe( 'ImageUploadEditing', () => { // eslint-disable-next-line max-len const base64Sample = ''; - const isEdgeEnv = env.isEdge; let adapterMocks = []; let editor, model, view, doc, fileRepository, viewDocument, nativeReaderMock, loader; @@ -49,15 +47,6 @@ describe( 'ImageUploadEditing', () => { } beforeEach( () => { - if ( isEdgeEnv ) { - sinon.stub( window, 'File' ).callsFake( () => { - return { name: 'file.jpg' }; - } ); - } - - // Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`. - sinon.stub( env, 'isEdge' ).get( () => false ); - sinon.stub( window, 'FileReader' ).callsFake( () => { nativeReaderMock = new NativeFileReaderMock(); @@ -816,14 +805,7 @@ describe( 'ImageUploadEditing', () => { } ); it( 'should not upload and remove image when `File` constructor is not supported', done => { - if ( isEdgeEnv ) { - // Since on Edge `File` is already stubbed, restore it to it native form so that exception will be thrown. - sinon.restore(); - // Since all stubs were restored, re-stub `scrollToTheSelection`. - sinon.stub( editor.editing.view, 'scrollToTheSelection' ).callsFake( () => {} ); - } else { - sinon.stub( window, 'File' ).throws( 'Function expected.' ); - } + sinon.stub( window, 'File' ).throws( 'Function expected.' ); const notification = editor.plugins.get( Notification ); @@ -857,8 +839,7 @@ describe( 'ImageUploadEditing', () => { ); } ); - // Skip this test on Edge as we mock `File` object there so there is no sense in testing it. - ( isEdgeEnv ? it.skip : it )( 'should get file extension from base64 string', done => { + it( 'should get file extension from base64 string', done => { setModelData( model, '[]foo' ); const clipboardHtml = ``; @@ -883,8 +864,7 @@ describe( 'ImageUploadEditing', () => { } ); } ); - // Skip this test on Edge as we mock `File` object there so there is no sense in testing it. - ( isEdgeEnv ? it.skip : it )( 'should use fallback file extension', done => { + it( 'should use fallback file extension', done => { setModelData( model, '[]foo' ); const clipboardHtml = ``; diff --git a/tests/imageupload/imageuploadprogress.js b/tests/imageupload/imageuploadprogress.js index 9db02f34..9f1b0d90 100644 --- a/tests/imageupload/imageuploadprogress.js +++ b/tests/imageupload/imageuploadprogress.js @@ -20,7 +20,6 @@ import { setData as setModelData } from '@ckeditor/ckeditor5-engine/src/dev-util import { getData as getViewData } from '@ckeditor/ckeditor5-engine/src/dev-utils/view'; import testUtils from '@ckeditor/ckeditor5-core/tests/_utils/utils'; import svgPlaceholder from '../../theme/icons/image_placeholder.svg'; -import env from '@ckeditor/ckeditor5-utils/src/env'; describe( 'ImageUploadProgress', () => { const imagePlaceholder = encodeURIComponent( svgPlaceholder ); @@ -44,9 +43,6 @@ describe( 'ImageUploadProgress', () => { testUtils.createSinonSandbox(); beforeEach( () => { - // Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`. - testUtils.sinon.stub( env, 'isEdge' ).get( () => false ); - testUtils.sinon.stub( window, 'FileReader' ).callsFake( () => { nativeReaderMock = new NativeFileReaderMock(); @@ -333,31 +329,4 @@ describe( 'ImageUploadProgress', () => { ']' ); } ); - - it( 'should not create completeIcon element when browser is Microsoft Edge', done => { - testUtils.sinon.stub( env, 'isEdge' ).get( () => true ); - - setModelData( model, '[]foo' ); - editor.execute( 'imageUpload', { file: createNativeFileMock() } ); - - model.document.once( 'change', () => { - model.document.once( 'change', () => { - try { - expect( getViewData( view ) ).to.equal( - '[
' + - '' + - '
]

foo

' - ); - - done(); - } catch ( err ) { - done( err ); - } - }, { priority: 'lowest' } ); - - loader.file.then( () => adapterMock.mockSuccess( { default: 'image.png' } ) ); - } ); - - loader.file.then( () => nativeReaderMock.mockSuccess( base64Sample ) ); - } ); } ); diff --git a/tests/integration.js b/tests/integration.js index 58736424..6c5825d4 100644 --- a/tests/integration.js +++ b/tests/integration.js @@ -11,7 +11,6 @@ import global from '@ckeditor/ckeditor5-utils/src/dom/global'; import Image from '../src/image'; import ImageToolbar from '../src/imagetoolbar'; import View from '@ckeditor/ckeditor5-ui/src/view'; -import env from '@ckeditor/ckeditor5-utils/src/env'; import testUtils from '@ckeditor/ckeditor5-core/tests/_utils/utils'; describe( 'ImageToolbar integration', () => { @@ -21,9 +20,6 @@ describe( 'ImageToolbar integration', () => { testUtils.createSinonSandbox(); beforeEach( () => { - // Most tests assume non-edge environment but we do not set `contenteditable=false` on Edge so stub `env.isEdge`. - testUtils.sinon.stub( env, 'isEdge' ).get( () => false ); - editorElement = global.document.createElement( 'div' ); global.document.body.appendChild( editorElement );