Add a basic test for the Poll, adding votes and making a graph.
Add POD to Poll for setVote, and use placeholders in there.
This commit is contained in:
parent
8318ffe9b1
commit
0bf47be7f4
2 changed files with 138 additions and 6 deletions
|
|
@ -382,13 +382,32 @@ sub setGraphConfig {
|
||||||
}
|
}
|
||||||
|
|
||||||
#-------------------------------------------------------------------
|
#-------------------------------------------------------------------
|
||||||
|
|
||||||
|
=head2 setVote ($answer, $userId, $ip)
|
||||||
|
|
||||||
|
Accumulates a vote into the database so that it can be counted.
|
||||||
|
|
||||||
|
=head3 $answer
|
||||||
|
|
||||||
|
The answer selected by the user.
|
||||||
|
|
||||||
|
=head3 $userid
|
||||||
|
|
||||||
|
The userId of the person who voted.
|
||||||
|
|
||||||
|
=head3 $ip
|
||||||
|
|
||||||
|
The IP address of the user who voted.
|
||||||
|
|
||||||
|
=cut
|
||||||
|
|
||||||
sub setVote {
|
sub setVote {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
my $answer = shift;
|
my $answer = shift;
|
||||||
my $userId = shift;
|
my $userId = shift;
|
||||||
my $ip = shift;
|
my $ip = shift;
|
||||||
$self->session->db->write("insert into Poll_answer (assetId, answer, userId, ipAddress) values (".$self->session->db->quote($self->getId).",
|
$self->session->db->write("insert into Poll_answer (assetId, answer, userId, ipAddress) values (?,?,?,?)",
|
||||||
".$self->session->db->quote($answer).", ".$self->session->db->quote($userId).", '$ip')");
|
[$self->getId, $answer, $userId, $ip] );
|
||||||
}
|
}
|
||||||
|
|
||||||
#----------------------------------------------------------------------------
|
#----------------------------------------------------------------------------
|
||||||
|
|
|
||||||
113
t/Asset/Wobject/Poll.t
Normal file
113
t/Asset/Wobject/Poll.t
Normal file
|
|
@ -0,0 +1,113 @@
|
||||||
|
# vim:syntax=perl
|
||||||
|
#-------------------------------------------------------------------
|
||||||
|
# WebGUI is Copyright 2001-2009 Plain Black Corporation.
|
||||||
|
#-------------------------------------------------------------------
|
||||||
|
# Please read the legal notices (docs/legal.txt) and the license
|
||||||
|
# (docs/license.txt) that came with this distribution before using
|
||||||
|
# this software.
|
||||||
|
#------------------------------------------------------------------
|
||||||
|
# http://www.plainblack.com info@plainblack.com
|
||||||
|
#------------------------------------------------------------------
|
||||||
|
|
||||||
|
# Write a little about what this script tests.
|
||||||
|
#
|
||||||
|
#
|
||||||
|
|
||||||
|
use FindBin;
|
||||||
|
use strict;
|
||||||
|
use lib "$FindBin::Bin/../../lib";
|
||||||
|
use Test::More;
|
||||||
|
use Test::Deep;
|
||||||
|
use Data::Dumper;
|
||||||
|
use JSON;
|
||||||
|
use Path::Class;
|
||||||
|
|
||||||
|
use WebGUI::Test; # Must use this before any other WebGUI modules
|
||||||
|
use WebGUI::Session;
|
||||||
|
use WebGUI::Image::Graph;
|
||||||
|
|
||||||
|
################################################################
|
||||||
|
#
|
||||||
|
# setup session, users and groups for this test
|
||||||
|
#
|
||||||
|
################################################################
|
||||||
|
|
||||||
|
my $session = WebGUI::Test->session;
|
||||||
|
|
||||||
|
my $tests = 3
|
||||||
|
;
|
||||||
|
plan tests => 1
|
||||||
|
+ $tests;
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------------
|
||||||
|
# put your tests here
|
||||||
|
|
||||||
|
my $class = 'WebGUI::Asset::Wobject::Poll';
|
||||||
|
my $loaded = use_ok($class);
|
||||||
|
|
||||||
|
SKIP: {
|
||||||
|
|
||||||
|
skip "Unable to load module $class", $tests unless $loaded;
|
||||||
|
|
||||||
|
|
||||||
|
my $defaultNode = WebGUI::Asset->getDefault($session);
|
||||||
|
my $template = $defaultNode->addChild({
|
||||||
|
className => 'WebGUI::Asset::Template',
|
||||||
|
title => 'test poll template',
|
||||||
|
template => q|
|
||||||
|
{
|
||||||
|
"responses.total" : "<tmpl_var responses.total>",
|
||||||
|
"hasImageGraph" : "<tmpl_var hasImageGraph>",
|
||||||
|
"graphUrl" : "<tmpl_var graphUrl>"
|
||||||
|
}
|
||||||
|
|,
|
||||||
|
});
|
||||||
|
|
||||||
|
my $poll = $defaultNode->addChild({
|
||||||
|
className => $class,
|
||||||
|
active => 1,
|
||||||
|
title => 'test poll',
|
||||||
|
generateGraph => 1,
|
||||||
|
question => "How often do you look at a man's shoes?",
|
||||||
|
a1 => 'daily',
|
||||||
|
a2 => 'hourly',
|
||||||
|
a3 => 'never',
|
||||||
|
templateId => $template->getId,
|
||||||
|
graphConfiguration => '{"graph_labelFontSize":"20","xyGraph_chartWidth":"200","xyGraph_drawRulers":"1","graph_labelColor":"#333333","xyGraph_drawAxis":"1","graph_formNamespace":"Graph_XYGraph_Bar","graph_backgroundColor":"#ffffff","xyGraph_bar_barSpacing":0,"graph_labelFontId":"defaultFont","graph_labelOffset":"10","xyGraph_drawMode":"sideBySide","xyGraph_yGranularity":"10","xyGraph_chartHeight":"200","graph_imageHeight":"300","graph_imageWidth":"300","xyGraph_drawLabels":"1","xyGraph_bar_groupSpacing":0,"graph_paletteId":"defaultPalette"}',
|
||||||
|
});
|
||||||
|
|
||||||
|
my $versionTag = WebGUI::VersionTag->getWorking($session);
|
||||||
|
WebGUI::Test->tagsToRollback($versionTag);
|
||||||
|
$versionTag->commit;
|
||||||
|
|
||||||
|
isa_ok($poll, 'WebGUI::Asset::Wobject::Poll');
|
||||||
|
|
||||||
|
$poll->setVote('daily', 1, '127.0.0.1');
|
||||||
|
$poll->setVote('hourly', 1, '127.0.0.1');
|
||||||
|
$poll->setVote('never', 1, '127.0.0.1');
|
||||||
|
$poll->setVote('never', 1, '127.0.0.1');
|
||||||
|
|
||||||
|
$poll->prepareView();
|
||||||
|
my $json = $poll->view();
|
||||||
|
my $output = JSON::from_json($json);
|
||||||
|
|
||||||
|
cmp_deeply(
|
||||||
|
$output,
|
||||||
|
{
|
||||||
|
'responses.total' => 4,
|
||||||
|
hasImageGraph => 1,
|
||||||
|
graphUrl => re('^\S+$'),
|
||||||
|
},
|
||||||
|
'poll has correct number of responses, a graph and a path to the generated file'
|
||||||
|
);
|
||||||
|
|
||||||
|
my $graphUrl = Path::Class::File->new($output->{graphUrl});
|
||||||
|
my $uploadsPath = Path::Class::Dir->new($session->config->get('uploadsPath'));
|
||||||
|
my $uploadsUrl = Path::Class::Dir->new($session->config->get('uploadsURL'));
|
||||||
|
my $graphRelative = $graphUrl->relative($uploadsUrl);
|
||||||
|
my $graphFile = $uploadsPath->file($graphRelative);
|
||||||
|
diag $graphFile->stringify;
|
||||||
|
|
||||||
|
ok(-e $graphFile->stringify, 'graph exists');
|
||||||
|
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue