2013-07-30 10:15:40 +00:00
|
|
|
use Test::More tests => 4;
|
2013-01-01 22:16:51 +00:00
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
|
|
|
BEGIN {
|
|
|
|
use FindBin;
|
|
|
|
use lib "$FindBin::Bin/../lib";
|
|
|
|
}
|
|
|
|
|
|
|
|
use List::Util qw(first);
|
|
|
|
use Slic3r;
|
|
|
|
use Slic3r::Test qw(_eq);
|
|
|
|
|
|
|
|
my $config = Slic3r::Config->new_from_defaults;
|
|
|
|
|
|
|
|
my $test = sub {
|
|
|
|
my ($conf) = @_;
|
|
|
|
$conf ||= $config;
|
|
|
|
|
|
|
|
my $print = Slic3r::Test::init_print('20mm_cube', config => $conf);
|
|
|
|
|
|
|
|
my @z = ();
|
|
|
|
my @increments = ();
|
2013-05-13 18:14:33 +00:00
|
|
|
Slic3r::GCode::Reader->new(gcode => Slic3r::Test::gcode($print))->parse(sub {
|
2013-01-01 22:16:51 +00:00
|
|
|
my ($self, $cmd, $args, $info) = @_;
|
|
|
|
|
|
|
|
if ($info->{dist_Z}) {
|
|
|
|
push @z, 1*$args->{Z};
|
|
|
|
push @increments, $info->{dist_Z};
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
fail 'wrong first layer height'
|
|
|
|
if $z[0] ne $config->get_value('first_layer_height') + $config->z_offset;
|
|
|
|
|
|
|
|
fail 'wrong second layer height'
|
|
|
|
if $z[1] ne $config->get_value('first_layer_height') + $config->get_value('layer_height') + $config->z_offset;
|
|
|
|
|
|
|
|
fail 'wrong layer height'
|
|
|
|
if first { !_eq($_, $config->layer_height) } @increments[1..$#increments];
|
|
|
|
|
|
|
|
1;
|
|
|
|
};
|
|
|
|
|
2013-03-09 21:05:41 +00:00
|
|
|
$config->set('start_gcode', ''); # to avoid dealing with the nozzle lift in start G-code
|
2013-01-01 22:16:51 +00:00
|
|
|
$config->set('layer_height', 0.3);
|
|
|
|
$config->set('first_layer_height', 0.2);
|
|
|
|
ok $test->(), "absolute first layer height";
|
|
|
|
|
|
|
|
$config->set('first_layer_height', '60%');
|
|
|
|
ok $test->(), "relative first layer height";
|
|
|
|
|
|
|
|
$config->set('z_offset', 0.9);
|
|
|
|
ok $test->(), "positive Z offset";
|
|
|
|
|
|
|
|
$config->set('z_offset', -0.8);
|
|
|
|
ok $test->(), "negative Z offset";
|
|
|
|
|
|
|
|
__END__
|