GroupText.t: fix number of tests

Session/Id.pm: add a method to validate GUIDs, change s/// to tr/// for efficiency.
Session.pm: change open to use new Id.pm validation method
Scratch.t: Change test from ok to is so that it tells you what the failing ID is.
Id.t: Add validation tests in addition to uniqueness tests.  Fix the uniqueness test so that it works.  Add tests to check the new validation method
This commit is contained in:
Colin Kuskie 2006-07-15 01:54:49 +00:00
parent 41bdf0e28d
commit f3a1f0f9f2
6 changed files with 65 additions and 8 deletions

View file

@ -13,6 +13,8 @@
- Added an unsubscribe link to the messages generated by collaboration - Added an unsubscribe link to the messages generated by collaboration
subscriptions per the laws in various countries. subscriptions per the laws in various countries.
- fix: MultiSearch - fix: MultiSearch
- fix: Unable to duplicate existing Session Id
7.0.1 7.0.1
- fix: User profile field "Department" needs i18n - fix: User profile field "Department" needs i18n

View file

@ -370,7 +370,7 @@ sub open {
bless $self , $class; bless $self , $class;
$self->{_request} = Apache2::Request->new($request) if (defined $request); $self->{_request} = Apache2::Request->new($request) if (defined $request);
my $sessionId = shift || $self->http->getCookies->{"wgSession"} || $self->id->generate; my $sessionId = shift || $self->http->getCookies->{"wgSession"} || $self->id->generate;
$sessionId = $self->id->generate if ($sessionId !~ m/^[A-Za-z0-9\+\/=]{22}$/); $sessionId = $self->id->generate unless $self->id->valid($sessionId);
my $noFuss = shift; my $noFuss = shift;
$self->{_var} = WebGUI::Session::Var->new($self,$sessionId, $noFuss); $self->{_var} = WebGUI::Session::Var->new($self,$sessionId, $noFuss);
$self->errorHandler->warn("You've disabled cache in your config file and that can cause many problems on a production site.") if ($config->get("disableCache")); $self->errorHandler->warn("You've disabled cache in your config file and that can cause many problems on a production site.") if ($config->get("disableCache"));

View file

@ -68,8 +68,7 @@ sub generate {
my($s,$us)=gettimeofday(); my($s,$us)=gettimeofday();
my($v)=sprintf("%09d%06d%10d%06d%255s",rand(999999999),$us,$s,$$,$self->session->config->getFilename); my($v)=sprintf("%09d%06d%10d%06d%255s",rand(999999999),$us,$s,$$,$self->session->config->getFilename);
my $id = Digest::MD5::md5_base64($v); my $id = Digest::MD5::md5_base64($v);
$id =~ s/\+/_/g; $id =~ tr{+/}{_-};
$id =~ s/\//-/g;
return $id; return $id;
} }
@ -105,6 +104,19 @@ sub session {
return $self->{_session}; return $self->{_session};
} }
#-------------------------------------------------------------------
=head2 valid ( $idString )
Returns true if $idString is a valid WebGUI guid.
=cut
sub valid {
my ($self, $idString) = @_;
return $idString =~ m/^[A-Za-z0-9_-]{22}$/;
}
1; 1;

View file

@ -23,7 +23,7 @@ my $session = WebGUI::Test->session;
use Test::More; # increment this value for each test you create use Test::More; # increment this value for each test you create
plan tests => 4 + 4; plan tests => 3 + 4;
unless ($session->config->get('macros')->{'GroupText'}) { unless ($session->config->get('macros')->{'GroupText'}) {
Macro_Config::insert_macro($session, 'GroupText', 'GroupText'); Macro_Config::insert_macro($session, 'GroupText', 'GroupText');

View file

@ -14,21 +14,64 @@ use lib "$FindBin::Bin/../lib";
use WebGUI::Test; use WebGUI::Test;
use WebGUI::Session; use WebGUI::Session;
use Test::More tests => 2; # increment this value for each test you create
use WebGUI::Utility; use WebGUI::Utility;
use Test::More;
my @testSets = (
{
comment => 'too short',
guid => 'tooShort',
valid => '',
},
{
comment => 'too long',
guid => '12345678901234567890123',
valid => '',
},
{
comment => 'contains white space',
guid => ' 23456 890123456789012',
valid => '',
},
{
comment => 'contains illegal punctuation',
guid => '12#4%67*901234&678901.',
valid => '',
},
{
comment => 'MD5 style',
guid => '==//abcdeZYXWV01234567',
valid => '',
},
{
comment => 'GUID style',
guid => '--__abcdeZYXWV0123456A',
valid => 1,
},
);
my $session = WebGUI::Test->session; my $session = WebGUI::Test->session;
plan tests => scalar(@testSets) + 3;
# generate # generate
my $generateId = $session->id->generate(); my $generateId = $session->id->generate();
is(length($generateId), 22, "generate() - length of 22 characters"); is(length($generateId), 22, "generate() - length of 22 characters");
my @uniqueIds; my @uniqueIds;
my $isUnique = 1; my $isUnique = 1;
my $isValid = 1;
for (1..2000) { for (1..2000) {
last unless $isUnique; last unless $isUnique;
my $id = $session->id->generate(); my $id = $session->id->generate();
$isUnique = !isIn($id,@uniqueIds); $isUnique = ($isUnique ? !isIn($id,@uniqueIds) : 0);
$isValid = ($isValid ? $session->id->valid($id) : 0);
push(@uniqueIds,$id); push(@uniqueIds,$id);
} }
ok($isUnique, "generate() - unique"); ok($isUnique, "generate() - unique");
ok($isValid, "generate() - valid id generated");
foreach my $testSet (@testSets) {
is($session->id->valid($testSet->{guid}), $testSet->{valid}, $testSet->{comment});
}

View file

@ -58,7 +58,7 @@ for (my $count = 1; $count <= $maxCount; $count++){
##Creating a new session with the previous session's Id should clone the scratch data ##Creating a new session with the previous session's Id should clone the scratch data
my $newSession = WebGUI::Session->open(WebGUI::Test->root, WebGUI::Test->file, undef, undef, $session->getId); my $newSession = WebGUI::Session->open(WebGUI::Test->root, WebGUI::Test->file, undef, undef, $session->getId);
ok($newSession->getId eq $session->getId, "Successful session duplication"); is($newSession->getId, $session->getId, "Successful session duplication");
for (my $count = 1; $count <= $maxCount; $count++){ for (my $count = 1; $count <= $maxCount; $count++){
is($newSession->scratch->get("dBase$count"), $count, "Passed set/get $count"); is($newSession->scratch->get("dBase$count"), $count, "Passed set/get $count");