File Coverage

lib/MediaCloud/JobManager/Worker.pm
Criterion Covered Total %
statement 18 38 47.3
branch 0 6 0.0
condition n/a
subroutine 6 8 75.0
pod 0 2 0.0
total 24 54 44.4


line stmt bran cond sub pod time code
1             package MediaCloud::JobManager::Worker;
2              
3             #
4             # Worker helpers
5             #
6              
7 1     1   325 use strict;
  1         3  
  1         29  
8 1     1   5 use warnings;
  1         2  
  1         20  
9 1     1   5 use Modern::Perl "2012";
  1         1  
  1         4  
10              
11 1     1   83 use MediaCloud::JobManager;
  1         3  
  1         14  
12 1     1   4 use MediaCloud::JobManager::Configuration;
  1         6  
  1         23  
13              
14 1     1   4 use Log::Log4perl qw(:easy);
  1         2  
  1         18  
15             Log::Log4perl->easy_init( { level => $DEBUG, utf8 => 1, layout => "%d{ISO8601} [%P]: %m%n" } );
16              
17             # Import function Perl module by path or name
18             sub import_function($)
19             {
20 0     0 0       my ( $path_or_name ) = shift;
21              
22                 eval {
23 0 0                 if ( $path_or_name =~ /\.pm$/ )
24                     {
25             # /somewhere/Foo/Bar.pm
26              
27             # Expect the package to return its name so that we'll know how to call it:
28             # http://stackoverflow.com/a/9850017/200603
29 0                       $path_or_name = require $path_or_name;
30 0 0                     if ( $path_or_name . '' eq '1' )
31                         {
32 0                           LOGDIE( "The function package should return __PACKAGE__ at the end of the file instead of just 1." );
33                         }
34 0                       $path_or_name->import();
35 0                       1;
36                     }
37                     else
38                     {
39             # Foo::Bar
40 0                       ( my $file = $path_or_name ) =~ s|::|/|g;
41 0                       require $file . '.pm';
42 0                       $path_or_name->import();
43 0                       1;
44                     }
45                 } or do
46 0 0             {
47 0                   LOGDIE( "Unable to find function in '$path_or_name': $@" );
48                 };
49              
50 0               return $path_or_name;
51             }
52              
53             # Run worker
54             sub start_worker($)
55             {
56 0     0 0       my ( $function_name_or_path ) = @_;
57              
58 0               my $function_name = import_function( $function_name_or_path );
59 0               my $config = $function_name->configuration();
60              
61 0               INFO( "Starting function '$function_name' from '$function_name_or_path'." );
62              
63 0               $config->{ broker }->start_worker( $function_name );
64              
65 0               INFO( "Done." );
66             }
67              
68             1;
69