Merge pull request #10677 from creative-commoners/pulls/4/deprecate-diff

API Deprecate Diff in favour of CMS5's HtmlDiff
This commit is contained in:
Sabina Talipova 2023-02-08 16:36:58 +13:00 committed by GitHub
commit 1f7adab62e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 45 additions and 3 deletions

View File

@ -5,16 +5,28 @@ namespace SilverStripe\View\Parsers;
use InvalidArgumentException; use InvalidArgumentException;
use SilverStripe\Core\Convert; use SilverStripe\Core\Convert;
use SilverStripe\Core\Injector\Injector; use SilverStripe\Core\Injector\Injector;
use SilverStripe\Dev\Deprecation;
require_once 'difflib/difflib.php'; require_once 'difflib/difflib.php';
/** /**
* Class representing a 'diff' between two sequences of strings. * Class representing a 'diff' between two sequences of strings.
*
* @deprecated 4.13.0 Will be replaced with SilverStripe\View\Parsers\HtmlDiff
*/ */
class Diff extends \Diff class Diff extends \Diff
{ {
public static $html_cleaner_class = null; public static $html_cleaner_class = null;
/**
* @inheritDoc
*/
public function __construct($from_lines, $to_lines)
{
Deprecation::notice('4.13.0', 'Will be replaced with SilverStripe\View\Parsers\HtmlDiff', Deprecation::SCOPE_CLASS);
parent::__construct($from_lines, $to_lines);
}
/** /**
* Attempt to clean invalid HTML, which messes up diffs. * Attempt to clean invalid HTML, which messes up diffs.
* This cleans code if possible, using an instance of HTMLCleaner * This cleans code if possible, using an instance of HTMLCleaner
@ -26,9 +38,12 @@ class Diff extends \Diff
* @param HTMLCleaner $cleaner Optional instance of a HTMLCleaner class to * @param HTMLCleaner $cleaner Optional instance of a HTMLCleaner class to
* use, overriding self::$html_cleaner_class * use, overriding self::$html_cleaner_class
* @return mixed|string * @return mixed|string
*
* @deprecated 4.13.0 Will be removed without equivalent functionality
*/ */
public static function cleanHTML($content, $cleaner = null) public static function cleanHTML($content, $cleaner = null)
{ {
Deprecation::notice('4.13.0', 'Will be removed without equivalent functionality');
if (!$cleaner) { if (!$cleaner) {
if (self::$html_cleaner_class && class_exists(self::$html_cleaner_class)) { if (self::$html_cleaner_class && class_exists(self::$html_cleaner_class)) {
$cleaner = Injector::inst()->create(self::$html_cleaner_class); $cleaner = Injector::inst()->create(self::$html_cleaner_class);
@ -57,9 +72,13 @@ class Diff extends \Diff
* @param string $to * @param string $to
* @param bool $escape * @param bool $escape
* @return string * @return string
*
* @deprecated 4.13.0 Will be replaced with SilverStripe\View\Parsers\HtmlDiff::compareHTML()
*/ */
public static function compareHTML($from, $to, $escape = false) public static function compareHTML($from, $to, $escape = false)
{ {
Deprecation::notice('4.13.0', 'Will be replaced with SilverStripe\View\Parsers\HtmlDiff::compareHTML()');
// First split up the content into words and tags // First split up the content into words and tags
$set1 = self::getHTMLChunks($from); $set1 = self::getHTMLChunks($from);
$set2 = self::getHTMLChunks($to); $set2 = self::getHTMLChunks($to);
@ -163,9 +182,13 @@ class Diff extends \Diff
/** /**
* @param string|bool|array $content If passed as an array, values will be concatenated with a comma. * @param string|bool|array $content If passed as an array, values will be concatenated with a comma.
* @return array * @return array
*
* @deprecated 4.13.0 Will be removed without equivalent functionality
*/ */
public static function getHTMLChunks($content) public static function getHTMLChunks($content)
{ {
Deprecation::notice('4.13.0', 'Will be removed without equivalent functionality');
if ($content && !is_string($content) && !is_array($content) && !is_numeric($content) && !is_bool($content)) { if ($content && !is_string($content) && !is_array($content) && !is_numeric($content) && !is_bool($content)) {
throw new InvalidArgumentException('$content parameter needs to be a string or array'); throw new InvalidArgumentException('$content parameter needs to be a string or array');
} }

View File

@ -2,6 +2,7 @@
namespace SilverStripe\View\Tests\Parsers; namespace SilverStripe\View\Tests\Parsers;
use SilverStripe\Dev\Deprecation;
use SilverStripe\Dev\SapphireTest; use SilverStripe\Dev\SapphireTest;
use SilverStripe\View\Parsers\Diff; use SilverStripe\View\Parsers\Diff;
@ -13,6 +14,10 @@ class DiffTest extends SapphireTest
*/ */
public function testTableDiff() public function testTableDiff()
{ {
if (Deprecation::isEnabled()) {
$this->markTestSkipped('Test calls deprecated code');
}
if (!class_exists('DOMDocument')) { if (!class_exists('DOMDocument')) {
$this->markTestSkipped('"DOMDocument" required'); $this->markTestSkipped('"DOMDocument" required');
return; return;
@ -47,7 +52,9 @@ class DiffTest extends SapphireTest
</table>"; </table>";
$expected = "<ins>" . $to . "</ins>" . "<del>" . $from . "</del>"; $expected = "<ins>" . $to . "</ins>" . "<del>" . $from . "</del>";
$compare = Diff::compareHTML($from, $to); $compare = Deprecation::withNoReplacement(function () use ($from, $to) {
return Diff::compareHTML($from, $to);
});
// Very hard to debug this way, wouldn't need to do this if PHP had an *actual* DOM parsing lib, // Very hard to debug this way, wouldn't need to do this if PHP had an *actual* DOM parsing lib,
// and not just the poor excuse that is DOMDocument // and not just the poor excuse that is DOMDocument
@ -62,6 +69,10 @@ class DiffTest extends SapphireTest
*/ */
public function testLegacyEachStatement() public function testLegacyEachStatement()
{ {
if (Deprecation::isEnabled()) {
$this->markTestSkipped('Test calls deprecated code');
}
$sentenceOne = $sentenceOne =
'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'; 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.';
$sentenceTwo = $sentenceTwo =
@ -73,17 +84,25 @@ class DiffTest extends SapphireTest
// We're cheating our test a little bit here, because depending on what HTML cleaner you have, you'll get // We're cheating our test a little bit here, because depending on what HTML cleaner you have, you'll get
// spaces added or not added around the tags. // spaces added or not added around the tags.
$expected = "/^ *<del>$sentenceOne<\/del> *$sentenceTwo *<ins>$sentenceOne<\/ins> *$/"; $expected = "/^ *<del>$sentenceOne<\/del> *$sentenceTwo *<ins>$sentenceOne<\/ins> *$/";
$actual = Diff::compareHTML($from, $to); $actual = Deprecation::withNoReplacement(function () use ($from, $to) {
return Diff::compareHTML($from, $to);
});
$this->assertMatchesRegularExpression($expected, $actual); $this->assertMatchesRegularExpression($expected, $actual);
} }
public function testDiffArray() public function testDiffArray()
{ {
if (Deprecation::isEnabled()) {
$this->markTestSkipped('Test calls deprecated code');
}
$from = ['Lorem', ['array here please ignore'], 'ipsum dolor']; $from = ['Lorem', ['array here please ignore'], 'ipsum dolor'];
$to = 'Lorem,ipsum'; $to = 'Lorem,ipsum';
$expected = "/^Lorem,ipsum *<del>dolor<\/del> *$/"; $expected = "/^Lorem,ipsum *<del>dolor<\/del> *$/";
$actual = Diff::compareHTML($from, $to); $actual = Deprecation::withNoReplacement(function () use ($from, $to) {
return Diff::compareHTML($from, $to);
});
$this->assertMatchesRegularExpression($expected, $actual); $this->assertMatchesRegularExpression($expected, $actual);
} }