Merge branch 'b-3.6.1' of ../kivitendo-erp_20220811
[kivitendo-erp.git] / SL / Dev / Part.pm
1 package SL::Dev::Part;
2
3 use strict;
4 use base qw(Exporter);
5 our @EXPORT_OK = qw(new_part new_service new_assembly new_assortment);
6 our %EXPORT_TAGS = (ALL => \@EXPORT_OK);
7
8 use SL::DB::Part;
9 use SL::DB::Unit;
10 use SL::DB::Buchungsgruppe;
11
12 sub new_part {
13   my (%params) = @_;
14
15   my $part = SL::DB::Part->new_part(
16     description        => 'Test part',
17     sellprice          => '10',
18     lastcost           => '5',
19     buchungsgruppen_id => _default_buchungsgruppe()->id,
20     unit               => _default_unit()->name
21   );
22   $part->assign_attributes( %params );
23   return $part;
24 }
25
26 sub new_service {
27   my (%params) = @_;
28
29   my $part = SL::DB::Part->new_service(
30     description        => 'Test service',
31     sellprice          => '10',
32     lastcost           => '5',
33     buchungsgruppen_id => _default_buchungsgruppe()->id,
34     unit               => _default_unit()->name
35   );
36   $part->assign_attributes( %params );
37   return $part;
38 }
39
40 sub new_assembly {
41   my (%params) = @_;
42
43   my $assnumber       = delete $params{assnumber};
44   my $base_partnumber = delete $params{partnumber} || 'ap';
45
46   my $assembly_items = [];
47
48   if ( $params{assembly_items} ) {
49     $assembly_items = delete $params{assembly_items};
50   } else {
51     for my $i ( 1 .. delete $params{number_of_parts} || 3) {
52       my $part = new_part(partnumber  => "$base_partnumber $i",
53                           description => "Testpart $i",
54                          )->save;
55       push( @{$assembly_items}, SL::DB::Assembly->new(parts_id => $part->id,
56                                                       qty      => 1,
57                                                       position => $i,
58                                                      ));
59     }
60   }
61
62   my $assembly = SL::DB::Part->new_assembly(
63     partnumber         => $assnumber,
64     description        => 'Test Assembly',
65     sellprice          => '10',
66     lastcost           => '5',
67     assemblies         => $assembly_items,
68     buchungsgruppen_id => _default_buchungsgruppe()->id,
69     unit               => _default_unit()->name
70   );
71   $assembly->assign_attributes( %params );
72   return $assembly;
73 }
74
75 sub new_assortment {
76   my (%params) = @_;
77
78   my $assnumber       = delete $params{assnumber};
79   my $base_partnumber = delete $params{partnumber} || 'ap';
80
81   my $assortment_items = [];
82
83   if ( $params{assortment_items} ) {
84     $assortment_items = delete $params{assortment_items};
85   } else {
86     for my $i ( 1 .. delete $params{number_of_parts} || 3) {
87       my $part = new_part(partnumber  => "$base_partnumber $i",
88                           description => "Testpart $i",
89                          )->save;
90       push( @{$assortment_items}, SL::DB::AssortmentItem->new(parts_id => $part->id,
91                                                               qty      => 1,
92                                                               position => $i,
93                                                               unit     => $part->unit,
94                                                              ));
95     }
96   }
97
98   my $assortment = SL::DB::Part->new_assortment(
99     partnumber         => $assnumber,
100     description        => 'Test Assortment',
101     sellprice          => '10',
102     lastcost           => '5',
103     assortment_items   => $assortment_items,
104     buchungsgruppen_id => _default_buchungsgruppe()->id,
105     unit               => _default_unit()->name
106   );
107
108   $assortment->assign_attributes( %params );
109   return $assortment;
110 }
111
112
113 sub _default_buchungsgruppe {
114   return SL::DB::Manager::Buchungsgruppe->find_by(description => 'Standard 19%') || die "No accounting group";
115 }
116
117 sub _default_unit {
118   return SL::DB::Manager::Unit->find_by(name => 'Stck') || die "No unit";
119 }
120
121
122 1;
123
124 __END__
125
126 =head1 NAME
127
128 SL::Dev::Part - create part objects for testing, with minimal defaults
129
130 =head1 SYNOPSIS
131
132   use SL::Dev::Part qw(new_part new_assembly new_service new_assortment);
133
134   # simple default objects
135   my $part     = new_part()->save;
136   my $assembly = new_assembly()->save;
137   my $service  = new_service()->save;
138   my $assortment = new_assortment()->save;
139
140   # pass additional params to the generated object
141   # see individual functions for special parameters
142   my $part     = new_part(
143     partnumber   => 'Test 001',
144     warehouse_id => $bin->warehouse->id,
145     bin_id       => $bin->id,
146   );
147
148 =head1 FUNCTIONS
149
150 =head2 C<new_part %PARAMS>
151
152 Creates a new part (part_type = part).
153
154 =head2 C<new_service %PARAMS>
155
156 Creates a new service (part_type = service).
157
158 =head2 C<new_assembly %PARAMS>
159
160 Create a new assembly (part_type = assembly).
161
162 Special params:
163
164 =over 2
165
166 =item * C<number_of_parts>
167
168 The number of automatically created assembly parts.
169
170 =item * C<assnumber>
171
172 the partnumber of the assembly
173
174 =item * C<partnumber>
175
176 the partnumber of the first assembly part to be created
177
178 =back
179
180 By default 3 parts (p1, p2, p3) are created and saved as an assembly (as1).
181
182 Create a new assembly with 10 parts, the assembly gets partnumber 'Ass1' and the
183 parts get partnumbers 'Testpart 1' to 'Testpart 10':
184
185   my $assembly = SL::Dev::Part::new_assembly(
186     number_of_parts => 10,
187     partnumber      => 'Testpart',
188     assnumber       => 'Ass1'
189   )->save;
190
191 Create an assembly with specific parts:
192
193   my $assembly_item_1 = SL::DB::Assembly->new( parts_id => $part1->id, qty => 3, position => 1);
194   my $assembly_item_2 = SL::DB::Assembly->new( parts_id => $part2->id, qty => 3, position => 2);
195   my $assembly_part   = new_assembly(
196     assnumber      => 'Assembly 1',
197     description    => 'Assembly test',
198     sellprice      => $part1->sellprice + $part2->sellprice,
199     assembly_items => [ $assembly_item_1, $assembly_item_2 ],
200   );
201
202 =head2 C<new_assortment %PARAMS>
203
204 Create a new assortment (part_type = assortment).
205
206 Special params:
207
208 =over 2
209
210 =item * C<number_of_parts>
211
212 The number of automatically created assembly parts.
213
214 =item * C<assnumber>
215
216 the partnumber of the assortment
217
218 =item * C<partnumber>
219
220 the partnumber of the first assembly part to be created
221
222 =back
223
224 By default 3 parts (p1, p2, p3) are created and saved as an assortment.
225
226 Create a new assortment with 10 automatically created parts using the
227 number_of_parts param:
228
229   my $assortment = new_assortment(number_of_parts => 10)->save;
230
231 Create an assortment with a certain name and pass some assortment_item Objects
232 from newly created parts:
233
234   my $part1             = new_part(sellprice => 7.77)->save;
235   my $part2             = new_part(sellprice => 6.66)->save;
236   my $assortment_item_1 = SL::DB::AssortmentItem->new( parts_id => $part1->id, qty => 3, unit => $part1->unit, position => 1);
237   my $assortment_item_2 = SL::DB::AssortmentItem->new( parts_id => $part2->id, qty => 3, unit => $part2->unit, position => 2);
238   my $assortment_part   = SL::Dev::Part::new_assortment(
239     assnumber        => 'Assortment 1',
240     description      => 'assortment test',
241     sellprice        => (3*$part1->sellprice + 3*$part2->sellprice),
242     lastcost         => (3*$part1->lastcost  + 3*$part2->lastcost),
243     assortment_items => [ $assortment_item_1, $assortment_item_2 ],
244   )->save;
245
246 =head1 TODO
247
248 Nothing here yet.
249
250 =head1 BUGS
251
252 Nothing here yet.
253
254 =head1 AUTHOR
255
256 G. Richardson E<lt>grichardson@kivitendo-premium.deE<gt>
257
258 =cut