26dt_leapsecond_pm.t   [plain text]


use strict;

use Test::More tests => 9;

use DateTime::LeapSecond;

is ( DateTime::LeapSecond::leap_seconds( 100 ), 0, 'before 1970'  );

# at the start of the table:

# 1972-06-30
my $day = 720074;
is ( DateTime::LeapSecond::leap_seconds( $day ), 0, 'before leap-second transition'  );

is ( DateTime::LeapSecond::extra_seconds( $day ) + 0, 1, 'leap day'  );

# 1972-07-01
$day = 720075;
is ( DateTime::LeapSecond::leap_seconds( $day ), 1, 'day after leap-second day'  );

is ( DateTime::LeapSecond::extra_seconds( $day ), 0, 'not a leap day'  );

# 1972-07-02
$day = 720076;
is ( DateTime::LeapSecond::leap_seconds( $day ), 1, 'after leap-second day'  );

# at the end of the table:
# 1998-12-31
$day = 729754;
is ( DateTime::LeapSecond::leap_seconds( $day ), 21, 'before leap-second day'  );

# 1999-01-01
$day = 729755;
is ( DateTime::LeapSecond::leap_seconds( $day ), 22, 'leap-second day'  );

# 1999-01-02
$day = 729756;
is ( DateTime::LeapSecond::leap_seconds( $day ), 22, 'after leap-second day'  );


# some leap second dates:
# 1972  Jul. 1
# 1973  Jan. 1
# ...
# 1997  Jul. 1
# 1999  Jan. 1