Conflicts: docs/gotcha.txt docs/previousVersion.sql docs/templates.txt lib/WebGUI.pm lib/WebGUI/Asset.pm lib/WebGUI/Asset/Event.pm lib/WebGUI/Asset/File.pm lib/WebGUI/Asset/MapPoint.pm lib/WebGUI/Asset/RichEdit.pm lib/WebGUI/Asset/Sku/Product.pm lib/WebGUI/Asset/Snippet.pm lib/WebGUI/Asset/Story.pm lib/WebGUI/Asset/Template.pm lib/WebGUI/Asset/Template/TemplateToolkit.pm lib/WebGUI/Asset/Wobject/Calendar.pm lib/WebGUI/Asset/Wobject/Carousel.pm lib/WebGUI/Asset/Wobject/Collaboration.pm lib/WebGUI/Asset/Wobject/Dashboard.pm lib/WebGUI/Asset/Wobject/DataForm.pm lib/WebGUI/Asset/Wobject/Folder.pm lib/WebGUI/Asset/Wobject/Map.pm lib/WebGUI/Asset/Wobject/Search.pm lib/WebGUI/Asset/Wobject/Shelf.pm lib/WebGUI/Asset/Wobject/StockData.pm lib/WebGUI/Asset/Wobject/StoryTopic.pm lib/WebGUI/Asset/Wobject/SyndicatedContent.pm lib/WebGUI/Asset/Wobject/Thingy.pm lib/WebGUI/Asset/Wobject/WeatherData.pm lib/WebGUI/AssetClipboard.pm lib/WebGUI/AssetCollateral/DataForm/Entry.pm lib/WebGUI/AssetExportHtml.pm lib/WebGUI/AssetLineage.pm lib/WebGUI/AssetMetaData.pm lib/WebGUI/AssetTrash.pm lib/WebGUI/AssetVersioning.pm lib/WebGUI/Auth.pm lib/WebGUI/Cache/CHI.pm lib/WebGUI/Content/AssetManager.pm lib/WebGUI/Fork/ProgressBar.pm lib/WebGUI/Form/JsonTable.pm lib/WebGUI/Form/TimeField.pm lib/WebGUI/Form/Zipcode.pm lib/WebGUI/Group.pm lib/WebGUI/International.pm lib/WebGUI/Macro/AssetProxy.pm lib/WebGUI/Macro/FileUrl.pm lib/WebGUI/Operation/SSO.pm lib/WebGUI/Operation/User.pm lib/WebGUI/Role/Asset/Subscribable.pm lib/WebGUI/Shop/Cart.pm lib/WebGUI/Shop/Transaction.pm lib/WebGUI/Shop/TransactionItem.pm lib/WebGUI/Test.pm lib/WebGUI/URL/Content.pm lib/WebGUI/URL/Uploads.pm lib/WebGUI/User.pm lib/WebGUI/Workflow/Activity/ExtendCalendarRecurrences.pm lib/WebGUI/Workflow/Activity/SendNewsletters.pm lib/WebGUI/i18n/English/Asset.pm lib/WebGUI/i18n/English/WebGUI.pm sbin/installClass.pl sbin/rebuildLineage.pl sbin/search.pl sbin/testEnvironment.pl t/Asset/Asset.t t/Asset/AssetClipboard.t t/Asset/AssetLineage.t t/Asset/AssetMetaData.t t/Asset/Event.t t/Asset/File.t t/Asset/File/Image.t t/Asset/Post/notification.t t/Asset/Sku.t t/Asset/Story.t t/Asset/Template.t t/Asset/Wobject/Collaboration/templateVariables.t t/Asset/Wobject/Collaboration/unarchiveAll.t t/Asset/Wobject/Shelf.t t/Auth.t t/Macro/EditableToggle.t t/Macro/FilePump.t t/Shop/Cart.t t/Shop/Transaction.t t/Storage.t t/User.t t/Workflow.t
135 lines
3.9 KiB
Perl
135 lines
3.9 KiB
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
|
|
#-------------------------------------------------------------------
|
|
|
|
use strict;
|
|
|
|
use WebGUI::Test;
|
|
use WebGUI::Session;
|
|
use WebGUI::International;
|
|
|
|
use Test::More; # increment this value for each test you create
|
|
use Test::Deep;
|
|
|
|
my @simpleTests = (
|
|
{
|
|
method => 'adminOnly',
|
|
status => 401,
|
|
titleCode => 35,
|
|
},
|
|
{
|
|
method => 'insufficient',
|
|
status => 401,
|
|
titleCode => 37,
|
|
},
|
|
{
|
|
method => 'locked',
|
|
status => 401,
|
|
titleCode => 37,
|
|
},
|
|
{
|
|
method => 'notMember',
|
|
status => 400,
|
|
titleCode => 345,
|
|
},
|
|
{
|
|
method => 'vitalComponent',
|
|
status => 403,
|
|
titleCode => 40,
|
|
},
|
|
{
|
|
method => 'noAccess',
|
|
status => 401,
|
|
titleCode => 37,
|
|
},
|
|
|
|
);
|
|
|
|
my $num_tests = 1;
|
|
$num_tests += 3 * scalar @simpleTests; ##For each simple privilege validation
|
|
$num_tests += 2; ##For noAccess as Visitor tests
|
|
$num_tests += 3; ##For insufficient with noStyle=1
|
|
|
|
plan tests => $num_tests;
|
|
|
|
my $session = WebGUI::Test->session;
|
|
|
|
# put your tests here
|
|
|
|
my $privilege = $session->privilege;
|
|
|
|
my ($userTemplate) = setup_assets($session);
|
|
|
|
isa_ok($privilege, 'WebGUI::Session::Privilege', 'session has correct object type');
|
|
|
|
##Override the original user style template to make verification easier
|
|
$session->setting->set('userFunctionStyleId', $userTemplate->getId);
|
|
|
|
#One of the tests has different behavior depending on how it is called.
|
|
#If the user is visitor, it passes them to the login screen. We'll set
|
|
#the user to a different user to do simple testing on that method, then
|
|
#we'll come back and do the specialized testing.
|
|
$session->user({userId=>3});
|
|
|
|
my $i18n = WebGUI::International->new($session);
|
|
|
|
foreach my $test (@simpleTests) {
|
|
my $method = $test->{method};
|
|
my $output = $privilege->$method;
|
|
is($session->response->status(), $test->{status}, "$method: status code");
|
|
my $title = $i18n->get($test->{titleCode});
|
|
like($output, qr{<h1>$title</h1>}, "$method: correct title");
|
|
like($output, qr{^USERSTYLE}, "$method: renders in WebGUI User Style");
|
|
}
|
|
|
|
|
|
####################################################
|
|
#
|
|
# insufficient with empty style
|
|
#
|
|
####################################################
|
|
|
|
my $output = $privilege->insufficient(1);
|
|
is($session->response->status(), '401', 'insufficient: status code with Visitor');
|
|
my $title = $i18n->get(37);
|
|
unlike($output, qr{^USERSTYLE}, "insufficient: when noStyle is true the user style is not used");
|
|
like($output, qr{<h1>$title</h1>}, "insufficient: when noStyle is true the title is still okay");
|
|
|
|
####################################################
|
|
#
|
|
# noAccess when the user is the Visitor
|
|
#
|
|
####################################################
|
|
|
|
$session->user({userId=>1});
|
|
|
|
my $output = $privilege->noAccess;
|
|
is($session->response->status(), '401', 'noAccess: status code with Visitor');
|
|
##Is the auth screen returned, not validating the auth screen
|
|
is($output, WebGUI::Operation::Auth::www_auth($session, "init"), 'noAccess: visitor sees auth screen');
|
|
|
|
sub setup_assets {
|
|
my $session = shift;
|
|
my $importNode = WebGUI::Test->asset;
|
|
my $properties = {
|
|
title => 'user template for printing',
|
|
className => 'WebGUI::Asset::Template',
|
|
parser => 'WebGUI::Asset::Template::HTMLTemplate',
|
|
url => 'user_style_printable',
|
|
namespace => 'Style',
|
|
##Note, at this point
|
|
template => "USERSTYLE:<tmpl_var body.content>",
|
|
id => 'printableUser0Template',
|
|
# '1234567890123456789012'
|
|
};
|
|
my $userTemplate = $importNode->addChild($properties, $properties->{id});
|
|
return ($userTemplate);
|
|
}
|
|
|
|
#vim:ft=perl
|