use Config;
use POSIX;
-use Test::More qw(no_plan);
+use Test::More tests => 9;
# go to UTC to avoid DST issues around the world when testing. SUS3 says that
# null should get you UTC, but some environments want the explicit names.
$^O eq "MSWin32" || $^O eq "dos" || $^O eq "interix";
tzset();
my @tzname = tzname();
- like($tzname[0], qr/[GMT|UTC]/i, "tzset() to GMT/UTC");
- like($tzname[1], qr/[GMT|UTC]/i, "The whole year?");
+ like($tzname[0], qr/(GMT|UTC)/i, "tzset() to GMT/UTC");
+ SKIP: {
+ skip "Mac OS X/Darwin doesn't handle this", 1 if $^O =~ /darwin/i;
+ like($tzname[1], qr/(GMT|UTC)/i, "The whole year?");
+ }
}
# asctime and ctime...Let's stay below INT_MAX for 32-bits and
# Careful! strftime() is locale sensative. Let's take care of that
my $orig_loc = setlocale(LC_TIME, "C") || die "Cannot setlocale() to C: $!";
-if ($^O eq "MSWin32") {
- is(ctime(0), strftime("%a %b %#d %H:%M:%S %Y\n", localtime(0)),
+my $jan_16 = 15 * 86400;
+is(ctime($jan_16), strftime("%a %b %d %H:%M:%S %Y\n", localtime($jan_16)),
"get ctime() equal to strftime()");
-} else {
- is(ctime(0), strftime("%a %b %e %H:%M:%S %Y\n", localtime(0)),
- "get ctime() equal to strftime()");
-}
setlocale(LC_TIME, $orig_loc) || die "Cannot setlocale() back to orig: $!";
-# Hard to test other than to make sure it returns something numeric and < 0
+# clock() seems to have different definitions of what it does between POSIX
+# and BSD. Cygwin, Win32, and Linux lean the BSD way. So, the tests just
+# check the basics.
like(clock(), qr/\d*/, "clock() returns a numeric value");
-ok(clock() > 0, "...and its greater than zero");
+ok(clock() >= 0, "...and it returns something >= 0");
SKIP: {
skip "No difftime()", 1 if $Config{d_difftime} ne 'define';