The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use strict;

use OpenGuides;
use OpenGuides::Test;
use Test::More;
use Wiki::Toolkit::Setup::SQLite;

eval { require DBD::SQLite; };
if ( $@ ) {
    my ($error) = $@ =~ /^(.*?)\n/;
    plan skip_all => "DBD::SQLite could not be used - no database to test with. ($error)";
}

plan tests => 2;

# Clear out the database from any previous runs.
    OpenGuides::Test::refresh_db();

# Set up a guide which uses a spam detector module.
my $config = OpenGuides::Test->make_basic_config;
$config->spam_detector_module( "OpenGuides::Local::SpamDetector" );
my $guide = OpenGuides->new( config => $config );

# Try to write something that isn't spam.
my $q = OpenGuides::Test->make_cgi_object( content => "puppies" );
my $output = $guide->commit_node(
                                  id            => "Puppies",
                                  cgi_obj       => $q,
                                  return_output => 1,
                                );
ok( $guide->wiki->node_exists( "Puppies" ), "can write non-spam node" );

# Try to write something that is.
$q = OpenGuides::Test->make_cgi_object( content => "kittens" );
$output = $guide->commit_node(
                               id            => "Kittens",
                               cgi_obj       => $q,
                               return_output => 1,
                             );
ok( !$guide->wiki->node_exists( "Kittens" ), "can't write spammy node" );

package OpenGuides::Local::SpamDetector;

sub looks_like_spam {
    my ( $class, %args ) = @_;
    if ( $args{content} =~ /kittens/i ) {
        return 1;
    }
    return 0;
}