Add tests for GroupDelete and GroupAdd macros.
Fix bugs exposed by the tests.
This commit is contained in:
parent
5a23f11707
commit
654e5751e8
5 changed files with 341 additions and 30 deletions
|
|
@ -19,6 +19,7 @@
|
||||||
- fix: Data Form Text Area Box Non-Existent (Wouter van Oijen / ProcoliX)
|
- fix: Data Form Text Area Box Non-Existent (Wouter van Oijen / ProcoliX)
|
||||||
- Added an error message to the FileUrl macro to help users figure out why it
|
- Added an error message to the FileUrl macro to help users figure out why it
|
||||||
doesn't work.
|
doesn't work.
|
||||||
|
- Fixed bugs in the GroupAdd and GroupDelete macros.
|
||||||
- Fixed a cross-Matrix linking problem when you have two or more Matricies on
|
- Fixed a cross-Matrix linking problem when you have two or more Matricies on
|
||||||
one site with the same category names.
|
one site with the same category names.
|
||||||
- Deleted a template that was accidentally added to the core.
|
- Deleted a template that was accidentally added to the core.
|
||||||
|
|
|
||||||
|
|
@ -43,20 +43,19 @@ An optional template for formatting the text and link.
|
||||||
|
|
||||||
#-------------------------------------------------------------------
|
#-------------------------------------------------------------------
|
||||||
sub process {
|
sub process {
|
||||||
my @param = @_;
|
my ($session, $groupName, $text, $template) = @_;
|
||||||
my $session = shift;
|
return "" if ($groupName eq "");
|
||||||
return "" if ($param[0] eq "");
|
return "" if ($text eq "");
|
||||||
return "" if ($param[1] eq "");
|
|
||||||
return "" if ($session->user->userId eq '1');
|
return "" if ($session->user->userId eq '1');
|
||||||
my $g = WebGUI::Group->find($param[0]);
|
my $g = WebGUI::Group->find($session, $groupName);
|
||||||
return "" unless defined $g->getId;
|
return "" unless defined $g->getId;
|
||||||
return "" unless ($g->autoAdd);
|
return "" unless ($g->autoAdd);
|
||||||
return "" if ($session->user->isInGroup($g->getId));
|
return "" if ($session->user->isInGroup($g->getId));
|
||||||
my %var = ();
|
my %var = ();
|
||||||
$var{'group.url'} = $session->url->page("op=autoAddToGroup;groupId=".$g->getId);
|
$var{'group.url'} = $session->url->page("op=autoAddToGroup;groupId=".$g->getId);
|
||||||
$var{'group.text'} = $param[1];
|
$var{'group.text'} = $text;
|
||||||
if ($param[2]) {
|
if ($template) {
|
||||||
return WebGUI::Asset::Template->newByUrl($session,$param[2])->process(\%var);
|
return WebGUI::Asset::Template->newByUrl($session,$template)->process(\%var);
|
||||||
} else {
|
} else {
|
||||||
return WebGUI::Asset::Template->new($session,"PBtmpl0000000000000040")->process(\%var);
|
return WebGUI::Asset::Template->new($session,"PBtmpl0000000000000040")->process(\%var);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -43,20 +43,19 @@ An optional template for formatting the text and link.
|
||||||
|
|
||||||
#-------------------------------------------------------------------
|
#-------------------------------------------------------------------
|
||||||
sub process {
|
sub process {
|
||||||
my $session = shift;
|
my ($session, $groupName, $text, $template) = @_;
|
||||||
my @param = @_;
|
return "" if ($groupName eq "");
|
||||||
return "" if ($param[0] eq "");
|
return "" if ($text eq "");
|
||||||
return "" if ($param[1] eq "");
|
|
||||||
return "" if ($session->user->userId eq '1');
|
return "" if ($session->user->userId eq '1');
|
||||||
my $g = WebGUI::Group->find($param[0]);
|
my $g = WebGUI::Group->find($session, $groupName);
|
||||||
return "" if ($g->getId eq "");
|
return "" unless defined $g->getId;
|
||||||
return "" unless ($g->autoDelete);
|
return "" unless ($g->autoDelete);
|
||||||
return "" unless ($session->user->isInGroup($g->getId));
|
return "" unless ($session->user->isInGroup($g->getId));
|
||||||
my %var = ();
|
my %var = ();
|
||||||
$var{'group.url'} = $session->url->page("op=autoDeleteFromGroup;groupId=".$g->getId);
|
$var{'group.url'} = $session->url->page("op=autoDeleteFromGroup;groupId=".$g->getId);
|
||||||
$var{'group.text'} = $param[1];
|
$var{'group.text'} = $text;
|
||||||
if ($param[2]) {
|
if ($template) {
|
||||||
return WebGUI::Asset::Template->newByUrl($session,$param[2])->process(\%var);
|
return WebGUI::Asset::Template->newByUrl($session,$template)->process(\%var);
|
||||||
} else {
|
} else {
|
||||||
return WebGUI::Asset::Template->new($session,"PBtmpl0000000000000041")->process(\%var);
|
return WebGUI::Asset::Template->new($session,"PBtmpl0000000000000041")->process(\%var);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -19,6 +19,7 @@ use WebGUI::Macro_Config;
|
||||||
use Data::Dumper;
|
use Data::Dumper;
|
||||||
|
|
||||||
use Test::More; # increment this value for each test you create
|
use Test::More; # increment this value for each test you create
|
||||||
|
use HTML::TokeParser;
|
||||||
|
|
||||||
my $session = WebGUI::Test->session;
|
my $session = WebGUI::Test->session;
|
||||||
|
|
||||||
|
|
@ -27,9 +28,8 @@ unless ($session->config->get('macros')->{'GroupAdd'}) {
|
||||||
}
|
}
|
||||||
|
|
||||||
my $homeAsset = WebGUI::Asset->getDefault($session);
|
my $homeAsset = WebGUI::Asset->getDefault($session);
|
||||||
my ($groups, $users) = setupTest($session);
|
my ($versionTag, $template, $groups, $users) = setupTest($session, $homeAsset);
|
||||||
|
|
||||||
##Add more Asset configurations here.
|
|
||||||
my @testSets = (
|
my @testSets = (
|
||||||
{
|
{
|
||||||
comment => 'Empty macro call returns null string',
|
comment => 'Empty macro call returns null string',
|
||||||
|
|
@ -76,6 +76,57 @@ my @testSets = (
|
||||||
empty => 1,
|
empty => 1,
|
||||||
userId => $users->[2]->userId,
|
userId => $users->[2]->userId,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
comment => 'Group without autoAdd returns null string',
|
||||||
|
macroText => q!^GroupAdd("%s","%s");!,
|
||||||
|
groupName => $groups->[1]->name,
|
||||||
|
text => 'Join up!',
|
||||||
|
template => '',
|
||||||
|
empty => 1,
|
||||||
|
userId => $users->[2]->userId,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Existing member of group sees empty string',
|
||||||
|
macroText => q!^GroupAdd("%s","%s");!,
|
||||||
|
groupName => $groups->[0]->name,
|
||||||
|
text => 'Join up!',
|
||||||
|
template => '',
|
||||||
|
empty => 1,
|
||||||
|
userId => $users->[0]->userId,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Non-member of group sees text and link',
|
||||||
|
macroText => q!^GroupAdd("%s","%s");!,
|
||||||
|
groupName => $groups->[0]->name,
|
||||||
|
groupId => $groups->[0]->getId,
|
||||||
|
text => 'Join up!',
|
||||||
|
template => '',
|
||||||
|
empty => 0,
|
||||||
|
userId => $users->[2]->userId,
|
||||||
|
parser => \&simpleHTMLParser,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Member of different group sees text and link',
|
||||||
|
macroText => q!^GroupAdd("%s","%s");!,
|
||||||
|
groupName => $groups->[0]->name,
|
||||||
|
groupId => $groups->[0]->getId,
|
||||||
|
text => 'Join up!',
|
||||||
|
template => '',
|
||||||
|
empty => 0,
|
||||||
|
userId => $users->[1]->userId,
|
||||||
|
parser => \&simpleHTMLParser,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Custom template check',
|
||||||
|
macroText => q!^GroupAdd("%s","%s","%s");!,
|
||||||
|
groupName => $groups->[0]->name,
|
||||||
|
groupId => $groups->[0]->getId,
|
||||||
|
text => 'Join up!',
|
||||||
|
template => $template->get('url'),
|
||||||
|
empty => 0,
|
||||||
|
userId => $users->[1]->userId,
|
||||||
|
parser => \&simpleTextParser,
|
||||||
|
},
|
||||||
);
|
);
|
||||||
|
|
||||||
my $numTests = 0;
|
my $numTests = 0;
|
||||||
|
|
@ -95,11 +146,15 @@ foreach my $testSet (@testSets) {
|
||||||
is($output, '', $testSet->{comment});
|
is($output, '', $testSet->{comment});
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
my ($url, $text) = $testSet->{parser}->($output);
|
||||||
|
is($text, $testSet->{text}, 'TEXT: '.$testSet->{comment});
|
||||||
|
my $expectedUrl = $session->url->page('op=autoAddToGroup;groupId='.$testSet->{groupId});
|
||||||
|
is($url, $expectedUrl, 'URL: '.$testSet->{comment});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sub setupTest {
|
sub setupTest {
|
||||||
my ($session) = @_;
|
my ($session, $defaultNode) = @_;
|
||||||
my @groups;
|
my @groups;
|
||||||
##Two groups, one with Group Add and one without
|
##Two groups, one with Group Add and one without
|
||||||
$groups[0] = WebGUI::Group->new($session, "new");
|
$groups[0] = WebGUI::Group->new($session, "new");
|
||||||
|
|
@ -114,14 +169,52 @@ sub setupTest {
|
||||||
$users[0]->addToGroups([$groups[0]->getId]);
|
$users[0]->addToGroups([$groups[0]->getId]);
|
||||||
$users[1]->addToGroups([$groups[1]->getId]);
|
$users[1]->addToGroups([$groups[1]->getId]);
|
||||||
|
|
||||||
return \@groups, \@users;
|
my $versionTag = WebGUI::VersionTag->getWorking($session);
|
||||||
|
$versionTag->set({name=>"GroupAdd test"});
|
||||||
|
my $properties = {
|
||||||
|
title => 'GroupAdd test template',
|
||||||
|
className => 'WebGUI::Asset::Template',
|
||||||
|
url => 'groupadd-test',
|
||||||
|
namespace => 'Macro/GroupAdd',
|
||||||
|
template => "HREF=<tmpl_var group.url>\nLABEL=<tmpl_var group.text>",
|
||||||
|
# '1234567890123456789012'
|
||||||
|
id => 'GroupAdd001100Template',
|
||||||
|
};
|
||||||
|
my $asset = $defaultNode->addChild($properties, $properties->{id});
|
||||||
|
$versionTag->commit;
|
||||||
|
|
||||||
|
return $versionTag, $asset, \@groups, \@users;
|
||||||
}
|
}
|
||||||
|
|
||||||
#END { ##Clean-up after yourself, always
|
sub simpleHTMLParser {
|
||||||
# foreach my $testGroup (@{ $groups }, ) {
|
my ($text) = @_;
|
||||||
# $testGroup->delete if (defined $testGroup and ref $testGroup eq 'WebGUI::Group');
|
my $p = HTML::TokeParser->new(\$text);
|
||||||
# }
|
|
||||||
# foreach my $dude (@{ $users }, ) {
|
my $token = $p->get_tag("a");
|
||||||
# $dude->delete if (defined $dude and ref $dude eq 'WebGUI::User');
|
my $url = $token->[1]{href} || "-";
|
||||||
# }
|
my $label = $p->get_trimmed_text("/a");
|
||||||
#}
|
|
||||||
|
return ($url, $label);
|
||||||
|
}
|
||||||
|
|
||||||
|
sub simpleTextParser {
|
||||||
|
my ($text) = @_;
|
||||||
|
|
||||||
|
my ($url) = $text =~ /^HREF=(.+)$/m;
|
||||||
|
my ($label) = $text =~ /^LABEL=(.+)$/m;
|
||||||
|
|
||||||
|
return ($url, $label);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
END { ##Clean-up after yourself, always
|
||||||
|
foreach my $testGroup (@{ $groups }, ) {
|
||||||
|
$testGroup->delete if (defined $testGroup and ref $testGroup eq 'WebGUI::Group');
|
||||||
|
}
|
||||||
|
foreach my $dude (@{ $users }, ) {
|
||||||
|
$dude->delete if (defined $dude and ref $dude eq 'WebGUI::User');
|
||||||
|
}
|
||||||
|
if (defined $versionTag and ref $versionTag eq 'WebGUI::VersionTag') {
|
||||||
|
$versionTag->rollback;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
||||||
219
t/Macro/GroupDelete.t
Normal file
219
t/Macro/GroupDelete.t
Normal file
|
|
@ -0,0 +1,219 @@
|
||||||
|
#-------------------------------------------------------------------
|
||||||
|
# WebGUI is Copyright 2001-2006 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
|
||||||
|
#-------------------------------------------------------------------
|
||||||
|
|
||||||
|
use FindBin;
|
||||||
|
use strict;
|
||||||
|
use lib "$FindBin::Bin/../lib";
|
||||||
|
|
||||||
|
use WebGUI::Test;
|
||||||
|
use WebGUI::Macro;
|
||||||
|
use WebGUI::Session;
|
||||||
|
use WebGUI::Macro_Config;
|
||||||
|
use Data::Dumper;
|
||||||
|
|
||||||
|
use Test::More; # increment this value for each test you create
|
||||||
|
use HTML::TokeParser;
|
||||||
|
|
||||||
|
my $session = WebGUI::Test->session;
|
||||||
|
|
||||||
|
unless ($session->config->get('macros')->{'GroupDelete'}) {
|
||||||
|
Macro_Config::insert_macro($session, 'GroupDelete', 'GroupDelete');
|
||||||
|
}
|
||||||
|
|
||||||
|
my $homeAsset = WebGUI::Asset->getDefault($session);
|
||||||
|
my ($versionTag, $template, $groups, $users) = setupTest($session, $homeAsset);
|
||||||
|
|
||||||
|
my @testSets = (
|
||||||
|
{
|
||||||
|
comment => 'Empty macro call returns null string',
|
||||||
|
macroText => q!^GroupDelete();!,
|
||||||
|
groupName => '',
|
||||||
|
text => '',
|
||||||
|
template => '',
|
||||||
|
empty => 1,
|
||||||
|
userId => $users->[2]->userId,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Empty group returns null string',
|
||||||
|
macroText => q!^GroupDelete("%s","%s");!,
|
||||||
|
groupName => '',
|
||||||
|
text => 'Bow out',
|
||||||
|
template => '',
|
||||||
|
empty => 1,
|
||||||
|
userId => $users->[2]->userId,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Empty text returns null string',
|
||||||
|
macroText => q!^GroupDelete("%s","%s");!,
|
||||||
|
groupName => $groups->[0]->name,
|
||||||
|
text => '',
|
||||||
|
template => '',
|
||||||
|
empty => 1,
|
||||||
|
userId => $users->[2]->userId,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Visitor sees empty string with valid group and text',
|
||||||
|
macroText => q!^GroupDelete("%s","%s");!,
|
||||||
|
groupName => $groups->[0]->name(),
|
||||||
|
text => 'Bow out',
|
||||||
|
template => '',
|
||||||
|
empty => 1,
|
||||||
|
userId => 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Non-existant group returns null string',
|
||||||
|
macroText => q!^GroupDelete("%s","%s");!,
|
||||||
|
groupName => "Dudes of the day",
|
||||||
|
text => 'Bow out',
|
||||||
|
template => '',
|
||||||
|
empty => 1,
|
||||||
|
userId => $users->[2]->userId,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Group without autoDelete returns null string',
|
||||||
|
macroText => q!^GroupDelete("%s","%s");!,
|
||||||
|
groupName => $groups->[1]->name,
|
||||||
|
text => 'Bow out',
|
||||||
|
template => '',
|
||||||
|
empty => 1,
|
||||||
|
userId => $users->[2]->userId,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Non-member of group sees empty string',
|
||||||
|
macroText => q!^GroupDelete("%s","%s");!,
|
||||||
|
groupName => $groups->[0]->name,
|
||||||
|
text => 'Bow out',
|
||||||
|
template => '',
|
||||||
|
empty => 1,
|
||||||
|
userId => $users->[1]->userId,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Member of different group sees empty string',
|
||||||
|
macroText => q!^GroupDelete("%s","%s");!,
|
||||||
|
groupName => $groups->[0]->name,
|
||||||
|
groupId => $groups->[0]->getId,
|
||||||
|
text => 'Bow out',
|
||||||
|
template => '',
|
||||||
|
empty => 1,
|
||||||
|
userId => $users->[2]->userId,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Member of group sees text and link',
|
||||||
|
macroText => q!^GroupDelete("%s","%s");!,
|
||||||
|
groupName => $groups->[0]->name,
|
||||||
|
groupId => $groups->[0]->getId,
|
||||||
|
text => 'Bow out',
|
||||||
|
template => '',
|
||||||
|
empty => 0,
|
||||||
|
userId => $users->[0]->userId,
|
||||||
|
parser => \&simpleHTMLParser,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
comment => 'Custom template check',
|
||||||
|
macroText => q!^GroupDelete("%s","%s","%s");!,
|
||||||
|
groupName => $groups->[0]->name,
|
||||||
|
groupId => $groups->[0]->getId,
|
||||||
|
text => 'Bow out',
|
||||||
|
template => $template->get('url'),
|
||||||
|
empty => 0,
|
||||||
|
userId => $users->[0]->userId,
|
||||||
|
parser => \&simpleTextParser,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
|
my $numTests = 0;
|
||||||
|
|
||||||
|
foreach my $testSet (@testSets) {
|
||||||
|
$numTests += 1 + ($testSet->{empty} == 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
plan tests => $numTests;
|
||||||
|
|
||||||
|
foreach my $testSet (@testSets) {
|
||||||
|
$session->user({ userId => $testSet->{userId} });
|
||||||
|
my $output = sprintf $testSet->{macroText},
|
||||||
|
$testSet->{groupName}, $testSet->{text}, $testSet->{template};
|
||||||
|
WebGUI::Macro::process($session, \$output);
|
||||||
|
if ($testSet->{empty}) {
|
||||||
|
is($output, '', $testSet->{comment});
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
my ($url, $text) = $testSet->{parser}->($output);
|
||||||
|
is($text, $testSet->{text}, 'TEXT: '.$testSet->{comment});
|
||||||
|
my $expectedUrl = $session->url->page('op=autoDeleteFromGroup;groupId='.$testSet->{groupId});
|
||||||
|
is($url, $expectedUrl, 'URL: '.$testSet->{comment});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sub setupTest {
|
||||||
|
my ($session, $defaultNode) = @_;
|
||||||
|
my @groups;
|
||||||
|
##Two groups, one with Group Delete and one without
|
||||||
|
$groups[0] = WebGUI::Group->new($session, "new");
|
||||||
|
$groups[0]->name('AutoDelete Group');
|
||||||
|
$groups[0]->autoDelete(1);
|
||||||
|
$groups[1] = WebGUI::Group->new($session, "new");
|
||||||
|
$groups[1]->name('Regular Old Group');
|
||||||
|
$groups[1]->autoDelete(0);
|
||||||
|
|
||||||
|
##Three users. One in each group and one with no group membership
|
||||||
|
my @users = map { WebGUI::User->new($session, "new") } 0..2;
|
||||||
|
$users[0]->addToGroups([$groups[0]->getId]);
|
||||||
|
$users[1]->addToGroups([$groups[1]->getId]);
|
||||||
|
|
||||||
|
my $versionTag = WebGUI::VersionTag->getWorking($session);
|
||||||
|
$versionTag->set({name=>"GroupDelete test"});
|
||||||
|
my $properties = {
|
||||||
|
title => 'GroupDelete test template',
|
||||||
|
className => 'WebGUI::Asset::Template',
|
||||||
|
url => 'groupdelete-test',
|
||||||
|
namespace => 'Macro/GroupDelete',
|
||||||
|
template => "HREF=<tmpl_var group.url>\nLABEL=<tmpl_var group.text>",
|
||||||
|
# '1234567890123456789012'
|
||||||
|
id => 'GroupDelete001Template',
|
||||||
|
};
|
||||||
|
my $asset = $defaultNode->addChild($properties, $properties->{id});
|
||||||
|
$versionTag->commit;
|
||||||
|
|
||||||
|
return $versionTag, $asset, \@groups, \@users;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub simpleHTMLParser {
|
||||||
|
my ($text) = @_;
|
||||||
|
my $p = HTML::TokeParser->new(\$text);
|
||||||
|
|
||||||
|
my $token = $p->get_tag("a");
|
||||||
|
my $url = $token->[1]{href} || "-";
|
||||||
|
my $label = $p->get_trimmed_text("/a");
|
||||||
|
|
||||||
|
return ($url, $label);
|
||||||
|
}
|
||||||
|
|
||||||
|
sub simpleTextParser {
|
||||||
|
my ($text) = @_;
|
||||||
|
|
||||||
|
my ($url) = $text =~ /^HREF=(.+)$/m;
|
||||||
|
my ($label) = $text =~ /^LABEL=(.+)$/m;
|
||||||
|
|
||||||
|
return ($url, $label);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
END { ##Clean-up after yourself, always
|
||||||
|
foreach my $testGroup (@{ $groups }, ) {
|
||||||
|
$testGroup->delete if (defined $testGroup and ref $testGroup eq 'WebGUI::Group');
|
||||||
|
}
|
||||||
|
foreach my $dude (@{ $users }, ) {
|
||||||
|
$dude->delete if (defined $dude and ref $dude eq 'WebGUI::User');
|
||||||
|
}
|
||||||
|
if (defined $versionTag and ref $versionTag eq 'WebGUI::VersionTag') {
|
||||||
|
$versionTag->rollback;
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue