|
|
b8c914 |
From 381d51822fccaa333cbd0ab9fca8b69f650c05f9 Mon Sep 17 00:00:00 2001
|
|
|
b8c914 |
From: =?UTF-8?q?Petr=20P=C3=ADsa=C5=99?= <ppisar@redhat.com>
|
|
|
b8c914 |
Date: Fri, 14 Feb 2020 14:10:10 +0100
|
|
|
b8c914 |
Subject: [PATCH] Only pass 2-digit years to tests when testing 2-digit year
|
|
|
b8c914 |
handling
|
|
|
b8c914 |
MIME-Version: 1.0
|
|
|
b8c914 |
Content-Type: text/plain; charset=UTF-8
|
|
|
b8c914 |
Content-Transfer-Encoding: 8bit
|
|
|
b8c914 |
|
|
|
b8c914 |
This will start breaking in 2020 if done without working around the whole
|
|
|
b8c914 |
breakpoint thing. See https://rt.cpan.org/Ticket/Display.html?id=124787.
|
|
|
b8c914 |
|
|
|
b8c914 |
Ported from Time-Local 63265fd81c7f6177bf28dfe0d1ada9cb897de566 commit
|
|
|
b8c914 |
by Dave Rolsky <autarch@urth.org> to perl 5.28.2.
|
|
|
b8c914 |
|
|
|
b8c914 |
Signed-off-by: Petr Písař <ppisar@redhat.com>
|
|
|
b8c914 |
---
|
|
|
b8c914 |
cpan/Time-Local/t/Local.t | 40 +++++++++++++++++++++++++++++----------
|
|
|
b8c914 |
1 file changed, 30 insertions(+), 10 deletions(-)
|
|
|
b8c914 |
|
|
|
b8c914 |
diff --git a/cpan/Time-Local/t/Local.t b/cpan/Time-Local/t/Local.t
|
|
|
b8c914 |
index 6341396..701d22d 100644
|
|
|
b8c914 |
--- a/cpan/Time-Local/t/Local.t
|
|
|
b8c914 |
+++ b/cpan/Time-Local/t/Local.t
|
|
|
b8c914 |
@@ -85,19 +85,17 @@ my $epoch_is_64
|
|
|
b8c914 |
|
|
|
b8c914 |
for ( @time, @neg_time ) {
|
|
|
b8c914 |
my ( $year, $mon, $mday, $hour, $min, $sec ) = @$_;
|
|
|
b8c914 |
- $year -= 1900;
|
|
|
b8c914 |
$mon--;
|
|
|
b8c914 |
|
|
|
b8c914 |
SKIP: {
|
|
|
b8c914 |
skip '1970 test on VOS fails.', 12
|
|
|
b8c914 |
- if $^O eq 'vos' && $year == 70;
|
|
|
b8c914 |
+ if $^O eq 'vos' && $year == 1970;
|
|
|
b8c914 |
skip 'this platform does not support negative epochs.', 12
|
|
|
b8c914 |
- if $year < 70 && !$neg_epoch_ok;
|
|
|
b8c914 |
+ if $year < 1970 && !$neg_epoch_ok;
|
|
|
b8c914 |
|
|
|
b8c914 |
# Test timelocal()
|
|
|
b8c914 |
{
|
|
|
b8c914 |
- my $year_in = $year < 70 ? $year + 1900 : $year;
|
|
|
b8c914 |
- my $time = timelocal( $sec, $min, $hour, $mday, $mon, $year_in );
|
|
|
b8c914 |
+ my $time = timelocal( $sec, $min, $hour, $mday, $mon, $year );
|
|
|
b8c914 |
|
|
|
b8c914 |
my ( $s, $m, $h, $D, $M, $Y ) = localtime($time);
|
|
|
b8c914 |
|
|
|
b8c914 |
@@ -106,13 +104,12 @@ SKIP: {
|
|
|
b8c914 |
is( $h, $hour, "timelocal hour for @$_" );
|
|
|
b8c914 |
is( $D, $mday, "timelocal day for @$_" );
|
|
|
b8c914 |
is( $M, $mon, "timelocal month for @$_" );
|
|
|
b8c914 |
- is( $Y, $year, "timelocal year for @$_" );
|
|
|
b8c914 |
+ is( $Y, $year - 1900, "timelocal year for @$_" );
|
|
|
b8c914 |
}
|
|
|
b8c914 |
|
|
|
b8c914 |
# Test timegm()
|
|
|
b8c914 |
{
|
|
|
b8c914 |
- my $year_in = $year < 70 ? $year + 1900 : $year;
|
|
|
b8c914 |
- my $time = timegm( $sec, $min, $hour, $mday, $mon, $year_in );
|
|
|
b8c914 |
+ my $time = timegm( $sec, $min, $hour, $mday, $mon, $year );
|
|
|
b8c914 |
|
|
|
b8c914 |
my ( $s, $m, $h, $D, $M, $Y ) = gmtime($time);
|
|
|
b8c914 |
|
|
|
b8c914 |
@@ -121,14 +118,13 @@ SKIP: {
|
|
|
b8c914 |
is( $h, $hour, "timegm hour for @$_" );
|
|
|
b8c914 |
is( $D, $mday, "timegm day for @$_" );
|
|
|
b8c914 |
is( $M, $mon, "timegm month for @$_" );
|
|
|
b8c914 |
- is( $Y, $year, "timegm year for @$_" );
|
|
|
b8c914 |
+ is( $Y, $year - 1900, "timegm year for @$_" );
|
|
|
b8c914 |
}
|
|
|
b8c914 |
}
|
|
|
b8c914 |
}
|
|
|
b8c914 |
|
|
|
b8c914 |
for (@bad_time) {
|
|
|
b8c914 |
my ( $year, $mon, $mday, $hour, $min, $sec ) = @$_;
|
|
|
b8c914 |
- $year -= 1900;
|
|
|
b8c914 |
$mon--;
|
|
|
b8c914 |
|
|
|
b8c914 |
eval { timegm( $sec, $min, $hour, $mday, $mon, $year ) };
|
|
|
b8c914 |
@@ -229,6 +225,30 @@ SKIP:
|
|
|
b8c914 |
);
|
|
|
b8c914 |
}
|
|
|
b8c914 |
|
|
|
b8c914 |
+# 2-digit years
|
|
|
b8c914 |
+{
|
|
|
b8c914 |
+ my $current_year = ( localtime() )[5];
|
|
|
b8c914 |
+ my $pre_break = ( $current_year + 49 ) - 100;
|
|
|
b8c914 |
+ my $break = ( $current_year + 50 ) - 100;
|
|
|
b8c914 |
+ my $post_break = ( $current_year + 51 ) - 100;
|
|
|
b8c914 |
+
|
|
|
b8c914 |
+ is(
|
|
|
b8c914 |
+ ( ( localtime( timelocal( 0, 0, 0, 1, 1, $pre_break ) ) )[5] ),
|
|
|
b8c914 |
+ $pre_break + 100,
|
|
|
b8c914 |
+ "year $pre_break is treated as next century",
|
|
|
b8c914 |
+ );
|
|
|
b8c914 |
+ is(
|
|
|
b8c914 |
+ ( ( localtime( timelocal( 0, 0, 0, 1, 1, $break ) ) )[5] ),
|
|
|
b8c914 |
+ $break + 100,
|
|
|
b8c914 |
+ "year $break is treated as next century",
|
|
|
b8c914 |
+ );
|
|
|
b8c914 |
+ is(
|
|
|
b8c914 |
+ ( ( localtime( timelocal( 0, 0, 0, 1, 1, $post_break ) ) )[5] ),
|
|
|
b8c914 |
+ $post_break,
|
|
|
b8c914 |
+ "year $post_break is treated as current century",
|
|
|
b8c914 |
+ );
|
|
|
b8c914 |
+}
|
|
|
b8c914 |
+
|
|
|
b8c914 |
SKIP:
|
|
|
b8c914 |
{
|
|
|
b8c914 |
skip 'These tests only run for the package maintainer.', 8
|
|
|
b8c914 |
--
|
|
|
b8c914 |
2.21.1
|
|
|
b8c914 |
|