Merge commit 'v7.10.15' into 8
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
This commit is contained in:
commit
277faae8a1
783 changed files with 32041 additions and 25495 deletions
|
|
@ -14,6 +14,7 @@ use strict;
|
|||
##versions.
|
||||
|
||||
use WebGUI::Test;
|
||||
use WebGUI::Test::Metadata;
|
||||
use WebGUI::Session;
|
||||
use WebGUI::Asset;
|
||||
use WebGUI::VersionTag;
|
||||
|
|
@ -21,11 +22,11 @@ use WebGUI::Test::Mechanize;
|
|||
|
||||
use Test::More; # increment this value for each test you create
|
||||
use Test::Deep;
|
||||
plan tests => 22;
|
||||
plan tests => 25;
|
||||
|
||||
my $session = WebGUI::Test->session;
|
||||
$session->user({userId => 3});
|
||||
my $root = WebGUI::Asset->getRoot($session);
|
||||
my $root = WebGUI::Test->asset;
|
||||
my $versionTag = WebGUI::VersionTag->getWorking($session);
|
||||
my %tag = ( tagId => $versionTag->getId, status => "pending" );
|
||||
$versionTag->set({name=>"Asset Package test"});
|
||||
|
|
@ -75,6 +76,21 @@ WebGUI::Test->addToCleanup(sub {
|
|||
cmp_deeply({}, $snippet->getMetaDataFields, 'snippet has no metadata fields');
|
||||
cmp_deeply({}, $folder->getMetaDataFields, 'folder has no metadata fields');
|
||||
|
||||
subtest 'Field with class data' => sub {
|
||||
my $meta = WebGUI::Test::Metadata->new(
|
||||
$folder, {
|
||||
classes => ['WebGUI::Asset::Wobject::Folder']
|
||||
}
|
||||
);
|
||||
my $id = $meta->fieldId;
|
||||
my $snips = $snippet->getMetaDataFields;
|
||||
my $folds = $folder->getMetaDataFields;
|
||||
ok !exists $snips->{$id}, 'snippet does not have field';
|
||||
ok exists $folds->{$id}, 'but folder does';
|
||||
$snips = $snippet->getAllMetaDataFields;
|
||||
ok exists $snips->{$id}, 'snips returns data with getAll';
|
||||
};
|
||||
|
||||
$snippet->addMetaDataField('new', 'searchEngine', '', 'Search Engine preference', 'text');
|
||||
|
||||
my @snipKeys;
|
||||
|
|
@ -224,6 +240,70 @@ cmp_deeply(
|
|||
'getMetaDataAsTemplateVariables returns proper values for folder'
|
||||
);
|
||||
|
||||
{
|
||||
my $asset = $root->addChild(
|
||||
{
|
||||
className => 'WebGUI::Asset::Snippet',
|
||||
}
|
||||
);
|
||||
WebGUI::Test->addToCleanup($asset);
|
||||
my $meta = WebGUI::Test::Metadata->new($asset);
|
||||
my $ff = $asset->getMetaDataAsFormFields;
|
||||
like $ff->{$meta->fieldName}, qr/input/, 'getMetaDataAsFormFields';
|
||||
}
|
||||
|
||||
# check that asset metadata versioning works properly
|
||||
subtest 'asset metadata versioning' => sub {
|
||||
my $asset = WebGUI::Test->asset->addChild(
|
||||
{
|
||||
className => 'WebGUI::Asset::Snippet',
|
||||
}
|
||||
);
|
||||
my $meta = WebGUI::Test::Metadata->new($asset);
|
||||
$meta->update('version one');
|
||||
sleep 1;
|
||||
my $rev2 = $asset->addRevision();
|
||||
is $meta->get(), 'version one', 'v1 for 1';
|
||||
is $meta->get($rev2), 'version one', 'v1 for 2';
|
||||
$meta->update('version two', $rev2);
|
||||
is $meta->get($rev2), 'version two', 'v2 has been set';
|
||||
is $meta->get(), 'version one', 'v1 has not been changed';
|
||||
|
||||
my $dup = $asset->duplicate;
|
||||
|
||||
my $db = $session->db;
|
||||
my $count_rev = sub {
|
||||
my $a = shift;
|
||||
my $sql = q{
|
||||
select count(*)
|
||||
from metaData_values
|
||||
where assetId = ? and revisionDate = ?
|
||||
};
|
||||
$db->quickScalar( $sql, [ $a->getId, $a->get('revisionDate') ] );
|
||||
};
|
||||
my $count_all = sub {
|
||||
my $a = shift;
|
||||
my $sql = 'select count(*) from metaData_values where assetId = ?';
|
||||
$db->quickScalar( $sql, [ $a->getId ] );
|
||||
};
|
||||
|
||||
is $count_all->($asset), 2, 'two values for original';
|
||||
is $count_all->($dup), 1, 'one value for dup';
|
||||
|
||||
is $count_rev->($asset), 1, 'one value for v1';
|
||||
is $count_rev->($rev2), 1, 'one value for v2';
|
||||
|
||||
$rev2->purgeRevision;
|
||||
|
||||
note 'after purge';
|
||||
|
||||
is $count_rev->($asset), 1, 'one value for v1';
|
||||
is $count_rev->($rev2), 0, 'no value for v2';
|
||||
|
||||
is $count_all->($asset), 1, 'one value for original';
|
||||
is $count_all->($dup), 1, 'one value for dup';
|
||||
};
|
||||
|
||||
sub buildNameIndex {
|
||||
my ($fidStruct) = @_;
|
||||
my $nameStruct;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue