jenkins-bot has submitted this change and it was merged.

Change subject: Fix 5+ year comparison in TimeValueComparer
......................................................................


Fix 5+ year comparison in TimeValueComparer

Change-Id: I4a6e8fa90fd25e76196c53a6e3b251b0e7b84d18
---
M includes/CrossCheck/Comparer/TimeValueComparer.php
M tests/phpunit/CrossCheck/Comparer/TimeValueComparerTest.php
2 files changed, 38 insertions(+), 6 deletions(-)

Approvals:
  Daniel Kinzler: Looks good to me, approved
  jenkins-bot: Verified



diff --git a/includes/CrossCheck/Comparer/TimeValueComparer.php 
b/includes/CrossCheck/Comparer/TimeValueComparer.php
index cba8f64..86ec7ef 100644
--- a/includes/CrossCheck/Comparer/TimeValueComparer.php
+++ b/includes/CrossCheck/Comparer/TimeValueComparer.php
@@ -42,11 +42,24 @@
 
                $result = ComparisonResult::STATUS_MISMATCH;
 
+               if ( !preg_match( '/^([-+]?)(\d*)((\d{4}\b).*)/', 
$value->getTime(), $localMatches )
+                       || !preg_match( '/^([-+]?)(\d*)((\d{4}\b).*)/', 
$comparativeValue->getTime(), $externalMatches )
+               ) {
+                       return ComparisonResult::STATUS_MISMATCH;
+               }
+               list( , $localSign, $localYearHigh, $localMwTime, $localYearLow 
) = $localMatches;
+               list( , $externalSign, $externalYearHigh, $externalMwTime, 
$externalYearLow ) = $externalMatches;
+               if ( $localSign !== $externalSign && ( $localYearHigh . 
$localYearLow !== '0000'
+                               || $externalYearHigh . $externalYearLow !== 
'0000' )
+               ) {
+                       return ComparisonResult::STATUS_MISMATCH;
+               }
+
                try {
-                       // FIXME: MWTimestamp does not support years with more 
than 4 digits!
-                       $localTimestamp = new MWTimestamp( substr( 
$value->getTime(), 1 ) );
-                       $externalTimestamp = new MWTimestamp( substr( 
$comparativeValue->getTime(), 1 ) );
+                       $localTimestamp = new MWTimestamp( $localMwTime );
+                       $externalTimestamp = new MWTimestamp( $externalMwTime );
                        $diff = $localTimestamp->diff( $externalTimestamp );
+                       $diff->y += abs( $localYearHigh - $externalYearHigh ) * 
10000;
 
                        if ( $value->getPrecision() === 
$comparativeValue->getPrecision()
                                && $this->resultOfDiffWithPrecision( $diff, 
$value->getPrecision() )
diff --git a/tests/phpunit/CrossCheck/Comparer/TimeValueComparerTest.php 
b/tests/phpunit/CrossCheck/Comparer/TimeValueComparerTest.php
index 33f07e6..dc458bd 100644
--- a/tests/phpunit/CrossCheck/Comparer/TimeValueComparerTest.php
+++ b/tests/phpunit/CrossCheck/Comparer/TimeValueComparerTest.php
@@ -95,10 +95,15 @@
                                new TimeValue( '+11980-08-00T00:00:00Z', 0, 0, 
0, TimeValue::PRECISION_YEAR, $g ),
                                new TimeValue( '+1980-00-00T00:00:00Z', 0, 0, 
0, TimeValue::PRECISION_YEAR, $g )
                        ),
-                       'Other gigayear' => array(
+                       'Other gigayear increasing' => array(
                                ComparisonResult::STATUS_MISMATCH,
                                new TimeValue( '+1000000000-00-00T00:00:00Z', 
0, 0, 0, TimeValue::PRECISION_YEAR1G, $g ),
                                new TimeValue( '+2000000000-00-00T00:00:00Z', 
0, 0, 0, TimeValue::PRECISION_YEAR1G, $g )
+                       ),
+                       'Other gigayear decreasing' => array(
+                               ComparisonResult::STATUS_MISMATCH,
+                               new TimeValue( '+2000000000-00-00T00:00:00Z', 
0, 0, 0, TimeValue::PRECISION_YEAR1G, $g ),
+                               new TimeValue( '+1000000000-00-00T00:00:00Z', 
0, 0, 0, TimeValue::PRECISION_YEAR1G, $g )
                        ),
                        'Other decade with year precision' => array(
                                ComparisonResult::STATUS_MISMATCH,
@@ -130,12 +135,26 @@
                                new TimeValue( '+2001-01-01T01:01:01Z', 0, 0, 
0, TimeValue::PRECISION_SECOND, $g ),
                                new TimeValue( '+2001-01-01T01:02:01Z', 0, 0, 
0, TimeValue::PRECISION_SECOND, $g )
                        ),
-                       // FIXME: This is a bug!
-                       'Can not compare 5+ digit years' => array(
+                       'Other sign' => array(
                                ComparisonResult::STATUS_MISMATCH,
+                               new TimeValue( '-2001-00-00T00:00:00Z', 0, 0, 
0, TimeValue::PRECISION_YEAR, $g ),
+                               new TimeValue( '+2001-00-00T00:00:00Z', 0, 0, 
0, TimeValue::PRECISION_YEAR, $g )
+                       ),
+                       'Plus/minus zero' => array(
+                               ComparisonResult::STATUS_MATCH,
+                               new TimeValue( '-0000-00-00T00:00:00Z', 0, 0, 
0, TimeValue::PRECISION_YEAR, $g ),
+                               new TimeValue( '+0000-00-00T00:00:00Z', 0, 0, 
0, TimeValue::PRECISION_YEAR, $g )
+                       ),
+                       'Same 5+ digit years' => array(
+                               ComparisonResult::STATUS_MATCH,
                                new TimeValue( '+12345-00-00T00:00:00Z', 0, 0, 
0, TimeValue::PRECISION_YEAR, $g ),
                                new TimeValue( '+12345-00-00T00:00:00Z', 0, 0, 
0, TimeValue::PRECISION_YEAR, $g )
                        ),
+                       'Same gigayear' => array(
+                               ComparisonResult::STATUS_MATCH,
+                               new TimeValue( '+1000010000-00-00T00:00:00Z', 
0, 0, 0, TimeValue::PRECISION_YEAR1G, $g ),
+                               new TimeValue( '+1000020000-00-00T00:00:00Z', 
0, 0, 0, TimeValue::PRECISION_YEAR1G, $g )
+                       ),
                );
        }
 

-- 
To view, visit https://gerrit.wikimedia.org/r/243627
To unsubscribe, visit https://gerrit.wikimedia.org/r/settings

Gerrit-MessageType: merged
Gerrit-Change-Id: I4a6e8fa90fd25e76196c53a6e3b251b0e7b84d18
Gerrit-PatchSet: 2
Gerrit-Project: mediawiki/extensions/WikibaseQualityExternalValidation
Gerrit-Branch: master
Gerrit-Owner: Thiemo Mättig (WMDE) <[email protected]>
Gerrit-Reviewer: Addshore <[email protected]>
Gerrit-Reviewer: Aude <[email protected]>
Gerrit-Reviewer: Daniel Kinzler <[email protected]>
Gerrit-Reviewer: Jeroen De Dauw <[email protected]>
Gerrit-Reviewer: jenkins-bot <>

_______________________________________________
MediaWiki-commits mailing list
[email protected]
https://lists.wikimedia.org/mailman/listinfo/mediawiki-commits

Reply via email to