NAME
DBIx::Class::Schema::Critic::Policy - Role for criticizing database schemas
VERSION
version 0.005
SYNOPSIS
package DBIx::Class::Schema::Critic::Policy::MyPolicy;
use Moose;
use MooseX::Types::DBIx::Class 'ResultSource';
has description => (default => 'Follow my policy');
has explanation => (default => 'My way or the highway');
has applies_to => (
isa => 'ArrayRef[Moose::Meta::TypeConstraint]',
default => sub { [ResultSource] },
);
with 'DBIx::Class::Schema::Critic::Policy';
sub violates { $_[0]->element ne '' }
DESCRIPTION
This is a Moose::Role consumed by all DBIx::Class::Schema::Critic policy plugins.
ATTRIBUTES
element
Read-only accessor for the current schema element being examined by DBIx::Class::Schema::Critic, as an instance of DBICType.
schema
Read-only accessor for the current schema object being examined by DBIx::Class::Schema::Critic.
METHODS
violation
Given a string description of a violation that has been encountered, creates a new DBIx::Class::Schema::Critic::Violation object from the current policy.
REQUIRED METHODS
description
Returns a short string describing what's wrong.
explanation
Returns a string giving further details.
applies_to
Returns an array reference of TypeConstraints s indicating what part(s) of the schema the policy is interested in. Select from the list defined in DBICType.
violates
Role consumers must implement a violates
method that returns true if the policy is violated and false otherwise, based on attributes provided by the role. Callers should call the violates
method as the following:
$policy->violates($element, $schema);
- Arguments: $element, $schema
- Return value: nothing if the policy passes, or a DBIx::Class::Schema::Critic::Violation object if it doesn't.
SUPPORT
Perldoc
You can find documentation for this module with the perldoc command.
perldoc DBIx::Class::Schema::Critic
Websites
The following websites have more information about this module, and may be of help to you. As always, in addition to those websites please use your favorite search engine to discover more resources.
Search CPAN
The default CPAN search engine, useful to view POD in HTML format.
AnnoCPAN
The AnnoCPAN is a website that allows community annonations of Perl module documentation.
CPAN Ratings
The CPAN Ratings is a website that allows community ratings and reviews of Perl modules.
CPANTS
The CPANTS is a website that analyzes the Kwalitee ( code metrics ) of a distribution.
http://cpants.perl.org/dist/overview/DBIx-Class-Schema-Critic
CPAN Testers
The CPAN Testers is a network of smokers who run automated tests on uploaded CPAN distributions.
http://www.cpantesters.org/distro/D/DBIx-Class-Schema-Critic
CPAN Testers Matrix
The CPAN Testers Matrix is a website that provides a visual way to determine what Perls/platforms PASSed for a distribution.
http://matrix.cpantesters.org/?dist=DBIx-Class-Schema-Critic
CPAN Testers Dependencies
The CPAN Testers Dependencies is a website that shows a chart of the test results of all dependencies for a distribution.
http://deps.cpantesters.org/?module=DBIx::Class::Schema::Critic
Bugs / Feature Requests
Please report any bugs or feature requests through the web interface at https://github.com/mjgardner/DBIx-Class-Schema-Critic/issues. You will be automatically notified of any progress on the request by the system.
Source Code
The code is open to the world, and available for you to hack on. Please feel free to browse it and play with it, or whatever. If you want to contribute patches, please send me a diff or prod me to pull from your repository :)
https://github.com/mjgardner/DBIx-Class-Schema-Critic
git clone git://github.com/mjgardner/DBIx-Class-Schema-Critic.git
AUTHOR
Mark Gardner <mjgardner@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2011 by Mark Gardner.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.