kivitendo/SL/Dev/Part.pm @ 0d6ff79f
ec1dc3e8 | Geoffrey Richardson | package SL::Dev::Part;
|
||
8d4130ed | Sven Schöling | use strict;
|
||
ec1dc3e8 | Geoffrey Richardson | use base qw(Exporter);
|
||
cf3a8cf7 | Sven Schöling | our @EXPORT_OK = qw(new_part new_service new_assembly new_assortment);
|
||
our %EXPORT_TAGS = (ALL => \@EXPORT_OK);
|
||||
ec1dc3e8 | Geoffrey Richardson | |||
use SL::DB::Part;
|
||||
use SL::DB::Unit;
|
||||
use SL::DB::Buchungsgruppe;
|
||||
cf3a8cf7 | Sven Schöling | sub new_part {
|
||
ec1dc3e8 | Geoffrey Richardson | my (%params) = @_;
|
||
my $part = SL::DB::Part->new_part(
|
||||
description => 'Test part',
|
||||
sellprice => '10',
|
||||
lastcost => '5',
|
||||
17ef0d2b | Geoffrey Richardson | buchungsgruppen_id => _default_buchungsgruppe()->id,
|
||
unit => _default_unit()->name
|
||||
ec1dc3e8 | Geoffrey Richardson | );
|
||
$part->assign_attributes( %params );
|
||||
return $part;
|
||||
}
|
||||
cf3a8cf7 | Sven Schöling | sub new_service {
|
||
ec1dc3e8 | Geoffrey Richardson | my (%params) = @_;
|
||
my $part = SL::DB::Part->new_service(
|
||||
description => 'Test service',
|
||||
sellprice => '10',
|
||||
lastcost => '5',
|
||||
17ef0d2b | Geoffrey Richardson | buchungsgruppen_id => _default_buchungsgruppe()->id,
|
||
unit => _default_unit()->name
|
||||
ec1dc3e8 | Geoffrey Richardson | );
|
||
$part->assign_attributes( %params );
|
||||
return $part;
|
||||
}
|
||||
cf3a8cf7 | Sven Schöling | sub new_assembly {
|
||
17ef0d2b | Geoffrey Richardson | my (%params) = @_;
|
||
981bfe17 | Geoffrey Richardson | my $assnumber = delete $params{assnumber};
|
||
my $base_partnumber = delete $params{partnumber} || 'ap';
|
||||
17ef0d2b | Geoffrey Richardson | |||
981bfe17 | Geoffrey Richardson | my $assembly_items = [];
|
||
17ef0d2b | Geoffrey Richardson | |||
981bfe17 | Geoffrey Richardson | if ( $params{assembly_items} ) {
|
||
$assembly_items = delete $params{assembly_items};
|
||||
} else {
|
||||
for my $i ( 1 .. delete $params{number_of_parts} || 3) {
|
||||
cf3a8cf7 | Sven Schöling | my $part = new_part(partnumber => "$base_partnumber $i",
|
||
bbbe79aa | Geoffrey Richardson | description => "Testpart $i",
|
||
)->save;
|
||||
981bfe17 | Geoffrey Richardson | push( @{$assembly_items}, SL::DB::Assembly->new(parts_id => $part->id,
|
||
qty => 1,
|
||||
position => $i,
|
||||
));
|
||||
}
|
||||
17ef0d2b | Geoffrey Richardson | }
|
||
my $assembly = SL::DB::Part->new_assembly(
|
||||
5d711a25 | Martin Helmling | partnumber => $assnumber,
|
||
17ef0d2b | Geoffrey Richardson | description => 'Test Assembly',
|
||
sellprice => '10',
|
||||
lastcost => '5',
|
||||
981bfe17 | Geoffrey Richardson | assemblies => $assembly_items,
|
||
17ef0d2b | Geoffrey Richardson | buchungsgruppen_id => _default_buchungsgruppe()->id,
|
||
unit => _default_unit()->name
|
||||
);
|
||||
$assembly->assign_attributes( %params );
|
||||
return $assembly;
|
||||
}
|
||||
cf3a8cf7 | Sven Schöling | sub new_assortment {
|
||
17ef0d2b | Geoffrey Richardson | my (%params) = @_;
|
||
981bfe17 | Geoffrey Richardson | my $assnumber = delete $params{assnumber};
|
||
my $base_partnumber = delete $params{partnumber} || 'ap';
|
||||
fb11389a | Geoffrey Richardson | my $assortment_items = [];
|
||
981bfe17 | Geoffrey Richardson | |||
fb11389a | Geoffrey Richardson | if ( $params{assortment_items} ) {
|
||
981bfe17 | Geoffrey Richardson | $assortment_items = delete $params{assortment_items};
|
||
fb11389a | Geoffrey Richardson | } else {
|
||
981bfe17 | Geoffrey Richardson | for my $i ( 1 .. delete $params{number_of_parts} || 3) {
|
||
cf3a8cf7 | Sven Schöling | my $part = new_part(partnumber => "$base_partnumber $i",
|
||
bbbe79aa | Geoffrey Richardson | description => "Testpart $i",
|
||
)->save;
|
||||
fb11389a | Geoffrey Richardson | push( @{$assortment_items}, SL::DB::AssortmentItem->new(parts_id => $part->id,
|
||
qty => 1,
|
||||
981bfe17 | Geoffrey Richardson | position => $i,
|
||
fb11389a | Geoffrey Richardson | unit => $part->unit,
|
||
));
|
||||
}
|
||||
17ef0d2b | Geoffrey Richardson | }
|
||
my $assortment = SL::DB::Part->new_assortment(
|
||||
981bfe17 | Geoffrey Richardson | partnumber => $assnumber,
|
||
17ef0d2b | Geoffrey Richardson | description => 'Test Assortment',
|
||
sellprice => '10',
|
||||
lastcost => '5',
|
||||
fb11389a | Geoffrey Richardson | assortment_items => $assortment_items,
|
||
17ef0d2b | Geoffrey Richardson | buchungsgruppen_id => _default_buchungsgruppe()->id,
|
||
unit => _default_unit()->name
|
||||
);
|
||||
$assortment->assign_attributes( %params );
|
||||
return $assortment;
|
||||
}
|
||||
sub _default_buchungsgruppe {
|
||||
return SL::DB::Manager::Buchungsgruppe->find_by(description => 'Standard 19%') || die "No accounting group";
|
||||
}
|
||||
sub _default_unit {
|
||||
return SL::DB::Manager::Unit->find_by(name => 'Stck') || die "No unit";
|
||||
}
|
||||
ec1dc3e8 | Geoffrey Richardson | 1;
|
||
__END__
|
||||
=head1 NAME
|
||||
SL::Dev::Part - create part objects for testing, with minimal defaults
|
||||
cf3a8cf7 | Sven Schöling | =head1 SYNOPSIS
|
||
e7e7b7c6 | Geoffrey Richardson | use SL::Dev::Part qw(new_part new_assembly new_service new_assortment);
|
||
cf3a8cf7 | Sven Schöling | |||
# simple default objects
|
||||
my $part = new_part()->save;
|
||||
my $assembly = new_assembly()->save;
|
||||
my $service = new_service()->save;
|
||||
my $assortment = new_assortment()->save;
|
||||
# pass additional params to the generated object
|
||||
# see individual functions for special parameters
|
||||
my $part = new_part(
|
||||
partnumber => 'Test 001',
|
||||
warehouse_id => $bin->warehouse->id,
|
||||
bin_id => $bin->id,
|
||||
);
|
||||
ec1dc3e8 | Geoffrey Richardson | =head1 FUNCTIONS
|
||
cf3a8cf7 | Sven Schöling | =head2 C<new_part %PARAMS>
|
||
ec1dc3e8 | Geoffrey Richardson | |||
Creates a new part (part_type = part).
|
||||
cf3a8cf7 | Sven Schöling | =head2 C<new_service %PARAMS>
|
||
Creates a new service (part_type = service).
|
||||
ec1dc3e8 | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | =head2 C<new_assembly %PARAMS>
|
||
ec1dc3e8 | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | Create a new assembly (part_type = assembly).
|
||
ec1dc3e8 | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | Special params:
|
||
ec1dc3e8 | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | =over 2
|
||
17ef0d2b | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | =item * C<number_of_parts>
|
||
17ef0d2b | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | The number of automatically created assembly parts.
|
||
17ef0d2b | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | =item * C<assnumber>
|
||
17ef0d2b | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | the partnumber of the assembly
|
||
17ef0d2b | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | =item * C<partnumber>
|
||
ec1dc3e8 | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | the partnumber of the first assembly part to be created
|
||
981bfe17 | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | =back
|
||
ec1dc3e8 | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | By default 3 parts (p1, p2, p3) are created and saved as an assembly (as1).
|
||
ec1dc3e8 | Geoffrey Richardson | |||
981bfe17 | Geoffrey Richardson | Create a new assembly with 10 parts, the assembly gets partnumber 'Ass1' and the
|
||
parts get partnumbers 'Testpart 1' to 'Testpart 10':
|
||||
cf3a8cf7 | Sven Schöling | my $assembly = SL::Dev::Part::new_assembly(
|
||
number_of_parts => 10,
|
||||
partnumber => 'Testpart',
|
||||
assnumber => 'Ass1'
|
||||
)->save;
|
||||
17ef0d2b | Geoffrey Richardson | |||
981bfe17 | Geoffrey Richardson | Create an assembly with specific parts:
|
||
cf3a8cf7 | Sven Schöling | |||
981bfe17 | Geoffrey Richardson | my $assembly_item_1 = SL::DB::Assembly->new( parts_id => $part1->id, qty => 3, position => 1);
|
||
my $assembly_item_2 = SL::DB::Assembly->new( parts_id => $part2->id, qty => 3, position => 2);
|
||||
cf3a8cf7 | Sven Schöling | my $assembly_part = new_assembly(
|
||
assnumber => 'Assembly 1',
|
||||
description => 'Assembly test',
|
||||
sellprice => $part1->sellprice + $part2->sellprice,
|
||||
assembly_items => [ $assembly_item_1, $assembly_item_2 ],
|
||||
);
|
||||
17ef0d2b | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | =head2 C<new_assortment %PARAMS>
|
||
17ef0d2b | Geoffrey Richardson | |||
Create a new assortment (part_type = assortment).
|
||||
cf3a8cf7 | Sven Schöling | Special params:
|
||
=over 2
|
||||
=item * C<number_of_parts>
|
||||
The number of automatically created assembly parts.
|
||||
17ef0d2b | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | =item * C<assnumber>
|
||
the partnumber of the assortment
|
||||
=item * C<partnumber>
|
||||
the partnumber of the first assembly part to be created
|
||||
=back
|
||||
By default 3 parts (p1, p2, p3) are created and saved as an assortment.
|
||||
17ef0d2b | Geoffrey Richardson | |||
fb11389a | Geoffrey Richardson | Create a new assortment with 10 automatically created parts using the
|
||
number_of_parts param:
|
||||
17ef0d2b | Geoffrey Richardson | |||
cf3a8cf7 | Sven Schöling | my $assortment = new_assortment(number_of_parts => 10)->save;
|
||
17ef0d2b | Geoffrey Richardson | |||
fb11389a | Geoffrey Richardson | Create an assortment with a certain name and pass some assortment_item Objects
|
||
from newly created parts:
|
||||
cf3a8cf7 | Sven Schöling | my $part1 = new_part(sellprice => 7.77)->save;
|
||
my $part2 = new_part(sellprice => 6.66)->save;
|
||||
fb11389a | Geoffrey Richardson | my $assortment_item_1 = SL::DB::AssortmentItem->new( parts_id => $part1->id, qty => 3, unit => $part1->unit, position => 1);
|
||
my $assortment_item_2 = SL::DB::AssortmentItem->new( parts_id => $part2->id, qty => 3, unit => $part2->unit, position => 2);
|
||||
cf3a8cf7 | Sven Schöling | my $assortment_part = SL::Dev::Part::new_assortment(
|
||
assnumber => 'Assortment 1',
|
||||
description => 'assortment test',
|
||||
sellprice => (3*$part1->sellprice + 3*$part2->sellprice),
|
||||
lastcost => (3*$part1->lastcost + 3*$part2->lastcost),
|
||||
assortment_items => [ $assortment_item_1, $assortment_item_2 ],
|
||||
)->save;
|
||||
17ef0d2b | Geoffrey Richardson | |||
=head1 TODO
|
||||
Nothing here yet.
|
||||
ec1dc3e8 | Geoffrey Richardson | |||
=head1 BUGS
|
||||
Nothing here yet.
|
||||
=head1 AUTHOR
|
||||
G. Richardson E<lt>grichardson@kivitendo-premium.deE<gt>
|
||||
=cut
|