Dist::Zilla::App::Command::smoke - smoke your dist


Dist-Zilla documentation Contained in the Dist-Zilla distribution.

Index


Code Index:

NAME

Top

Dist::Zilla::App::Command::smoke - smoke your dist

VERSION

Top

version 4.200008

SYNOPSIS

Top

  dzil smoke [ --release ] [ --author ] [ --no-automated ]

DESCRIPTION

Top

This command builds and tests the distribution in "smoke testing mode."

This command is a thin wrapper around the test method in Dist::Zilla. It builds your dist and runs the tests with the AUTOMATED_TESTING environment variable turned on, so it's like doing this:

  export AUTOMATED_TESTING=1
  dzil build --no-tgz
  cd $BUILD_DIRECTORY
  perl Makefile.PL
  make
  make test

A build that fails tests will be left behind for analysis, and dzil will exit a non-zero value. If the tests are successful, the build directory will be removed and dzil will exit with status 0.

OPTIONS

Top

--release

This will run the testsuite with RELEASE_TESTING=1

--no-automated

This will run the testsuite without setting AUTOMATED_TESTING

--author

This will run the testsuite with AUTHOR_TESTING=1

AUTHOR

Top

Ricardo SIGNES <rjbs@cpan.org>

COPYRIGHT AND LICENSE

Top


Dist-Zilla documentation Contained in the Dist-Zilla distribution.

use strict;
use warnings;
package Dist::Zilla::App::Command::smoke;
BEGIN {
  $Dist::Zilla::App::Command::smoke::VERSION = '4.200008';
}
# ABSTRACT: smoke your dist
use Dist::Zilla::App -command;


sub opt_spec {
  [ 'release'   => 'enables the RELEASE_TESTING env variable', { default => 0 } ],
  [ 'automated!' => 'enables the AUTOMATED_TESTING env variable (default behavior)', { default => 1 } ],
  [ 'author' => 'enables the AUTHOR_TESTING env variable', { default => 0 } ]
}


sub abstract { 'smoke your dist' }

sub execute {
  my ($self, $opt, $arg) = @_;

  local $ENV{RELEASE_TESTING} = 1 if $opt->release;
  local $ENV{AUTHOR_TESTING} = 1 if $opt->author;
  local $ENV{AUTOMATED_TESTING} = 1 if $opt->automated;

  $self->zilla->test;
}

1;

__END__