From b31dc1518fb023a5a3699e5126734970615539f1 Mon Sep 17 00:00:00 2001 From: Packit Service Date: Dec 17 2020 00:41:51 +0000 Subject: Source-git repo for imports/c8s/perl-DateTime-Format-HTTP-0.42-9.el8 --- diff --git a/.packit.yaml b/.packit.yaml new file mode 100644 index 0000000..19654c4 --- /dev/null +++ b/.packit.yaml @@ -0,0 +1,11 @@ +jobs: +- job: copr_build + metadata: + targets: &id001 [centos-stream-x86_64] + trigger: pull_request +- job: tests + metadata: + targets: *id001 + trigger: pull_request +specfile_path: SPECS/perl-DateTime-Format-HTTP.spec +upstream_ref: c8s-source-git diff --git a/Build.PL b/Build.PL new file mode 100644 index 0000000..01b695c --- /dev/null +++ b/Build.PL @@ -0,0 +1,14 @@ +use strict; + +use Module::Build; + +Module::Build->new( module_name => 'DateTime::Format::HTTP', + dist_author => 'Christiaan Kras ', + license => 'perl', + requires => { 'DateTime' => '0.17', + 'HTTP::Date' => '1.44', + 'Test::More' => '0.47', + }, + create_readme => 1, + create_makefile_pl => 'traditional', + )->create_build_script; diff --git a/CREDITS b/CREDITS new file mode 100644 index 0000000..9975a74 --- /dev/null +++ b/CREDITS @@ -0,0 +1,6 @@ +CREDITS FOR DateTime::Format::HTTP 0.35 + +Gisle Aas (GAAS) for writing HTTP::Date. + +Me, for never quite finishing HTTP::Date::XS. + diff --git a/Changes b/Changes new file mode 100644 index 0000000..5521b34 --- /dev/null +++ b/Changes @@ -0,0 +1,80 @@ +0.42 2014-05-02 + +- Forgot to properly update the version number... + + +0.41 2014-05-02 + +- Fix out-by-ten bug in nanosecond computation (Stephen Thirlwall) + + +0.40 2010-10-31 + +- format_isoz now actually changes the time zone. Fixes RT 62332 (DOUGDUDE) + + +0.39 2010-07-03 + +- No code changes from previous versions. + + +0.38_01 2010-07-01 + +- Making sure the nanosecond is a integer, and not a float making the creation + of a DateTime object fail. Fixes RT 58854 (Christiaan Kras) + +- Repository moved from Subversion to Git. The repository can be located at + git://github.com/Htbaa/DateTime-Format-HTTP.git + + +0.38 2009-04-05 + +- No code changes from previous versions. + +- Shut up the verbose diagnostic output from the tests. + +- Fixed various bugs in the Build.PL, and generally modernized the + distro tarball. Hopefully this will fix problems some cpan testers + were seeing. + + +0.37 2006-08-09 + +- No code changes from previous versions, but there is no SIGNATURE + file, because this seems to cause more trouble than it's + worth. Fixes RT 17839. + + +0.36 2004-02-10 + +[ BACKWARDS INCOMPATIBILITY ] + +- The default time zone is now the floating time zone, not the local + time zone, because we cannot determine the local time zone reliably + on all systems. + + +0.3501 2004-01-26 + +- New maintainer - Dave Rolsky. + +- Switched to Module::Build. + + +0.35 2003-08-16 + +- Removed unused code. + +- Added support section to POD. + +- Modified wording of license section. + + +0.34 2004-07-07 + +- Bumped up DT::TZ requirements. + + +0.33 2003-07-02 + +- Initial release. diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..9d0305b --- /dev/null +++ b/LICENSE @@ -0,0 +1,383 @@ +Terms of Perl itself + +a) the GNU General Public License as published by the Free + Software Foundation; either version 1, or (at your option) any + later version, or +b) the "Artistic License" + +--------------------------------------------------------------------------- + +The General Public License (GPL) +Version 2, June 1991 + +Copyright (C) 1989, 1991 Free Software Foundation, Inc. 675 Mass Ave, +Cambridge, MA 02139, USA. Everyone is permitted to copy and distribute +verbatim copies of this license document, but changing it is not allowed. + +Preamble + +The licenses for most software are designed to take away your freedom to share +and change it. By contrast, the GNU General Public License is intended to +guarantee your freedom to share and change free software--to make sure the +software is free for all its users. This General Public License applies to most of +the Free Software Foundation's software and to any other program whose +authors commit to using it. (Some other Free Software Foundation software is +covered by the GNU Library General Public License instead.) You can apply it to +your programs, too. + +When we speak of free software, we are referring to freedom, not price. Our +General Public Licenses are designed to make sure that you have the freedom +to distribute copies of free software (and charge for this service if you wish), that +you receive source code or can get it if you want it, that you can change the +software or use pieces of it in new free programs; and that you know you can do +these things. + +To protect your rights, we need to make restrictions that forbid anyone to deny +you these rights or to ask you to surrender the rights. These restrictions +translate to certain responsibilities for you if you distribute copies of the +software, or if you modify it. + +For example, if you distribute copies of such a program, whether gratis or for a +fee, you must give the recipients all the rights that you have. You must make +sure that they, too, receive or can get the source code. And you must show +them these terms so they know their rights. + +We protect your rights with two steps: (1) copyright the software, and (2) offer +you this license which gives you legal permission to copy, distribute and/or +modify the software. + +Also, for each author's protection and ours, we want to make certain that +everyone understands that there is no warranty for this free software. If the +software is modified by someone else and passed on, we want its recipients to +know that what they have is not the original, so that any problems introduced by +others will not reflect on the original authors' reputations. + +Finally, any free program is threatened constantly by software patents. We wish +to avoid the danger that redistributors of a free program will individually obtain +patent licenses, in effect making the program proprietary. To prevent this, we +have made it clear that any patent must be licensed for everyone's free use or +not licensed at all. + +The precise terms and conditions for copying, distribution and modification +follow. + +GNU GENERAL PUBLIC LICENSE +TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND +MODIFICATION + +0. This License applies to any program or other work which contains a notice +placed by the copyright holder saying it may be distributed under the terms of +this General Public License. The "Program", below, refers to any such program +or work, and a "work based on the Program" means either the Program or any +derivative work under copyright law: that is to say, a work containing the +Program or a portion of it, either verbatim or with modifications and/or translated +into another language. (Hereinafter, translation is included without limitation in +the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not covered by +this License; they are outside its scope. The act of running the Program is not +restricted, and the output from the Program is covered only if its contents +constitute a work based on the Program (independent of having been made by +running the Program). Whether that is true depends on what the Program does. + +1. You may copy and distribute verbatim copies of the Program's source code as +you receive it, in any medium, provided that you conspicuously and appropriately +publish on each copy an appropriate copyright notice and disclaimer of warranty; +keep intact all the notices that refer to this License and to the absence of any +warranty; and give any other recipients of the Program a copy of this License +along with the Program. + +You may charge a fee for the physical act of transferring a copy, and you may at +your option offer warranty protection in exchange for a fee. + +2. You may modify your copy or copies of the Program or any portion of it, thus +forming a work based on the Program, and copy and distribute such +modifications or work under the terms of Section 1 above, provided that you also +meet all of these conditions: + +a) You must cause the modified files to carry prominent notices stating that you +changed the files and the date of any change. + +b) You must cause any work that you distribute or publish, that in whole or in +part contains or is derived from the Program or any part thereof, to be licensed +as a whole at no charge to all third parties under the terms of this License. + +c) If the modified program normally reads commands interactively when run, you +must cause it, when started running for such interactive use in the most ordinary +way, to print or display an announcement including an appropriate copyright +notice and a notice that there is no warranty (or else, saying that you provide a +warranty) and that users may redistribute the program under these conditions, +and telling the user how to view a copy of this License. (Exception: if the +Program itself is interactive but does not normally print such an announcement, +your work based on the Program is not required to print an announcement.) + +These requirements apply to the modified work as a whole. If identifiable +sections of that work are not derived from the Program, and can be reasonably +considered independent and separate works in themselves, then this License, +and its terms, do not apply to those sections when you distribute them as +separate works. But when you distribute the same sections as part of a whole +which is a work based on the Program, the distribution of the whole must be on +the terms of this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest your rights to +work written entirely by you; rather, the intent is to exercise the right to control +the distribution of derivative or collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program with the +Program (or with a work based on the Program) on a volume of a storage or +distribution medium does not bring the other work under the scope of this +License. + +3. You may copy and distribute the Program (or a work based on it, under +Section 2) in object code or executable form under the terms of Sections 1 and 2 +above provided that you also do one of the following: + +a) Accompany it with the complete corresponding machine-readable source +code, which must be distributed under the terms of Sections 1 and 2 above on a +medium customarily used for software interchange; or, + +b) Accompany it with a written offer, valid for at least three years, to give any +third party, for a charge no more than your cost of physically performing source +distribution, a complete machine-readable copy of the corresponding source +code, to be distributed under the terms of Sections 1 and 2 above on a medium +customarily used for software interchange; or, + +c) Accompany it with the information you received as to the offer to distribute +corresponding source code. (This alternative is allowed only for noncommercial +distribution and only if you received the program in object code or executable +form with such an offer, in accord with Subsection b above.) + +The source code for a work means the preferred form of the work for making +modifications to it. For an executable work, complete source code means all the +source code for all modules it contains, plus any associated interface definition +files, plus the scripts used to control compilation and installation of the +executable. However, as a special exception, the source code distributed need +not include anything that is normally distributed (in either source or binary form) +with the major components (compiler, kernel, and so on) of the operating system +on which the executable runs, unless that component itself accompanies the +executable. + +If distribution of executable or object code is made by offering access to copy +from a designated place, then offering equivalent access to copy the source +code from the same place counts as distribution of the source code, even though +third parties are not compelled to copy the source along with the object code. + +4. You may not copy, modify, sublicense, or distribute the Program except as +expressly provided under this License. Any attempt otherwise to copy, modify, +sublicense or distribute the Program is void, and will automatically terminate +your rights under this License. However, parties who have received copies, or +rights, from you under this License will not have their licenses terminated so long +as such parties remain in full compliance. + +5. You are not required to accept this License, since you have not signed it. +However, nothing else grants you permission to modify or distribute the Program +or its derivative works. These actions are prohibited by law if you do not accept +this License. Therefore, by modifying or distributing the Program (or any work +based on the Program), you indicate your acceptance of this License to do so, +and all its terms and conditions for copying, distributing or modifying the +Program or works based on it. + +6. Each time you redistribute the Program (or any work based on the Program), +the recipient automatically receives a license from the original licensor to copy, +distribute or modify the Program subject to these terms and conditions. You +may not impose any further restrictions on the recipients' exercise of the rights +granted herein. You are not responsible for enforcing compliance by third parties +to this License. + +7. If, as a consequence of a court judgment or allegation of patent infringement +or for any other reason (not limited to patent issues), conditions are imposed on +you (whether by court order, agreement or otherwise) that contradict the +conditions of this License, they do not excuse you from the conditions of this +License. If you cannot distribute so as to satisfy simultaneously your obligations +under this License and any other pertinent obligations, then as a consequence +you may not distribute the Program at all. For example, if a patent license would +not permit royalty-free redistribution of the Program by all those who receive +copies directly or indirectly through you, then the only way you could satisfy +both it and this License would be to refrain entirely from distribution of the +Program. + +If any portion of this section is held invalid or unenforceable under any particular +circumstance, the balance of the section is intended to apply and the section as +a whole is intended to apply in other circumstances. + +It is not the purpose of this section to induce you to infringe any patents or other +property right claims or to contest validity of any such claims; this section has +the sole purpose of protecting the integrity of the free software distribution +system, which is implemented by public license practices. Many people have +made generous contributions to the wide range of software distributed through +that system in reliance on consistent application of that system; it is up to the +author/donor to decide if he or she is willing to distribute software through any +other system and a licensee cannot impose that choice. + +This section is intended to make thoroughly clear what is believed to be a +consequence of the rest of this License. + +8. If the distribution and/or use of the Program is restricted in certain countries +either by patents or by copyrighted interfaces, the original copyright holder who +places the Program under this License may add an explicit geographical +distribution limitation excluding those countries, so that distribution is permitted +only in or among countries not thus excluded. In such case, this License +incorporates the limitation as if written in the body of this License. + +9. The Free Software Foundation may publish revised and/or new versions of the +General Public License from time to time. Such new versions will be similar in +spirit to the present version, but may differ in detail to address new problems or +concerns. + +Each version is given a distinguishing version number. If the Program specifies a +version number of this License which applies to it and "any later version", you +have the option of following the terms and conditions either of that version or of +any later version published by the Free Software Foundation. If the Program does +not specify a version number of this License, you may choose any version ever +published by the Free Software Foundation. + +10. If you wish to incorporate parts of the Program into other free programs +whose distribution conditions are different, write to the author to ask for +permission. For software which is copyrighted by the Free Software Foundation, +write to the Free Software Foundation; we sometimes make exceptions for this. +Our decision will be guided by the two goals of preserving the free status of all +derivatives of our free software and of promoting the sharing and reuse of +software generally. + +NO WARRANTY + +11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS +NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE +COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM +"AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR +IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE +ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE +PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, +YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR +CORRECTION. + +12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED +TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY +WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS +PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES +ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM +(INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING +RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY +OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS +BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + +END OF TERMS AND CONDITIONS + + +--------------------------------------------------------------------------- + +The Artistic License + +Preamble + +The intent of this document is to state the conditions under which a Package +may be copied, such that the Copyright Holder maintains some semblance of +artistic control over the development of the package, while giving the users of the +package the right to use and distribute the Package in a more-or-less customary +fashion, plus the right to make reasonable modifications. + +Definitions: + +- "Package" refers to the collection of files distributed by the Copyright + Holder, and derivatives of that collection of files created through textual + modification. +- "Standard Version" refers to such a Package if it has not been modified, + or has been modified in accordance with the wishes of the Copyright + Holder. +- "Copyright Holder" is whoever is named in the copyright or copyrights for + the package. +- "You" is you, if you're thinking about copying or distributing this Package. +- "Reasonable copying fee" is whatever you can justify on the basis of + media cost, duplication charges, time of people involved, and so on. (You + will not be required to justify it to the Copyright Holder, but only to the + computing community at large as a market that must bear the fee.) +- "Freely Available" means that no fee is charged for the item itself, though + there may be fees involved in handling the item. It also means that + recipients of the item may redistribute it under the same conditions they + received it. + +1. You may make and give away verbatim copies of the source form of the +Standard Version of this Package without restriction, provided that you duplicate +all of the original copyright notices and associated disclaimers. + +2. You may apply bug fixes, portability fixes and other modifications derived from +the Public Domain or from the Copyright Holder. A Package modified in such a +way shall still be considered the Standard Version. + +3. You may otherwise modify your copy of this Package in any way, provided +that you insert a prominent notice in each changed file stating how and when +you changed that file, and provided that you do at least ONE of the following: + + a) place your modifications in the Public Domain or otherwise + make them Freely Available, such as by posting said modifications + to Usenet or an equivalent medium, or placing the modifications on + a major archive site such as ftp.uu.net, or by allowing the + Copyright Holder to include your modifications in the Standard + Version of the Package. + + b) use the modified Package only within your corporation or + organization. + + c) rename any non-standard executables so the names do not + conflict with standard executables, which must also be provided, + and provide a separate manual page for each non-standard + executable that clearly documents how it differs from the Standard + Version. + + d) make other distribution arrangements with the Copyright Holder. + +4. You may distribute the programs of this Package in object code or executable +form, provided that you do at least ONE of the following: + + a) distribute a Standard Version of the executables and library + files, together with instructions (in the manual page or equivalent) + on where to get the Standard Version. + + b) accompany the distribution with the machine-readable source of + the Package with your modifications. + + c) accompany any non-standard executables with their + corresponding Standard Version executables, giving the + non-standard executables non-standard names, and clearly + documenting the differences in manual pages (or equivalent), + together with instructions on where to get the Standard Version. + + d) make other distribution arrangements with the Copyright Holder. + +5. You may charge a reasonable copying fee for any distribution of this Package. +You may charge any fee you choose for support of this Package. You may not +charge a fee for this Package itself. However, you may distribute this Package in +aggregate with other (possibly commercial) programs as part of a larger +(possibly commercial) software distribution provided that you do not advertise +this Package as a product of your own. + +6. The scripts and library files supplied as input to or produced as output from +the programs of this Package do not automatically fall under the copyright of this +Package, but belong to whomever generated them, and may be sold +commercially, and may be aggregated with this Package. + +7. C or perl subroutines supplied by you and linked into this Package shall not +be considered part of this Package. + +8. Aggregation of this Package with a commercial distribution is always permitted +provided that the use of this Package is embedded; that is, when no overt attempt +is made to make this Package's interfaces visible to the end user of the +commercial distribution. Such use shall not be construed as a distribution of +this Package. + +9. The name of the Copyright Holder may not be used to endorse or promote +products derived from this software without specific prior written permission. + +10. THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR +IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED +WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR +PURPOSE. + +The End + + diff --git a/MANIFEST b/MANIFEST new file mode 100644 index 0000000..e9df526 --- /dev/null +++ b/MANIFEST @@ -0,0 +1,15 @@ +Build.PL +Changes +CREDITS +lib/DateTime/Format/HTTP.pm +LICENSE +Makefile.PL +MANIFEST This list of files +META.json +META.yml +README +t/basic.t +t/date.t +t/pod-coverage.t +t/pod.t +t/time2str.t diff --git a/META.json b/META.json new file mode 100644 index 0000000..0ea0c89 --- /dev/null +++ b/META.json @@ -0,0 +1,43 @@ +{ + "abstract" : "Date conversion routines", + "author" : [ + "Christiaan Kras " + ], + "dynamic_config" : 1, + "generated_by" : "Module::Build version 0.38, CPAN::Meta::Converter version 2.133380", + "license" : [ + "perl_5" + ], + "meta-spec" : { + "url" : "http://search.cpan.org/perldoc?CPAN::Meta::Spec", + "version" : "2" + }, + "name" : "DateTime-Format-HTTP", + "prereqs" : { + "configure" : { + "requires" : { + "Module::Build" : "0.38" + } + }, + "runtime" : { + "requires" : { + "DateTime" : "0.17", + "HTTP::Date" : "1.44", + "Test::More" : "0.47" + } + } + }, + "provides" : { + "DateTime::Format::HTTP" : { + "file" : "lib/DateTime/Format/HTTP.pm", + "version" : "0.42" + } + }, + "release_status" : "stable", + "resources" : { + "license" : [ + "http://dev.perl.org/licenses/" + ] + }, + "version" : "0.42" +} diff --git a/META.yml b/META.yml new file mode 100644 index 0000000..1c87abd --- /dev/null +++ b/META.yml @@ -0,0 +1,25 @@ +--- +abstract: Date conversion routines +author: + - 'Christiaan Kras ' +build_requires: {} +configure_requires: + Module::Build: 0.38 +dynamic_config: 1 +generated_by: 'Module::Build version 0.38, CPAN::Meta::Converter version 2.133380' +license: perl +meta-spec: + url: http://module-build.sourceforge.net/META-spec-v1.4.html + version: 1.4 +name: DateTime-Format-HTTP +provides: + DateTime::Format::HTTP: + file: lib/DateTime/Format/HTTP.pm + version: 0.42 +requires: + DateTime: 0.17 + HTTP::Date: 1.44 + Test::More: 0.47 +resources: + license: http://dev.perl.org/licenses/ +version: 0.42 diff --git a/Makefile.PL b/Makefile.PL new file mode 100644 index 0000000..eb88ba0 --- /dev/null +++ b/Makefile.PL @@ -0,0 +1,16 @@ +# Note: this file was auto-generated by Module::Build::Compat version 0.3800 +use ExtUtils::MakeMaker; +WriteMakefile +( + 'PL_FILES' => {}, + 'INSTALLDIRS' => 'site', + 'NAME' => 'DateTime::Format::HTTP', + 'EXE_FILES' => [], + 'VERSION_FROM' => 'lib/DateTime/Format/HTTP.pm', + 'PREREQ_PM' => { + 'Test::More' => '0.47', + 'DateTime' => '0.17', + 'HTTP::Date' => '1.44' + } +) +; diff --git a/README b/README new file mode 100644 index 0000000..a24baa3 --- /dev/null +++ b/README @@ -0,0 +1,134 @@ +NAME + DateTime::Format::HTTP - Date conversion routines + +SYNOPSIS + use DateTime::Format::HTTP; + + my $class = 'DateTime::Format::HTTP'; + $string = $class->format_datetime($dt); # Format as GMT ASCII time + $time = $class->parse_datetime($string); # convert ASCII date to machine time + +DESCRIPTION + This module provides functions that deal the date formats used by the + HTTP protocol (and then some more). + +METHODS + parse_datetime( $str [, $zone] ) + The parse_datetime() function converts a string to machine time. It + throws an error if the format of $str is unrecognized, or the time is + outside the representable range. The time formats recognized are listed + below. + + The function also takes an optional second argument that specifies the + default time zone to use when converting the date. This parameter is + ignored if the zone is found in the date string itself. If this + parameter is missing, and the date string format does not contain any + zone specification, then the floating time zone is used. + + The zone should be one that is recognized by DateTime::TimeZone. + + Actual parsing is done with the HTTP::Date module. At the time of + writing it supports the formats listed next. Consult that module's + documentation in case the list has been changed. + + "Wed, 09 Feb 1994 22:23:32 GMT" -- HTTP format + "Thu Feb 3 17:03:55 GMT 1994" -- ctime(3) format + "Thu Feb 3 00:00:00 1994", -- ANSI C asctime() format + "Tuesday, 08-Feb-94 14:15:29 GMT" -- old rfc850 HTTP format + "Tuesday, 08-Feb-1994 14:15:29 GMT" -- broken rfc850 HTTP format + + "03/Feb/1994:17:03:55 -0700" -- common logfile format + "09 Feb 1994 22:23:32 GMT" -- HTTP format (no weekday) + "08-Feb-94 14:15:29 GMT" -- rfc850 format (no weekday) + "08-Feb-1994 14:15:29 GMT" -- broken rfc850 format (no weekday) + + "1994-02-03 14:15:29 -0100" -- ISO 8601 format + "1994-02-03 14:15:29" -- zone is optional + "1994-02-03" -- only date + "1994-02-03T14:15:29" -- Use T as separator + "19940203T141529Z" -- ISO 8601 compact format + "19940203" -- only date + + "08-Feb-94" -- old rfc850 HTTP format (no weekday, no time) + "08-Feb-1994" -- broken rfc850 HTTP format (no weekday, no time) + "09 Feb 1994" -- proposed new HTTP format (no weekday, no time) + "03/Feb/1994" -- common logfile format (no time, no offset) + + "Feb 3 1994" -- Unix 'ls -l' format + "Feb 3 17:03" -- Unix 'ls -l' format + + "11-15-96 03:52PM" -- Windows 'dir' format + + The parser ignores leading and trailing whitespace. It also allow the + seconds to be missing and the month to be numerical in most formats. + + If the year is missing, then we assume that the date is the first + matching date *before* current month. If the year is given with only 2 + digits, then parse_date() will select the century that makes the year + closest to the current date. + + format_datetime() + The "format_datetime()" method converts a DateTime to a string. If the + function is called without an argument, it will use the current time. + + The string returned is in the format preferred for the HTTP protocol. + This is a fixed length subset of the format defined by RFC 1123, + represented in Universal Time (GMT). An example of a time stamp in this + format is: + + Sun, 06 Nov 1994 08:49:37 GMT + + format_iso( [$time] ) + Same as format_datetime(), but returns a "YYYY-MM-DD hh:mm:ss"-formatted + string representing time in the local time zone. It is strongly + recommended that you use "format_isoz" or "format_datetime" instead (as + these provide time zone indication). + + format_isoz( [$dt] ) + Same as format_iso(), but returns a "YYYY-MM-DD hh:mm:ssZ"-formatted + string representing Universal Time. + +THANKS + Gisle Aas (GAAS) for writing HTTP::Date. + + Iain, for never quite finishing "HTTP::Date::XS". + +SUPPORT + Support for this module is provided via the datetime@perl.org email + list. See http://lists.perl.org/ for more details. + + Alternatively, log them via the CPAN RT system via the web or email: + + http://rt.cpan.org/NoAuth/ReportBug.html?Queue=DateTime%3A%3AFormat%3A%3AHTTP + bug-datetime-format-http@rt.cpan.org + + This makes it much easier for me to track things and thus means your + problem is less likely to be neglected. + +LICENCE AND COPYRIGHT + Copyright Iain Truskett, 2003. All rights reserved. Sections of the + documentation Gisle Aas, 1995-1999. Changes since version 0.35 copyright + David Rolsky, 2004. + + This library is free software; you can redistribute it and/or modify it + under the same terms as Perl itself, either Perl version 5.000 or, at + your option, any later version of Perl 5 you may have available. + + The full text of the licences can be found in the Artistic and COPYING + files included with this module, or in perlartistic and perlgpl as + supplied with Perl 5.8.1 and later. + +AUTHOR + Originally written by Iain Truskett , who died on + December 29, 2003. + + Maintained by Dave Rolsky and Christiaan Kras + + +SEE ALSO + "datetime@perl.org" mailing list. + + http://datetime.perl.org/ + + perl, DateTime, HTTP::Date, DateTime::TimeZone. + diff --git a/SPECS/DateTime-Format-HTTP-0.42.tar.gz b/SPECS/DateTime-Format-HTTP-0.42.tar.gz new file mode 100644 index 0000000..99d5820 Binary files /dev/null and b/SPECS/DateTime-Format-HTTP-0.42.tar.gz differ diff --git a/SPECS/perl-DateTime-Format-HTTP.spec b/SPECS/perl-DateTime-Format-HTTP.spec new file mode 100644 index 0000000..e4ad4fe --- /dev/null +++ b/SPECS/perl-DateTime-Format-HTTP.spec @@ -0,0 +1,161 @@ +Name: perl-DateTime-Format-HTTP +Version: 0.42 +Release: 9%{?dist} +Summary: HTTP protocol date conversion routines +Group: Development/Libraries +License: GPL+ or Artistic +URL: http://search.cpan.org/dist/DateTime-Format-HTTP +Source0: http://search.cpan.org/CPAN/authors/id/C/CK/CKRAS/DateTime-Format-HTTP-%{version}.tar.gz +BuildArch: noarch +# Build +BuildRequires: perl-interpreter +BuildRequires: perl-generators +BuildRequires: perl(ExtUtils::MakeMaker) +# Runtime +BuildRequires: perl(DateTime) >= 0.17 +BuildRequires: perl(HTTP::Date) => 1.44 +BuildRequires: perl(strict) +BuildRequires: perl(vars) +BuildRequires: perl(warnings) +# Tests only +BuildRequires: perl(lib) +BuildRequires: perl(Test::More) >= 0.47 +Requires: perl(:MODULE_COMPAT_%(eval "$(perl -V:version)"; echo $version)) +Requires: perl(DateTime) >= 0.17 +Requires: perl(HTTP::Date) >= 1.44 + +%global __requires_exclude %{?__requires_exclude|%__requires_exclude|}^perl\\(DateTime\\)$ +%global __requires_exclude %{?__requires_exclude|%__requires_exclude|}^perl\\(HTTP::Date\\)$ + +%description +This module provides functions that deal with the date formats used by the +HTTP protocol (and then some). + +%prep +%setup -q -n DateTime-Format-HTTP-%{version} +sed -i -e 's/\r//' LICENSE README Changes CREDITS + +%build +perl Makefile.PL INSTALLDIRS=vendor NO_PACKLIST=1 +make %{?_smp_mflags} + +%install +make pure_install DESTDIR=%{buildroot} +%{_fixperms} %{buildroot}/* + +%check +make test + +%files +%doc LICENSE Changes CREDITS README +%{perl_vendorlib}/* +%{_mandir}/man3/*.3* + + +%changelog +* Thu Feb 08 2018 Fedora Release Engineering - 0.42-9 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_28_Mass_Rebuild + +* Thu Jul 27 2017 Fedora Release Engineering - 0.42-8 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild + +* Tue Jun 06 2017 Jitka Plesnikova - 0.42-7 +- Perl 5.26 rebuild + +* Sat Feb 11 2017 Fedora Release Engineering - 0.42-6 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_26_Mass_Rebuild + +* Mon May 16 2016 Jitka Plesnikova - 0.42-5 +- Perl 5.24 rebuild + +* Thu Feb 04 2016 Fedora Release Engineering - 0.42-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_24_Mass_Rebuild + +* Thu Jun 18 2015 Fedora Release Engineering - 0.42-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_23_Mass_Rebuild + +* Sat Jun 06 2015 Jitka Plesnikova - 0.42-2 +- Perl 5.22 rebuild + +* Fri Nov 14 2014 Petr Ĺ abata - 0.42-1 +- 0.42 bump + +* Fri Aug 29 2014 Jitka Plesnikova - 0.40-12 +- Perl 5.20 rebuild + +* Sat Jun 07 2014 Fedora Release Engineering - 0.40-11 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_21_Mass_Rebuild + +* Sat Aug 03 2013 Fedora Release Engineering - 0.40-10 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_20_Mass_Rebuild + +* Wed Jul 31 2013 Petr Pisar - 0.40-9 +- Perl 5.18 rebuild + +* Thu Feb 14 2013 Fedora Release Engineering - 0.40-8 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_19_Mass_Rebuild + +* Fri Jul 20 2012 Fedora Release Engineering - 0.40-7 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_18_Mass_Rebuild + +* Wed Jun 20 2012 Petr Pisar - 0.40-6 +- Perl 5.16 rebuild + +* Fri Jan 13 2012 Fedora Release Engineering - 0.40-5 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_17_Mass_Rebuild + +* Thu Jul 21 2011 Petr Sabata - 0.40-4 +- Perl mass rebuild + +* Tue Jul 19 2011 Petr Sabata - 0.40-3 +- Perl mass rebuild + +* Tue Feb 08 2011 Fedora Release Engineering - 0.40-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_15_Mass_Rebuild + +* Sat Dec 18 2010 Iain Arnell 0.40-1 +- update to latest upstream version +- clean up spec for modern rpmbuild +- PERL_INSTALL_ROOT -> DESTDIR +- fix up crlf in docs + +* Thu Dec 16 2010 Marcela Maslanova - 0.38-6 +- 661697 rebuild for fixing problems with vendorach/lib + +* Fri Apr 30 2010 Marcela Maslanova - 0.38-5 +- Mass rebuild with perl-5.12.0 + +* Mon Dec 7 2009 Stepan Kasal - 0.38-4 +- rebuild against perl 5.10.1 + +* Sat Jul 25 2009 Fedora Release Engineering - 0.38-3 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_12_Mass_Rebuild + +* Sun May 17 2009 Chris Weyl 0.38-2 +- rearrange the files in doc as the tarball has changed contents + +* Sun May 17 2009 Chris Weyl 0.38-1 +- auto-update to 0.38 (by cpan-spec-update 0.01) + +* Thu Feb 26 2009 Fedora Release Engineering - 0.37-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_11_Mass_Rebuild + +* Tue Mar 4 2008 Tom "spot" Callaway 0.37-3 +- rebuild for new perl + +* Thu Aug 31 2006 Chris Weyl 0.37-2 +- bump for mass rebuild + +* Wed Aug 09 2006 Chris Weyl 0.37-1 +- update to 0.37 +- nix the SIGNATURE checking bits of the spec file as the author has dropped + it from this version + +* Sun Aug 06 2006 Chris Weyl 0.36-3 +- bump for build & release + +* Sun Aug 06 2006 Chris Weyl 0.36-2 +- add missing buildrequires: perl(File::Find::Rule) + +* Fri Aug 04 2006 Chris Weyl 0.36-1 +- Initial spec file for F-E diff --git a/lib/DateTime/Format/HTTP.pm b/lib/DateTime/Format/HTTP.pm new file mode 100644 index 0000000..13130fb --- /dev/null +++ b/lib/DateTime/Format/HTTP.pm @@ -0,0 +1,254 @@ +package DateTime::Format::HTTP; +use strict; +use warnings; +use vars qw( $VERSION ); + +$VERSION = '0.42'; + +use DateTime; +use HTTP::Date qw(); + +use vars qw( @MoY %MoY); +@MoY = qw(Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec); +@MoY{@MoY} = (1..12); + +sub format_datetime +{ + my ($self, $dt) = @_; + $dt = DateTime->now unless defined $dt; + $dt = $dt->clone->set_time_zone( 'GMT' ); + return $dt->strftime( "%a, %d %b %Y %H:%M:%S GMT" ); +} + + +sub parse_datetime +{ + my ($self, $str, $zone) = @_; + local $_; + die "No input string!" unless defined $str; + + # fast exit for strictly conforming string + if ($str =~ /^ + [SMTWF][a-z][a-z], + \ (\d\d) + \ ([JFMAJSOND][a-z][a-z]) + \ (\d\d\d\d) + \ (\d\d):(\d\d):(\d\d) + \ GMT$/x) { + return DateTime->new( + day => $1, + month => $MoY{$2}, + year => $3, + hour => $4, + minute => $5, + second => $6, + time_zone => 'GMT' + ); + } + + my %d = $self->_parse_date($str); + + unless (defined $d{time_zone}) + { + $d{time_zone} = defined $zone ? $zone : 'floating'; + } + + my $frac = $d{second}; $frac -= ($d{second} = int($frac)); + my $nano = 1_000_000_000 * $frac; $d{nanosecond} = int($nano + 0.5); + return DateTime->new( %d ); +} + + +sub _parse_date +{ + my ($self, $str) = @_; + my @fields = qw( year month day hour minute second time_zone ); + my %d; + my @values = HTTP::Date::parse_date( $str ); + die "Could not parse date [$str]\n" unless @values; + @d{@fields} = @values; + + if (defined $d{time_zone}) { + $d{time_zone} = "GMT" if $d{time_zone} =~ /^(Z|GMT|UTC?|[-+]?0+)$/ix; + } + + return %d; +} + + +sub format_iso +{ + my ($self, $dt) = @_; + $dt = DateTime->now unless defined $dt; + sprintf("%04d-%02d-%02d %02d:%02d:%02d", + $dt->year, $dt->month, $dt->day, + $dt->hour, $dt->min, $dt->sec + ); +} + + +sub format_isoz +{ + my ($self, $dt) = @_; + $dt = DateTime->now unless defined $dt; + $dt = $dt->clone->set_time_zone( 'UTC' ); + sprintf("%04d-%02d-%02d %02d:%02d:%02dZ", + $dt->year, $dt->month, $dt->day, + $dt->hour, $dt->min, $dt->sec + ); +} + +1; + + +__END__ + +=head1 NAME + +DateTime::Format::HTTP - Date conversion routines + +=head1 SYNOPSIS + + use DateTime::Format::HTTP; + + my $class = 'DateTime::Format::HTTP'; + $string = $class->format_datetime($dt); # Format as GMT ASCII time + $time = $class->parse_datetime($string); # convert ASCII date to machine time + +=head1 DESCRIPTION + +This module provides functions that deal the date formats used by the +HTTP protocol (and then some more). + +=head1 METHODS + +=head2 parse_datetime( $str [, $zone] ) + +The parse_datetime() function converts a string to machine time. It throws +an error if the format of $str is unrecognized, or the time is outside +the representable range. The time formats recognized are listed below. + +The function also takes an optional second argument that specifies the +default time zone to use when converting the date. This parameter is +ignored if the zone is found in the date string itself. If this +parameter is missing, and the date string format does not contain +any zone specification, then the floating time zone is used. + +The zone should be one that is recognized by L. + +Actual parsing is done with the L module. At the time of +writing it supports the formats listed next. Consult that module's +documentation in case the list has been changed. + + "Wed, 09 Feb 1994 22:23:32 GMT" -- HTTP format + "Thu Feb 3 17:03:55 GMT 1994" -- ctime(3) format + "Thu Feb 3 00:00:00 1994", -- ANSI C asctime() format + "Tuesday, 08-Feb-94 14:15:29 GMT" -- old rfc850 HTTP format + "Tuesday, 08-Feb-1994 14:15:29 GMT" -- broken rfc850 HTTP format + + "03/Feb/1994:17:03:55 -0700" -- common logfile format + "09 Feb 1994 22:23:32 GMT" -- HTTP format (no weekday) + "08-Feb-94 14:15:29 GMT" -- rfc850 format (no weekday) + "08-Feb-1994 14:15:29 GMT" -- broken rfc850 format (no weekday) + + "1994-02-03 14:15:29 -0100" -- ISO 8601 format + "1994-02-03 14:15:29" -- zone is optional + "1994-02-03" -- only date + "1994-02-03T14:15:29" -- Use T as separator + "19940203T141529Z" -- ISO 8601 compact format + "19940203" -- only date + + "08-Feb-94" -- old rfc850 HTTP format (no weekday, no time) + "08-Feb-1994" -- broken rfc850 HTTP format (no weekday, no time) + "09 Feb 1994" -- proposed new HTTP format (no weekday, no time) + "03/Feb/1994" -- common logfile format (no time, no offset) + + "Feb 3 1994" -- Unix 'ls -l' format + "Feb 3 17:03" -- Unix 'ls -l' format + + "11-15-96 03:52PM" -- Windows 'dir' format + +The parser ignores leading and trailing whitespace. It also allow the +seconds to be missing and the month to be numerical in most formats. + +If the year is missing, then we assume that the date is the first +matching date I current month. If the year is given with only +2 digits, then parse_date() will select the century that makes the +year closest to the current date. + +=head2 format_datetime() + +The C method converts a L to a string. If +the function is called without an argument, it will use the current +time. + +The string returned is in the format preferred for the HTTP protocol. +This is a fixed length subset of the format defined by RFC 1123, +represented in Universal Time (GMT). An example of a time stamp +in this format is: + + Sun, 06 Nov 1994 08:49:37 GMT + +=head2 format_iso( [$time] ) + +Same as format_datetime(), but returns a "YYYY-MM-DD hh:mm:ss"-formatted +string representing time in the local time zone. It is B +recommended that you use C or C instead +(as these provide time zone indication). + +=head2 format_isoz( [$dt] ) + +Same as format_iso(), but returns a "YYYY-MM-DD hh:mm:ssZ"-formatted +string representing Universal Time. + +=head1 THANKS + +Gisle Aas (GAAS) for writing L. + +Iain, for never quite finishing C. + +=head1 SUPPORT + +Support for this module is provided via the datetime@perl.org email +list. See http://lists.perl.org/ for more details. + +Alternatively, log them via the CPAN RT system via the web or email: + + http://rt.cpan.org/NoAuth/ReportBug.html?Queue=DateTime%3A%3AFormat%3A%3AHTTP + bug-datetime-format-http@rt.cpan.org + +This makes it much easier for me to track things and thus means +your problem is less likely to be neglected. + +=head1 LICENCE AND COPYRIGHT + +Copyright Iain Truskett, 2003. All rights reserved. +Sections of the documentation Gisle Aas, 1995-1999. +Changes since version 0.35 copyright David Rolsky, 2004. + +This library is free software; you can redistribute it and/or modify +it under the same terms as Perl itself, either Perl version 5.000 or, +at your option, any later version of Perl 5 you may have available. + +The full text of the licences can be found in the F and +F files included with this module, or in L and +L as supplied with Perl 5.8.1 and later. + + +=head1 AUTHOR + +Originally written by Iain Truskett , who died on +December 29, 2003. + +Maintained by Dave Rolsky and Christiaan Kras + +=head1 SEE ALSO + +C mailing list. + +http://datetime.perl.org/ + +L, L, L, L. + +=cut + diff --git a/t/basic.t b/t/basic.t new file mode 100644 index 0000000..57d46ad --- /dev/null +++ b/t/basic.t @@ -0,0 +1,11 @@ +#!/usr/bin/perl -w +use strict; +use lib 'inc'; +use Test::More tests => 2; + +BEGIN { + use_ok 'DateTime::Format::HTTP'; +} + +pass("All done"); + diff --git a/t/date.t b/t/date.t new file mode 100644 index 0000000..04dfca9 --- /dev/null +++ b/t/date.t @@ -0,0 +1,204 @@ +#!/usr/bin/perl -w +use strict; +use lib 'inc'; +use Test::More tests => 131; +use vars qw( $class ); + +BEGIN { + $class = 'DateTime::Format::HTTP'; + use_ok $class; +} + +require Time::Local if $^O eq "MacOS"; +my $offset = ($^O eq "MacOS") ? Time::Local::timegm(0,0,0,1,0,70) : 0; + +# test str2time for supported dates. Test cases with 2 digit year +# will probably break in year 2044. +my(@tests) = +( + + 'Thu, 03 Feb 1994 00:00:00 GMT', # proposed new HTTP format + 'Thursday, 03-Feb-94 00:00:00 GMT', # old rfc850 HTTP format + 'Thursday, 03-Feb-1994 00:00:00 GMT', # broken rfc850 HTTP format + + 'Thu Feb 3 00:00:00 GMT 1994', # ctime format + 'Thu Feb 3 00:00:00 1994', # same as ctime, except no TZ + + '03/Feb/1994:00:00:00 0000', # common logfile format + '03/Feb/1994:01:00:00 +0100', # common logfile format + '02/Feb/1994:23:00:00 -0100', # common logfile format + + '03 Feb 1994 00:00:00 GMT', # HTTP format (no weekday) + '03-Feb-94 00:00:00 GMT', # old rfc850 (no weekday) + '03-Feb-1994 00:00:00 GMT', # broken rfc850 (no weekday) + '03-Feb-1994 00:00 GMT', # broken rfc850 (no weekday, no seconds) + '03-Feb-1994 00:00', # VMS dir listing format + + '03-Feb-94', # old rfc850 HTTP format (no weekday, no time) + '03-Feb-1994', # broken rfc850 HTTP format (no weekday, no time) + '03 Feb 1994', # proposed new HTTP format (no weekday, no time) + '03/Feb/1994', # common logfile format (no time, no offset) + + #'Feb 3 00:00', # Unix 'ls -l' format (can't really test it here) + 'Feb 3 1994', # Unix 'ls -l' format + + "02-03-94 12:00AM", # Windows 'dir' format + + # ISO 8601 formats + '1994-02-03 00:00:00 +0000', + '1994-02-03', + '19940203', + '1994-02-03T00:00:00+0000', + '1994-02-02T23:00:00-0100', + '1994-02-02T23:00:00-01:00', + '1994-02-03T00:00:00 Z', + '19940203T000000Z', + '199402030000', + + # A few tests with extra space at various places + ' 03/Feb/1994 ', + ' 03 Feb 1994 0:00 ', +); + +{ + my $time = (760233600 + $offset); # assume broken POSIX counting of seconds + $time = DateTime->from_epoch( epoch => $time ); + + for (@tests) + { + my $t = $class->parse_datetime($_, /GMT/i ? () : ('GMT')); + my $t2 = $class->parse_datetime(lc($_) => 'GMT' ); + my $t3 = $class->parse_datetime(uc($_) => 'GMT' ); + + #diag "'$_' => $t"; + if ($t->epoch != $time->epoch ) + { + diag "difference is: ".($t->epoch - $time->epoch); + } + + is ( $t->epoch, $time->epoch, "str2time (1): $_" ); + is ( $t2->epoch, $time->epoch, "str2time (2): $_" ); + is ( $t3->epoch, $time->epoch, "str2time (3): $_" ); + } + + # test time2str + die "time2str failed" + unless $class->format_datetime($time) eq 'Thu, 03 Feb 1994 00:00:00 GMT'; +} + +{ + # test the 'ls -l' format with missing year$ + # round to nearest minute 3 days ago. + my $time = int((time - 3 * 24*60*60) /60)*60; + my ($min, $hr, $mday, $mon) = (gmtime $time)[1,2,3,4]; + $mon = (qw(Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec))[$mon]; + my $str = sprintf("$mon %02d %02d:%02d", $mday, $hr, $min); + my $t = $class->parse_datetime($str); + is( $t->epoch, $time ); #, "str2time ls -l: '$str' => $t ($time)\n"); +} + +for (undef, '', 'Garbage', + 'Mandag 16. September 1996', + '1980-00-01', + '1980-13-01', + '1980-01-00', + '1980-01-32', + '1980-01-01 25:00:00', + '1980-01-01 00:61:00', + ) +{ + my $desc = defined $_ ? "'$_'" : "undef"; + $desc .= ' does not parse'; + + my $ok = ! defined eval { $class->parse_datetime($_) }; + ok( $ok, $desc ); +} + +my $conv = sub { + my $str = shift; + $class->format_iso( $class->parse_datetime( $str ) ); +}; + +my $t; + +$t = $conv->("11-12-96 0:00AM"); +is($t => "1996-11-12 00:00:00", $t); + +$t = $conv->("11-12-96 12:00AM"); +is($t => "1996-11-12 00:00:00", $t); + +$t = $conv->("11-12-96 0:00PM"); +is($t => "1996-11-12 12:00:00", $t); + +$t = $conv->("11-12-96 12:00PM"); +is($t => "1996-11-12 12:00:00", $t); + +$t = $conv->("11-12-96 1:05AM"); +is($t => "1996-11-12 01:05:00", $t); + +$t = $conv->("11-12-96 12:05AM"); +is($t => "1996-11-12 00:05:00", $t); + +$t = $conv->("11-12-96 1:05PM"); +is($t => "1996-11-12 13:05:00", $t); + +$t = $conv->("11-12-96 12:05PM"); +is($t => "1996-11-12 12:05:00", $t); + +my $dt = $class->parse_datetime("2000-01-01 00:00:01.234"); +$t = $dt->epoch; +ok( + abs(($t - int($t)) - 0.234) > 0.000001, + "FRAC $t = ".$class->format_iso($dt) +); +is($dt->microsecond, 234_000, '.234s == 234_000us'); +is($dt->nanosecond, 234_000_000, '.234s == 234_000_000ns'); + +$dt = $class->parse_datetime("2010-06-26T15:14:33.400753"); +$t = $dt->epoch; +ok( + abs(($t - int($t)) - 0.400753) > 0.000001, + "FRAC $t = ".$class->format_iso($dt) +); +is($dt->microsecond, 400_753, '.400753s == 400_753us'); +is($dt->nanosecond, 400_753_000, '.400753s == 400_753_000ns'); + +for my $ns (qw(1 12 123 1234 499999999 500000000 500000001 999753123 999999999)) { + $dt = $class->parse_datetime(sprintf("2010-06-26T15:14:33.%09d", $ns)); + is($dt->nanosecond, $ns, ".${ns}s == ${ns}ns"); +} + +$a = $class->format_iso( ); +$b = $class->format_iso( DateTime->from_epoch( epoch => 500000 ) ); + +my $az = $class->format_isoz( ); +my $bz = $class->format_isoz( DateTime->from_epoch( epoch => 500000 ) ); + +for ($a, $b) { + like( $_ => qr/^\d{4}-\d\d-\d\d \d\d:\d\d:\d\d$/, "time2iso($_)" ); +} +for ($az, $bz) { + like( $_ => qr/^\d{4}-\d\d-\d\d \d\d:\d\d:\d\dZ$/, "time2isoz($_)" ); +} + +{ + # format_isoz must output date in UTC + my $eastern_date = DateTime->new( + year => 2010, + month => 10, + day => 21, + hour => 13, + minute => 8, + second => 23, + time_zone => 'America/New_York', + ); + + # Get the ISO "Z" format of the eastern zone date time + my $isoz = $class->format_isoz($eastern_date); + + # Get the actual UTC date time + my $utc = $eastern_date->clone->set_time_zone('UTC'); + + is($isoz, $class->format_isoz($utc), 'format_isoz converts to UTC time zone'); + is($eastern_date->time_zone->name, 'America/New_York', 'format_isoz does not modify input date\'s time zone'); +} diff --git a/t/pod-coverage.t b/t/pod-coverage.t new file mode 100644 index 0000000..2d1f47f --- /dev/null +++ b/t/pod-coverage.t @@ -0,0 +1,14 @@ +use strict; +use warnings; + +use Test::More; + + +plan skip_all => 'This test is only run for the module author' + unless -d '.svn' || $ENV{IS_MAINTAINER}; + +eval "use Test::Pod::Coverage 1.04"; +plan skip_all => "Test::Pod::Coverage 1.04 required for testing POD coverage" + if $@; + +all_pod_coverage_ok(); diff --git a/t/pod.t b/t/pod.t new file mode 100644 index 0000000..ef52fcb --- /dev/null +++ b/t/pod.t @@ -0,0 +1,13 @@ +use strict; +use warnings; + +use Test::More; + + +plan skip_all => 'This test is only run for the module author' + unless -d '.svn' || $ENV{IS_MAINTAINER}; + +eval "use Test::Pod 1.14"; +plan skip_all => "Test::Pod 1.14 required for testing POD" if $@; + +all_pod_files_ok(); diff --git a/t/time2str.t b/t/time2str.t new file mode 100644 index 0000000..e32242f --- /dev/null +++ b/t/time2str.t @@ -0,0 +1,26 @@ +#!/usr/bin/perl -w +use strict; +use lib 'inc'; +use vars qw( $class ); +use Test::More tests => 3; +use DateTime; + +BEGIN { + $class = 'DateTime::Format::HTTP'; + use_ok $class; +} + +require Time::Local if $^O eq "MacOS"; +my $offset = ($^O eq "MacOS") ? Time::Local::timegm(0,0,0,1,0,70) : 0; +my $time = (760233600 + $offset); # assume broken POSIX counting of seconds +$time = DateTime->from_epoch( epoch => $time ); + +# test time2str +{ + my $out = $class->format_datetime( $time ); + my $wanted = 'Thu, 03 Feb 1994 00:00:00 GMT'; + diag $out; + diag $wanted; + is ( $class->format_datetime($time) => $wanted, 'Basic' ); + ok( $class->format_datetime() => 'no param'); +}