Fill out FilePump macro tests and fix bugs.
This commit is contained in:
parent
d8a1623ea0
commit
de3b249a2b
2 changed files with 102 additions and 10 deletions
|
|
@ -12,6 +12,7 @@ package WebGUI::Macro::FilePump;
|
|||
|
||||
use strict;
|
||||
use WebGUI::FilePump::Bundle;
|
||||
use Path::Class;
|
||||
|
||||
=head1 NAME
|
||||
|
||||
|
|
@ -59,39 +60,59 @@ sub process {
|
|||
});
|
||||
return '' unless $bundleId and $bundleId->[0];
|
||||
|
||||
my $bundle = WebGUI::FilePump::Bundle->new($session, $bundleId);
|
||||
my $bundle = WebGUI::FilePump::Bundle->new($session, $bundleId->[0]);
|
||||
return '' unless $bundle;
|
||||
my $uploadsDir = Path::Class::Dir->new($session->config->get('uploadsPath'));
|
||||
my $uploadsUrl = Path::Class::Dir->new($session->config->get('uploadsURL'));
|
||||
|
||||
##Normal mode
|
||||
if (! $session->var->isAdminOn) {
|
||||
my $dir = $bundle->getPathClassDir;
|
||||
my $dir = $bundle->getPathClassDir->relative($uploadsDir);
|
||||
if ($type eq 'js' || $type eq 'javascript') {
|
||||
my $file = $dir->file($bundle->bundleUrl . '.js');
|
||||
return sprintf qq|<script type="type/javascript" src="%s">\n|, $file->stringify;
|
||||
my $file = $uploadsUrl->file($dir, $bundle->bundleUrl . '.js');
|
||||
return sprintf qq|<script type="text/javascript" src="%s">\n|, $file->stringify;
|
||||
}
|
||||
elsif ($type eq 'css') {
|
||||
my $file = $dir->file($bundle->bundleUrl . '.css');
|
||||
return sprintf qq|<link rel="stylesheet" type="type/css" href="%s">\n|, $file->stringify;
|
||||
my $file = $uploadsUrl->file($dir, $bundle->bundleUrl . '.css');
|
||||
return sprintf qq|<link rel="stylesheet" type="text/css" href="%s">\n|, $file->stringify;
|
||||
}
|
||||
else {
|
||||
return '';
|
||||
}
|
||||
}
|
||||
##Admin/Design mode
|
||||
else {
|
||||
my $template;
|
||||
my $files;
|
||||
if ($type eq 'js' || $type eq 'javascript') {
|
||||
$template = qq|<script type="type/javascript" src="%s">\n|;
|
||||
$template = qq|<script type="text/javascript" src="%s">\n|;
|
||||
$files = $bundle->get('jsFiles');
|
||||
}
|
||||
elsif ($type eq 'css') {
|
||||
$template = qq|<link rel="stylesheet" type="type/css" href="%s">\n|;
|
||||
$template = qq|<link rel="stylesheet" type="text/css" href="%s">\n|;
|
||||
$files = $bundle->get('cssFiles');
|
||||
}
|
||||
else {
|
||||
return '';
|
||||
}
|
||||
foreach my $file (@{ $files }) {
|
||||
$output .= sprintf $template, $file->{uri};
|
||||
my $uri = URI->new($file->{uri});
|
||||
my $scheme = $uri->scheme;
|
||||
my $url = '';
|
||||
if ($scheme eq 'asset') {
|
||||
$url = $uri->opaque;
|
||||
}
|
||||
elsif ($scheme eq 'file') {
|
||||
my $file = Path::Class::File->new($uri->path);
|
||||
my $uploadsRelFile = $file->relative($uploadsDir);
|
||||
$url = $uploadsUrl->file($uploadsRelFile)->stringify;
|
||||
|
||||
}
|
||||
elsif ($scheme eq 'http' or $scheme eq 'https') {
|
||||
$url = $uri->as_string;
|
||||
}
|
||||
$url =~ tr{/}{/}s;
|
||||
$output .= sprintf $template, $url;
|
||||
}
|
||||
return $output;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -28,7 +28,7 @@ my $session = WebGUI::Test->session;
|
|||
#----------------------------------------------------------------------------
|
||||
# Tests
|
||||
|
||||
my $tests = 0;
|
||||
my $tests = 6;
|
||||
plan tests => 1 + $tests;
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
|
@ -43,6 +43,77 @@ SKIP: {
|
|||
|
||||
skip "Unable to load $macro", $tests unless $loaded;
|
||||
|
||||
my $root = WebGUI::Asset->getRoot($session);
|
||||
|
||||
my $snippet = $root->addChild({
|
||||
className => 'WebGUI::Asset::Snippet',
|
||||
url => 'filePumpSnippet',
|
||||
snippet => qq|\n\nfunction doNothing()\n{ var foo = 'bar';} |,
|
||||
});
|
||||
|
||||
my $fileAsset = $root->addChild({
|
||||
className => 'WebGUI::Asset::File',
|
||||
url => 'filePumpFileAsset',
|
||||
filename => 'pumpfile',
|
||||
});
|
||||
|
||||
$fileAsset->getStorageLocation->addFileFromScalar('pumpfile.css', qq| body {\npadding: 0px;}\n\n|);
|
||||
|
||||
my $snippetTag = WebGUI::VersionTag->getWorking($session);
|
||||
WebGUI::Test->tagsToRollback($snippetTag);
|
||||
$snippetTag->commit;
|
||||
|
||||
$bundle->addFile('JS', 'asset://filePumpSnippet');
|
||||
$bundle->addFile('CSS', 'asset://filePumpFileAsset');
|
||||
|
||||
my $storedFile = WebGUI::Storage->create($session);
|
||||
WebGUI::Test->storagesToDelete($storedFile);
|
||||
$storedFile->addFileFromScalar('storedJS.js', qq|function helloWorld() { alert("Hellow world");}|, );
|
||||
$bundle->addFile('JS', 'file:'. $storedFile->getPath('storedJS.js'));
|
||||
|
||||
my $uploadsURL = $session->config->get('uploadsURL');
|
||||
|
||||
$bundle->build();
|
||||
is(
|
||||
WebGUI::Macro::FilePump::process($session, 'test bundle', 'JS'),
|
||||
sprintf(qq|<script type="text/javascript" src="%s">\n|,
|
||||
join('/', $uploadsURL, 'filepump', $bundle->bundleUrl . '.'. $bundle->get('lastBuild'), $bundle->bundleUrl.'.js'),
|
||||
),
|
||||
'... check JS file, normal mode'
|
||||
);
|
||||
is(
|
||||
WebGUI::Macro::FilePump::process($session, 'test bundle', 'CSS'),
|
||||
sprintf(qq|<link rel="stylesheet" type="text/css" href="%s">\n|,
|
||||
join('/', $uploadsURL, 'filepump', $bundle->bundleUrl . '.'. $bundle->get('lastBuild'), $bundle->bundleUrl.'.css'),
|
||||
),
|
||||
'... check CSS file, normal mode'
|
||||
);
|
||||
is(
|
||||
WebGUI::Macro::FilePump::process($session, 'test bundle', 'OTHER'),
|
||||
'',
|
||||
'... check illegal file type access returns empty string'
|
||||
);
|
||||
|
||||
$session->var->switchAdminOn();
|
||||
is(
|
||||
WebGUI::Macro::FilePump::process($session, 'test bundle', 'JS'),
|
||||
sprintf(qq|<script type="text/javascript" src="%s">\n<script type="text/javascript" src="%s">\n|,
|
||||
'/filePumpSnippet', $storedFile->getUrl('storedJS.js')
|
||||
),
|
||||
'... check JS file, normal mode'
|
||||
);
|
||||
is(
|
||||
WebGUI::Macro::FilePump::process($session, 'test bundle', 'CSS'),
|
||||
sprintf(qq|<link rel="stylesheet" type="text/css" href="/filePumpFileAsset">\n|, $fileAsset->getUrl),
|
||||
'... check CSS file, normal mode'
|
||||
);
|
||||
is(
|
||||
WebGUI::Macro::FilePump::process($session, 'test bundle', 'OTHER'),
|
||||
'',
|
||||
'... check illegal file type access returns empty string'
|
||||
);
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue