diff --git a/app/code/Magento/Cms/Helper/Wysiwyg/Images.php b/app/code/Magento/Cms/Helper/Wysiwyg/Images.php
index 4cddc23239b18..cd3473c6bab87 100644
--- a/app/code/Magento/Cms/Helper/Wysiwyg/Images.php
+++ b/app/code/Magento/Cms/Helper/Wysiwyg/Images.php
@@ -9,8 +9,6 @@
/**
* Wysiwyg Images Helper.
- *
- * @SuppressWarnings(PHPMD.CouplingBetweenObjects)
*/
class Images extends \Magento\Framework\App\Helper\AbstractHelper
{
diff --git a/app/code/Magento/Cms/view/adminhtml/web/js/folder-tree.js b/app/code/Magento/Cms/view/adminhtml/web/js/folder-tree.js
index 62b5648f4a278..9f082b2ce32ce 100644
--- a/app/code/Magento/Cms/view/adminhtml/web/js/folder-tree.js
+++ b/app/code/Magento/Cms/view/adminhtml/web/js/folder-tree.js
@@ -94,7 +94,7 @@ define([
lastExistentFolderEl = folderEl;
- if (path.length > 1) {
+ if (path.length) {
tree.jstree('open_node', folderEl, recursiveOpen);
} else {
tree.jstree('open_node', folderEl, function () {
diff --git a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Section/AdminProductFormSection.xml b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Section/AdminProductFormSection.xml
index 58aad7b294785..203451195828c 100644
--- a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Section/AdminProductFormSection.xml
+++ b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Section/AdminProductFormSection.xml
@@ -103,6 +103,8 @@
+
+
diff --git a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Test/AdminAddImageToWYSIWYGCatalogCest.xml b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Test/AdminAddImageToWYSIWYGCatalogCest.xml
index 8aa58cf1fb164..0f202e30c503f 100644
--- a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Test/AdminAddImageToWYSIWYGCatalogCest.xml
+++ b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Test/AdminAddImageToWYSIWYGCatalogCest.xml
@@ -21,8 +21,6 @@
-
-
diff --git a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Test/AdminAddImageToWYSIWYGProductCest.xml b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Test/AdminAddImageToWYSIWYGProductCest.xml
index ddc904d2ae396..b2eeacb3bc821 100644
--- a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Test/AdminAddImageToWYSIWYGProductCest.xml
+++ b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Catalog/Test/AdminAddImageToWYSIWYGProductCest.xml
@@ -16,8 +16,6 @@
-
-
@@ -47,7 +45,8 @@
-
+
+
diff --git a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Data/CmsPageData.xml b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Data/CmsPageData.xml
index 324d937df95b6..857ac2a2f1b1f 100644
--- a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Data/CmsPageData.xml
+++ b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Data/CmsPageData.xml
@@ -14,6 +14,12 @@
Sample page content. Yada yada yada.
test-page-
+
+ Test CMS Page
+ Test Content Heading
+ Sample page content. Yada yada yada.
+ test-page-
+
testpage
Test Content Heading
@@ -33,6 +39,7 @@
Yes
magento.jpg
magento
+ jpg
Image content. Yeah.
1000
diff --git a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddImageToWYSIWYGBlockCest.xml b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddImageToWYSIWYGBlockCest.xml
index 586be48618437..72d08737092cc 100644
--- a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddImageToWYSIWYGBlockCest.xml
+++ b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddImageToWYSIWYGBlockCest.xml
@@ -16,8 +16,6 @@
-
-
diff --git a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddImageToWYSIWYGCMSPageCest.xml b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddImageToWYSIWYGCMSPageCest.xml
index 626654b462833..4203614582711 100644
--- a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddImageToWYSIWYGCMSPageCest.xml
+++ b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddImageToWYSIWYGCMSPageCest.xml
@@ -16,8 +16,6 @@
-
-
@@ -47,7 +45,6 @@
-
diff --git a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddVariableToWYSIWYGBlockCest.xml b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddVariableToWYSIWYGBlockCest.xml
index 497185362add0..a4616d717dc7b 100644
--- a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddVariableToWYSIWYGBlockCest.xml
+++ b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Cms/Test/AdminAddVariableToWYSIWYGBlockCest.xml
@@ -12,8 +12,6 @@
-
-
diff --git a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/AdminAddImageToWYSIWYGNewsletterCest.xml b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/AdminAddImageToWYSIWYGNewsletterCest.xml
index dcc9c798dc4c1..28f57332650ed 100644
--- a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/AdminAddImageToWYSIWYGNewsletterCest.xml
+++ b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/AdminAddImageToWYSIWYGNewsletterCest.xml
@@ -16,8 +16,6 @@
-
-
@@ -58,7 +56,6 @@
-
diff --git a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/AdminAddVariableToWYSIWYGNewsletterCest.xml b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/AdminAddVariableToWYSIWYGNewsletterCest.xml
index fe0f067039209..59e4da42bddbc 100644
--- a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/AdminAddVariableToWYSIWYGNewsletterCest.xml
+++ b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/AdminAddVariableToWYSIWYGNewsletterCest.xml
@@ -12,7 +12,6 @@
-
diff --git a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/VerifyTinyMCEv4IsNativeWYSIWYGOnNewsletterCest.xml b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/VerifyTinyMCEv4IsNativeWYSIWYGOnNewsletterCest.xml
index dcf36d911e4ee..7ba7817555465 100644
--- a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/VerifyTinyMCEv4IsNativeWYSIWYGOnNewsletterCest.xml
+++ b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Newsletter/Test/VerifyTinyMCEv4IsNativeWYSIWYGOnNewsletterCest.xml
@@ -16,8 +16,6 @@
-
-
@@ -30,6 +28,7 @@
+
diff --git a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Variable/ActionGroup/CreateCustomVariableActionGroup.xml b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Variable/ActionGroup/CreateCustomVariableActionGroup.xml
index 001e8549142f6..84ccf65eb040d 100644
--- a/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Variable/ActionGroup/CreateCustomVariableActionGroup.xml
+++ b/dev/tests/acceptance/tests/functional/Magento/FunctionalTest/Variable/ActionGroup/CreateCustomVariableActionGroup.xml
@@ -21,6 +21,8 @@
+
+
diff --git a/dev/tests/integration/testsuite/Magento/Cms/Helper/Wysiwyg/ImagesTest.php b/dev/tests/integration/testsuite/Magento/Cms/Helper/Wysiwyg/ImagesTest.php
index 12d2a467360ea..68273ebe6180d 100644
--- a/dev/tests/integration/testsuite/Magento/Cms/Helper/Wysiwyg/ImagesTest.php
+++ b/dev/tests/integration/testsuite/Magento/Cms/Helper/Wysiwyg/ImagesTest.php
@@ -6,9 +6,20 @@
namespace Magento\Cms\Helper\Wysiwyg;
use Magento\Framework\App\Filesystem\DirectoryList;
+use Magento\TestFramework\ObjectManager;
class ImagesTest extends \PHPUnit\Framework\TestCase
{
+ /**
+ * @var ObjectManager
+ */
+ private $objectManager;
+
+ protected function setUp()
+ {
+ $this->objectManager = \Magento\TestFramework\Helper\Bootstrap::getObjectManager();
+ }
+
public function testGetStorageRoot()
{
/** @var \Magento\Framework\Filesystem $filesystem */
@@ -17,17 +28,112 @@ public function testGetStorageRoot()
);
$mediaPath = $filesystem->getDirectoryRead(DirectoryList::MEDIA)->getAbsolutePath();
/** @var \Magento\Cms\Helper\Wysiwyg\Images $helper */
- $helper = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()->create(
+ $helper = $this->objectManager->create(
\Magento\Cms\Helper\Wysiwyg\Images::class
);
$this->assertStringStartsWith($mediaPath, $helper->getStorageRoot());
}
+ /**
+ * @magentoConfigFixture current_store web/unsecure/base_url http://example.com/
+ */
public function testGetCurrentUrl()
{
- $helper = \Magento\TestFramework\Helper\Bootstrap::getObjectManager()->create(
+ /** @var \Magento\Cms\Helper\Wysiwyg\Images $helper */
+ $helper = $this->objectManager->create(
\Magento\Cms\Helper\Wysiwyg\Images::class
);
- $this->assertStringStartsWith('http://localhost/', $helper->getCurrentUrl());
+ $this->assertStringStartsWith('http://example.com/', $helper->getCurrentUrl());
+ }
+
+ /**
+ * @param bool $isStaticUrlsAllowed
+ * @param string $filename
+ * @param bool $renderAsTag
+ * @param string|callable $expectedResult - string or callable to make unique assertions on $expectedResult
+ * @magentoConfigFixture current_store web/unsecure/base_url http://example.com/
+ * @dataProvider providerGetImageHtmlDeclaration
+ */
+ public function testGetImageHtmlDeclaration(
+ $isStaticUrlsAllowed,
+ $filename,
+ $renderAsTag,
+ $expectedResult
+ ) {
+ $helper = $this->generateHelper($isStaticUrlsAllowed);
+
+ $actualResult = $helper->getImageHtmlDeclaration($filename, $renderAsTag);
+
+ if (is_callable($expectedResult)) {
+ $expectedResult($actualResult);
+ } else {
+ $this->assertEquals(
+ $expectedResult,
+ $actualResult
+ );
+ }
+ }
+
+ /**
+ * Data provider for testGetImageHtmlDeclaration
+ *
+ * @return array
+ */
+ public function providerGetImageHtmlDeclaration()
+ {
+ return [
+ [true, 'wysiwyg/hello.png', true, ''],
+ [
+ false,
+ 'wysiwyg/hello.png',
+ false,
+ function ($actualResult) {
+ $expectedResult = (
+ '/backend/cms/wysiwyg/directive/___directive/' .
+ 'e3ttZWRpYSB1cmw9Ind5c2l3eWcvaGVsbG8ucG5nIn19/'
+ );
+
+ $this->assertContains($expectedResult, parse_url($actualResult, PHP_URL_PATH));
+ }
+ ],
+ [true, 'wysiwyg/hello.png', false, 'http://example.com/pub/media/wysiwyg/hello.png'],
+ [false, 'wysiwyg/hello.png', true, ''],
+ ];
+ }
+
+ /**
+ * Generate instance of Images Helper
+ *
+ * @param bool $isStaticUrlsAllowed - mock is created to override value of isUsingStaticUrlsAllowed method in class
+ * @return \Magento\Cms\Helper\Wysiwyg\Images
+ * @SuppressWarnings(PHPMD.UnusedLocalVariable)
+ */
+ private function generateHelper($isStaticUrlsAllowed = false)
+ {
+ $storeId = 1;
+
+ $eventManagerMock = $this->createMock(\Magento\Framework\Event\ManagerInterface::class);
+
+ $contextMock = $this->objectManager->create(\Magento\Framework\App\Helper\Context::class, [
+ 'eventManager' => $eventManagerMock,
+ ]);
+
+ $helper = $this->objectManager->create(\Magento\Cms\Helper\Wysiwyg\Images::class, [
+ 'context' => $contextMock
+ ]);
+
+ $checkResult = new \stdClass();
+ $checkResult->isAllowed = false;
+
+ $eventManagerMock->expects($this->any())
+ ->method('dispatch')
+ ->with('cms_wysiwyg_images_static_urls_allowed', ['result' => $checkResult, 'store_id' => $storeId])
+ ->willReturnCallback(function ($_, $arr) use ($isStaticUrlsAllowed) {
+ $arr['result']->isAllowed = $isStaticUrlsAllowed;
+ });
+
+ $helper->setStoreId($storeId);
+
+ return $helper;
}
}
diff --git a/dev/tests/integration/testsuite/Magento/Cms/Model/Wysiwyg/ConfigTest.php b/dev/tests/integration/testsuite/Magento/Cms/Model/Wysiwyg/ConfigTest.php
index 201a08fa539ea..b79ccd255f26a 100644
--- a/dev/tests/integration/testsuite/Magento/Cms/Model/Wysiwyg/ConfigTest.php
+++ b/dev/tests/integration/testsuite/Magento/Cms/Model/Wysiwyg/ConfigTest.php
@@ -39,9 +39,16 @@ public function testGetConfig()
public function testGetConfigCssUrls()
{
$config = $this->model->getConfig();
- $publicPathPattern = 'http://localhost/pub/static/%s/adminhtml/Magento/backend/en_US/mage/%s';
+ $publicPathPattern = 'http://localhost/pub/static/%s/adminhtml/Magento/backend/en_US/%s';
$tinyMce4Config = $config->getData('tinymce4');
- $this->assertStringMatchesFormat($publicPathPattern, $tinyMce4Config['content_css']);
+ $contentCss = $tinyMce4Config['content_css'];
+ if (is_array($contentCss)) {
+ foreach ($contentCss as $url) {
+ $this->assertStringMatchesFormat($publicPathPattern, $url);
+ }
+ } else {
+ $this->assertStringMatchesFormat($publicPathPattern, $contentCss);
+ }
}
/**
diff --git a/dev/tests/js/jasmine/tests/lib/mage/wysiwygAdapter.test.js b/dev/tests/js/jasmine/tests/lib/mage/wysiwygAdapter.test.js
new file mode 100644
index 0000000000000..ff510046e5528
--- /dev/null
+++ b/dev/tests/js/jasmine/tests/lib/mage/wysiwygAdapter.test.js
@@ -0,0 +1,62 @@
+/**
+ * Copyright © Magento, Inc. All rights reserved.
+ * See COPYING.txt for license details.
+ */
+
+/* eslint-disable max-nested-callbacks */
+define([
+ 'wysiwygAdapter'
+], function (wysiwygAdapter) {
+ 'use strict';
+
+ var obj;
+
+ beforeEach(function () {
+
+ /**
+ * Dummy constructor to use for instantiation
+ * @constructor
+ */
+ var Constr = function () {};
+
+ Constr.prototype = wysiwygAdapter;
+
+ obj = new Constr();
+ obj.initialize('id', {
+ 'directives_url': 'http://example.com/admin/cms/wysiwyg/directive/'
+ });
+ });
+
+ describe('wysiwygAdapter', function () {
+ var decodedHtml = '' +
+ '
',
+ encodedHtml = '' +
+ '' +
+ '
',
+ encodedHtmlWithForwardSlashInImgSrc = encodedHtml.replace('%2C%2C', '%2C%2C/');
+
+ describe('"encodeDirectives" method', function () {
+ it('converts media directive img src to directive URL', function () {
+ expect(obj.encodeDirectives(decodedHtml)).toEqual(encodedHtml);
+ });
+ });
+
+ describe('"decodeDirectives" method', function () {
+ it(
+ 'converts directive URL img src without a trailing forward slash ' +
+ 'to media url without a trailing forward slash',
+ function () {
+ expect(obj.decodeDirectives(encodedHtml)).toEqual(decodedHtml);
+ }
+ );
+
+ it('converts directive URL img src with a trailing forward slash ' +
+ 'to media url without a trailing forward slash',
+ function () {
+ expect(obj.decodeDirectives(encodedHtmlWithForwardSlashInImgSrc)).toEqual(decodedHtml);
+ }
+ );
+ });
+ });
+});
diff --git a/lib/web/mage/adminhtml/wysiwyg/tiny_mce/tinymce4Adapter.js b/lib/web/mage/adminhtml/wysiwyg/tiny_mce/tinymce4Adapter.js
index bfae7a0157c23..443ca40862ca4 100644
--- a/lib/web/mage/adminhtml/wysiwyg/tiny_mce/tinymce4Adapter.js
+++ b/lib/web/mage/adminhtml/wysiwyg/tiny_mce/tinymce4Adapter.js
@@ -608,10 +608,10 @@ define([
decodeDirectives: function (content) {
// escape special chars in directives url to use it in regular expression
var url = this.makeDirectiveUrl('%directive%').replace(/([$^.?*!+:=()\[\]{}|\\])/g, '\\$1'),
- reg = new RegExp(url.replace('%directive%', '([a-zA-Z0-9,_-]+(?:%2[A-Z]|)+)'));
+ reg = new RegExp(url.replace('%directive%', '([a-zA-Z0-9,_-]+(?:%2[A-Z]|)+\/?)'));
return content.gsub(reg, function (match) { //eslint-disable-line no-extra-bind
- return Base64.mageDecode(decodeURIComponent(match[1])).replace(/"/g, '"');
+ return Base64.mageDecode(decodeURIComponent(match[1]).replace(/\/$/, '')).replace(/"/g, '"');
});
},