Permalink
Browse files

0.01 - from module-started and dzil

  • Loading branch information...
0 parents commit 46ecb872176c5ea58bce4b3bae7bfbfed6443e94 @mfontani committed Jul 16, 2009
Showing with 236 additions and 0 deletions.
  1. +10 −0 .cvsignore
  2. +10 −0 .gitignore
  3. +5 −0 Changes
  4. +10 −0 dist.ini
  5. +107 −0 lib/Net/Mosso/CloudServers.pm
  6. +9 −0 t/00-load.t
  7. +55 −0 t/boilerplate.t
  8. +18 −0 t/pod-coverage.t
  9. +12 −0 t/pod.t
@@ -0,0 +1,10 @@
+blib*
+Makefile
+Makefile.old
+Build
+_build*
+pm_to_blib*
+*.tar.gz
+.lwpcookies
+Net-Mosso-CloudServers-*
+cover_db
@@ -0,0 +1,10 @@
+blib*
+Makefile
+Makefile.old
+Build
+_build*
+pm_to_blib*
+*.tar.gz
+.lwpcookies
+Net-Mosso-CloudServers-*
+cover_db
@@ -0,0 +1,5 @@
+Revision history for Net-Mosso-CloudServers
+
+0.01 2009-07-16 1841 BST
+ First version, released on an unsuspecting world.
+
@@ -0,0 +1,10 @@
+name = Net-Mosso-CloudServers
+version = 1.000
+author = Marco Fontani
+license = Perl_5
+copyright_holder = Marco Fontani
+
+[@Classic]
+
+[Prereq]
+Moose = 0.87
@@ -0,0 +1,107 @@
+package Net::Mosso::CloudServers;
+
+use warnings;
+use strict;
+
+=head1 NAME
+
+Net::Mosso::CloudServers - The great new Net::Mosso::CloudServers!
+
+=head1 VERSION
+
+Version 0.01
+
+=cut
+
+our $VERSION = '0.01';
+
+
+=head1 SYNOPSIS
+
+Quick summary of what the module does.
+
+Perhaps a little code snippet.
+
+ use Net::Mosso::CloudServers;
+
+ my $foo = Net::Mosso::CloudServers->new();
+ ...
+
+=head1 EXPORT
+
+A list of functions that can be exported. You can delete this section
+if you don't export anything, such as for a purely object-oriented module.
+
+=head1 FUNCTIONS
+
+=head2 function1
+
+=cut
+
+sub function1 {
+}
+
+=head2 function2
+
+=cut
+
+sub function2 {
+}
+
+=head1 AUTHOR
+
+Marco Fontani, C<< <mfontani at cpan.org> >>
+
+=head1 BUGS
+
+Please report any bugs or feature requests to C<bug-net-mosso-cloudservers at rt.cpan.org>, or through
+the web interface at L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Net-Mosso-CloudServers>. I will be notified, and then you'll
+automatically be notified of progress on your bug as I make changes.
+
+
+
+
+=head1 SUPPORT
+
+You can find documentation for this module with the perldoc command.
+
+ perldoc Net::Mosso::CloudServers
+
+
+You can also look for information at:
+
+=over 4
+
+=item * RT: CPAN's request tracker
+
+L<http://rt.cpan.org/NoAuth/Bugs.html?Dist=Net-Mosso-CloudServers>
+
+=item * AnnoCPAN: Annotated CPAN documentation
+
+L<http://annocpan.org/dist/Net-Mosso-CloudServers>
+
+=item * CPAN Ratings
+
+L<http://cpanratings.perl.org/d/Net-Mosso-CloudServers>
+
+=item * Search CPAN
+
+L<http://search.cpan.org/dist/Net-Mosso-CloudServers/>
+
+=back
+
+
+=head1 ACKNOWLEDGEMENTS
+
+
+=head1 COPYRIGHT & LICENSE
+
+Copyright 2009 Marco Fontani, all rights reserved.
+
+This program is free software; you can redistribute it and/or modify it
+under the same terms as Perl itself.
+
+
+=cut
+
+1; # End of Net::Mosso::CloudServers
@@ -0,0 +1,9 @@
+#!perl -T
+
+use Test::More tests => 1;
+
+BEGIN {
+ use_ok( 'Net::Mosso::CloudServers' );
+}
+
+diag( "Testing Net::Mosso::CloudServers $Net::Mosso::CloudServers::VERSION, Perl $], $^X" );
@@ -0,0 +1,55 @@
+#!perl -T
+
+use strict;
+use warnings;
+use Test::More tests => 3;
+
+sub not_in_file_ok {
+ my ($filename, %regex) = @_;
+ open( my $fh, '<', $filename )
+ or die "couldn't open $filename for reading: $!";
+
+ my %violated;
+
+ while (my $line = <$fh>) {
+ while (my ($desc, $regex) = each %regex) {
+ if ($line =~ $regex) {
+ push @{$violated{$desc}||=[]}, $.;
+ }
+ }
+ }
+
+ if (%violated) {
+ fail("$filename contains boilerplate text");
+ diag "$_ appears on lines @{$violated{$_}}" for keys %violated;
+ } else {
+ pass("$filename contains no boilerplate text");
+ }
+}
+
+sub module_boilerplate_ok {
+ my ($module) = @_;
+ not_in_file_ok($module =>
+ 'the great new $MODULENAME' => qr/ - The great new /,
+ 'boilerplate description' => qr/Quick summary of what the module/,
+ 'stub function definition' => qr/function[12]/,
+ );
+}
+
+TODO: {
+ local $TODO = "Need to replace the boilerplate text";
+
+ not_in_file_ok(README =>
+ "The README is used..." => qr/The README is used/,
+ "'version information here'" => qr/to provide version information/,
+ );
+
+ not_in_file_ok(Changes =>
+ "placeholder date/time" => qr(Date/time)
+ );
+
+ module_boilerplate_ok('lib/Net/Mosso/CloudServers.pm');
+
+
+}
+
@@ -0,0 +1,18 @@
+use strict;
+use warnings;
+use Test::More;
+
+# Ensure a recent version of Test::Pod::Coverage
+my $min_tpc = 1.08;
+eval "use Test::Pod::Coverage $min_tpc";
+plan skip_all => "Test::Pod::Coverage $min_tpc required for testing POD coverage"
+ if $@;
+
+# Test::Pod::Coverage doesn't require a minimum Pod::Coverage version,
+# but older versions don't recognize some common documentation styles
+my $min_pc = 0.18;
+eval "use Pod::Coverage $min_pc";
+plan skip_all => "Pod::Coverage $min_pc required for testing POD coverage"
+ if $@;
+
+all_pod_coverage_ok();
12 t/pod.t
@@ -0,0 +1,12 @@
+#!perl -T
+
+use strict;
+use warnings;
+use Test::More;
+
+# Ensure a recent version of Test::Pod
+my $min_tp = 1.22;
+eval "use Test::Pod $min_tp";
+plan skip_all => "Test::Pod $min_tp required for testing POD" if $@;
+
+all_pod_files_ok();

0 comments on commit 46ecb87

Please sign in to comment.