NAME
Test::Perl::Critic::XTFiles - Perl::Critic test with XT::Files interface
VERSION
Version 0.001
SYNOPSIS
use Test::Perl::Critic::XTFiles;
Test::Perl::Critic::XTFiles->new->all_files_ok;
use Perl::Critic;
use Test::Perl::Critic::XTFiles;
Test::Perl::Critic::XTFiles->new(
critic => Perl::Critic->new( -profile => 'xt/author/perlcritic.rc' ),
)->all_files_ok;
DESCRIPTION
Tests all the files supplied from XT::Files with Perl::Critic. The output, and behavior, should be the same as from Test::Perl::Critic.
USAGE
new( [ ARGS ] )
Returns a new Test::Perl::Critic::XTFiles
instance. new
takes an optional hash or list with its arguments.
Test::Perl::Critic::XTFiles->new(
critic => Perl::Critic->new( -profile => '.perltidyrc' ),
critic_test => Perl::Critic->new( -profile => '.perltidyrc-tests' ),
);
The following arguments are supported:
critic, critic_module, critic_script, critic_test (optional)
Sets the default Perl::Critic object and the objects used to test module, script or test files. See the method with the same name for further explanation.
all_file_ok
Calls the files
method of Test::XTFiles to get all the files to be tested. All files are tested with the Perl::Critic object configured for their type.
It calls done_testing
or skip_all
so you can't have already called plan
.
all_files_ok
returns something true if all files test ok and false otherwise.
Please see XT::Files for how to configure the files to be checked.
critic
Returns, and optionally sets, the Perl::Critic default object. This is only used to initialize the other critic_*
methods. On first access this is initialized to Perl::Critic->new()
.
critic_module( [ARGS] )
Returns, and optionally sets, the Perl::Critic object used to test module files. On first access this is initialized to $self->critic()
.
critic_script( [ARGS] )
Returns, and optionally sets, the Perl::Critic object used to test script files. On first access this is initialized to $self->critic()
.
critic_test( [ARGS] )
Returns, and optionally sets, the Perl::Critic object used to test test files. On first access this is initialized to $self->critic()
.
EXAMPLES
Example 1 Default usage
Check all the files returned by XT::Files with Perl::Critic.
use 5.006;
use strict;
use warnings;
use Test::Perl::Critic::XTFiles;
Test::Perl::Critic::XTFiles->new->all_files_ok;
Example 2 Check non-default directories or files
Use the same test file as in Example 1 and create a .xtfilesrc config file in the root directory of your distribution.
[Dirs]
module = lib
module = tools
module = corpus/hello
[Files]
module = corpus/world.pm
Example 3 Use a different Perl::Critic config file for script files
use 5.006;
use strict;
use warnings;
use Perl::Critic;
use Test::Perl::Critic::XTFiles;
Test::Perl::Critic::XTFiles->new(
critic_script => Perl::Critic->new( -profile => '.perlcriticrc-scripts' ),
)->all_files_ok;
SEE ALSO
Test::More, Perl::Critic, XT::Files
SUPPORT
Bugs / Feature Requests
Please report any bugs or feature requests through the issue tracker at https://github.com/skirmess/Test-Perl-Critic-XTFiles/issues. You will be notified automatically of any progress on your issue.
Source Code
This is open source software. The code repository is available for public review and contribution under the terms of the license.
https://github.com/skirmess/Test-Perl-Critic-XTFiles
git clone https://github.com/skirmess/Test-Perl-Critic-XTFiles.git
AUTHOR
Sven Kirmess <sven.kirmess@kzone.ch>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2019 by Sven Kirmess.
This is free software, licensed under:
The (two-clause) FreeBSD License