File Coverage

blib/lib/SQL/Functional/InnerJoinClause.pm
Criterion Covered Total %
statement 6 8 75.0
branch n/a
condition n/a
subroutine 3 3 100.0
pod n/a
total 9 11 81.8


line stmt bran cond sub pod time code
1             # Copyright (c) 2016 Timm Murray
2             # All rights reserved.
3             #
4             # Redistribution and use in source and binary forms, with or without
5             # modification, are permitted provided that the following conditions are met:
6             #
7             # * Redistributions of source code must retain the above copyright notice,
8             # this list of conditions and the following disclaimer.
9             # * Redistributions in binary form must reproduce the above copyright
10             # notice, this list of conditions and the following disclaimer in the
11             # documentation and/or other materials provided with the distribution.
12             #
13             # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
14             # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15             # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16             # ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
17             # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18             # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19             # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20             # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21             # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22             # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
23             # POSSIBILITY OF SUCH DAMAGE.
24             package SQL::Functional::InnerJoinClause;
25             $SQL::Functional::InnerJoinClause::VERSION = '0.1';
26 1     1   1100 use v5.14;
  1         2  
27 1     1   3 use warnings;
  1         1  
  1         16  
28 1     1   150 use Moose;
  0            
  0            
29             use namespace::autoclean;
30             use SQL::Functional::Clause;
31             use SQL::Functional::TableClause;
32              
33             with 'SQL::Functional::Clause';
34              
35             has table => (
36             is => 'ro',
37             isa => 'SQL::Functional::TableClause',
38             required => 1,
39             );
40             has field1 => (
41             is => 'ro',
42             isa => 'SQL::Functional::FieldClause',
43             required => 1,
44             );
45             has field2 => (
46             is => 'ro',
47             isa => 'SQL::Functional::FieldClause',
48             required => 1,
49             );
50              
51             sub to_string
52             {
53             my ($self) = @_;
54             return 'INNER JOIN '
55             . $self->table->to_string
56             . ' ON ' . $self->field1->to_string
57             . ' = ' . $self->field2->to_string;
58             }
59              
60              
61             no Moose;
62             __PACKAGE__->meta->make_immutable;
63             1;
64             __END__