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
74
t/Storage/utf8_filenames.t
Normal file
74
t/Storage/utf8_filenames.t
Normal file
|
|
@ -0,0 +1,74 @@
|
|||
#-------------------------------------------------------------------
|
||||
# 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
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
#The goal of this test is to checkout uft8 handling in filenames.
|
||||
|
||||
use utf8;
|
||||
use FindBin;
|
||||
use strict;
|
||||
use lib "$FindBin::Bin/..//lib";
|
||||
|
||||
use WebGUI::Test;
|
||||
use WebGUI::Session;
|
||||
use WebGUI::Storage;
|
||||
|
||||
use Test::More;
|
||||
use Test::Deep;
|
||||
use Encode;
|
||||
use Cwd ();
|
||||
|
||||
my $session = WebGUI::Test->session;
|
||||
|
||||
plan tests => 4;
|
||||
|
||||
my $storage = WebGUI::Storage->create($session);
|
||||
WebGUI::Test->addToCleanup($storage);
|
||||
|
||||
my $filename = "Viel_Spa\x{00DF}.txt";
|
||||
utf8::upgrade($filename);
|
||||
$storage->addFileFromScalar($filename, 'some content');
|
||||
ok -e $storage->getPath($filename), 'addFileFromScalar: wrote filename with UTF-8 name';
|
||||
|
||||
my $filesystem_storage = WebGUI::Storage->create($session);
|
||||
WebGUI::Test->addToCleanup($filesystem_storage);
|
||||
|
||||
$filesystem_storage->addFileFromFilesystem($storage->getPath($filename));
|
||||
ok -e $filesystem_storage->getPath($filename), 'addFileFromFilesystem: brought file over with UTF-8 name';
|
||||
|
||||
cmp_deeply(
|
||||
$filesystem_storage->getFiles(),
|
||||
[ $filename ],
|
||||
'getFiles: returns names in UTF-8'
|
||||
);
|
||||
|
||||
my $copy_name = "Ca\x{0303}on.txt";
|
||||
utf8::upgrade($copy_name);
|
||||
$filesystem_storage->copyFile($filename, $copy_name);
|
||||
|
||||
cmp_bag(
|
||||
$filesystem_storage->getFiles(),
|
||||
[ $filename, $copy_name ],
|
||||
'copyFile: copies files handling UTF-8 correctly'
|
||||
)
|
||||
or diag(
|
||||
"GOT: " . join( ', ', map { nice_string($_) } @{ $filesystem_storage->getFiles } )
|
||||
. " EXPECT: " . join( ', ', map { nice_string($_) } ( $filename, $copy_name ) )
|
||||
);
|
||||
|
||||
sub nice_string {
|
||||
join("",
|
||||
map { $_ > 255 ? # if wide character...
|
||||
sprintf('\\x{%04X}', $_) : # \x{...}
|
||||
chr($_) =~ /[[:cntrl:]]/ ? # else if control character ...
|
||||
sprintf('\\x%02X', $_) : # \x..
|
||||
quotemeta(chr($_)) # else quoted or as themselves
|
||||
} unpack("W*", $_[0])); # unpack Unicode characters
|
||||
}
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue