adding FilePump
This commit is contained in:
commit
d8a1623ea0
14 changed files with 1986 additions and 1 deletions
366
t/FilePump/Bundle.t
Normal file
366
t/FilePump/Bundle.t
Normal file
|
|
@ -0,0 +1,366 @@
|
|||
# vim:syntax=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
|
||||
#------------------------------------------------------------------
|
||||
|
||||
# Write a little about what this script tests.
|
||||
#
|
||||
#
|
||||
|
||||
use FindBin;
|
||||
use strict;
|
||||
use lib "$FindBin::Bin/../lib";
|
||||
use Test::More;
|
||||
use Test::Deep;
|
||||
use Data::Dumper;
|
||||
use URI;
|
||||
use WebGUI::Test; # Must use this before any other WebGUI modules
|
||||
use WebGUI::Session;
|
||||
|
||||
my $startTime = time();
|
||||
my $wgBday = 997966800;
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# Init
|
||||
my $session = WebGUI::Test->session;
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# Tests
|
||||
|
||||
my $tests = 46; # Increment this number for each test you create
|
||||
plan tests => 1 + $tests; # 1 for the use_ok
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# put your tests here
|
||||
|
||||
my $loaded = use_ok('WebGUI::FilePump::Bundle');
|
||||
|
||||
SKIP: {
|
||||
|
||||
skip 'Unable to load module WebGUI::FilePump::Bundle', $tests unless $loaded;
|
||||
|
||||
my $bundle = WebGUI::FilePump::Bundle->create($session);
|
||||
isa_ok($bundle, 'WebGUI::FilePump::Bundle');
|
||||
isa_ok($bundle, 'WebGUI::Crud');
|
||||
|
||||
is($bundle->get('lastModified'), 0, 'by default, lastModified is 0');
|
||||
|
||||
###################################################################
|
||||
#
|
||||
# addFile
|
||||
#
|
||||
###################################################################
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->addFile() ],
|
||||
[ 0, 'Illegal type' ],
|
||||
'addFile, checking error for no type'
|
||||
);
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->addFile('BAD_TYPE', ) ],
|
||||
[ 0, 'Illegal type' ],
|
||||
'... checking error for bad type of file to add'
|
||||
);
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->addFile('JS', ) ],
|
||||
[ 0, 'No URI' ],
|
||||
'... checking error for no uri'
|
||||
);
|
||||
|
||||
is(
|
||||
$bundle->addFile('JS', 'http://mysite.com/script.js'),
|
||||
1,
|
||||
'... adding a JS file'
|
||||
);
|
||||
cmp_ok($bundle->get('lastModified'), '>=', $startTime, '... updates lastModified');
|
||||
|
||||
is(
|
||||
$bundle->addFile('CSS', 'http://mysite.com/script.js'),
|
||||
1,
|
||||
'... okay to add a duplicate to another type'
|
||||
);
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->addFile('JS', 'http://mysite.com/script.js') ],
|
||||
[ 0, 'Duplicate URI' ],
|
||||
'... checking error message for duplicate URI'
|
||||
);
|
||||
|
||||
$bundle->addFile('JS', 'http://mysite.com/helloworld.js');
|
||||
$bundle->addFile('JS', 'file:/data/domains/mysite.com/www/uploads/XX/YY/XXYYZZ/graviticEnergyDrive.js');
|
||||
|
||||
my @fileUris = map { $_->{uri} } @{ $bundle->get('jsFiles') };
|
||||
cmp_deeply(
|
||||
[ @fileUris ],
|
||||
[qw{
|
||||
http://mysite.com/script.js
|
||||
http://mysite.com/helloworld.js
|
||||
file:/data/domains/mysite.com/www/uploads/XX/YY/XXYYZZ/graviticEnergyDrive.js
|
||||
}],
|
||||
'... checking actual jsFiles data structure contents'
|
||||
);
|
||||
|
||||
###################################################################
|
||||
#
|
||||
# moveFile{Up,Down}
|
||||
#
|
||||
###################################################################
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->moveFileUp() ],
|
||||
[ 0, 'Illegal type' ],
|
||||
'moveFileUp: checking error for no type'
|
||||
);
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->moveFileUp('BEER') ],
|
||||
[ 0, 'Illegal type' ],
|
||||
'... checking error for bad type'
|
||||
);
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->moveFileUp('JS', ) ],
|
||||
[ 0, 'No fileId' ],
|
||||
'... checking error for no fileId'
|
||||
);
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->moveFileDown() ],
|
||||
[ 0, 'Illegal type' ],
|
||||
'moveFileDown: checking error for no type'
|
||||
);
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->moveFileDown('BEER') ],
|
||||
[ 0, 'Illegal type' ],
|
||||
'... checking error for bad type'
|
||||
);
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->moveFileDown('JS', ) ],
|
||||
[ 0, 'No fileId' ],
|
||||
'... checking error for no fileId'
|
||||
);
|
||||
|
||||
my @fileIds = map { $_->{fileId} } @{ $bundle->get('jsFiles') };
|
||||
|
||||
$bundle->update({lastModified => 0});
|
||||
ok($bundle->moveFileDown('JS', $fileIds[0]), 'moveFileDown returns 1 for a successful move');
|
||||
@fileUris = map { $_->{uri} } @{ $bundle->get('jsFiles') };
|
||||
cmp_deeply(
|
||||
[ @fileUris ],
|
||||
[qw{
|
||||
http://mysite.com/helloworld.js
|
||||
http://mysite.com/script.js
|
||||
file:/data/domains/mysite.com/www/uploads/XX/YY/XXYYZZ/graviticEnergyDrive.js
|
||||
}],
|
||||
'... checking the actual order of js files'
|
||||
);
|
||||
cmp_ok($bundle->get('lastModified'), '>=', $startTime, '... updates lastModified');
|
||||
|
||||
$bundle->update({lastModified => 0});
|
||||
ok($bundle->moveFileUp('JS', $fileIds[2]), 'moveFileUp returns 1 for a successful move');
|
||||
@fileUris = map { $_->{uri} } @{ $bundle->get('jsFiles') };
|
||||
cmp_deeply(
|
||||
[ @fileUris ],
|
||||
[qw{
|
||||
http://mysite.com/helloworld.js
|
||||
file:/data/domains/mysite.com/www/uploads/XX/YY/XXYYZZ/graviticEnergyDrive.js
|
||||
http://mysite.com/script.js
|
||||
}],
|
||||
'... checking the actual order of js files'
|
||||
);
|
||||
cmp_ok($bundle->get('lastModified'), '>=', $startTime, '... updates lastModified');
|
||||
|
||||
###################################################################
|
||||
#
|
||||
# deleteFile
|
||||
#
|
||||
###################################################################
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->deleteFile() ],
|
||||
[ 0, 'Illegal type' ],
|
||||
'deleteFile: checking error for no type'
|
||||
);
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->deleteFile('BEER') ],
|
||||
[ 0, 'Illegal type' ],
|
||||
'... checking error for bad type'
|
||||
);
|
||||
|
||||
cmp_deeply(
|
||||
[ $bundle->deleteFile('JS', ) ],
|
||||
[ 0, 'No fileId' ],
|
||||
'... checking error for no fileId'
|
||||
);
|
||||
|
||||
@fileIds = map { $_->{fileId} } @{ $bundle->get('jsFiles') };
|
||||
$bundle->update({lastModified => 0});
|
||||
$bundle->deleteFile('JS', $fileIds[1]);
|
||||
@fileUris = map { $_->{uri} } @{ $bundle->get('jsFiles') };
|
||||
cmp_deeply(
|
||||
[ @fileUris ],
|
||||
[qw{
|
||||
http://mysite.com/helloworld.js
|
||||
http://mysite.com/script.js
|
||||
}],
|
||||
'... checking the actual deletion of js files'
|
||||
);
|
||||
cmp_ok($bundle->get('lastModified'), '>=', $startTime, '... updates lastModified');
|
||||
|
||||
###################################################################
|
||||
#
|
||||
# fetch
|
||||
#
|
||||
###################################################################
|
||||
|
||||
my $root = WebGUI::Asset->getRoot($session);
|
||||
|
||||
my $snippet = $root->addChild({
|
||||
className => 'WebGUI::Asset::Snippet',
|
||||
url => 'filePumpSnippet',
|
||||
snippet => 'Pump a Snippet',
|
||||
});
|
||||
|
||||
my $fileAsset = $root->addChild({
|
||||
className => 'WebGUI::Asset::File',
|
||||
url => 'filePumpFileAsset',
|
||||
filename => 'pumpfile',
|
||||
});
|
||||
|
||||
$fileAsset->getStorageLocation->addFileFromScalar('pumpfile', 'Pump up the jam');
|
||||
|
||||
my $snippetTag = WebGUI::VersionTag->getWorking($session);
|
||||
WebGUI::Test->tagsToRollback($snippetTag);
|
||||
$snippetTag->commit;
|
||||
|
||||
my $guts;
|
||||
$guts = $bundle->fetchAsset(URI->new('asset://filePumpSnippet'));
|
||||
cmp_deeply(
|
||||
$guts,
|
||||
{
|
||||
content => 'Pump a Snippet',
|
||||
lastModified => re('^\d+$'),
|
||||
},
|
||||
'fetchAsset: retrieved a snippet'
|
||||
);
|
||||
|
||||
$guts = $bundle->fetchAsset(URI->new('asset://filePumpFileAsset'));
|
||||
cmp_deeply(
|
||||
$guts,
|
||||
{
|
||||
content => 'Pump up the jam',
|
||||
lastModified => re('^\d+$'),
|
||||
},
|
||||
'fetchAsset: retrieved a file asset'
|
||||
);
|
||||
|
||||
my $path = $fileAsset->getStorageLocation->getPath($fileAsset->get('filename'));
|
||||
my $urilet = URI->new('file:'.$path);
|
||||
|
||||
$guts = $bundle->fetchFile($urilet);
|
||||
cmp_deeply(
|
||||
$guts,
|
||||
{
|
||||
content => 'Pump up the jam',
|
||||
lastModified => re('^\d+$'),
|
||||
},
|
||||
'fetchFile: retrieved a file from the filesystem'
|
||||
);
|
||||
|
||||
###################################################################
|
||||
#
|
||||
# getPathClassDir
|
||||
#
|
||||
###################################################################
|
||||
|
||||
my $dir = $bundle->getPathClassDir();
|
||||
isa_ok($dir, 'Path::Class::Dir');
|
||||
my $timestampDir = $dir->dir_list(-1, 1);
|
||||
cmp_deeply(
|
||||
[ split /\./, $timestampDir ],
|
||||
[ 'new-bundle', 0 ],
|
||||
'... directory has correct name and timestamp'
|
||||
);
|
||||
|
||||
$dir = $bundle->getPathClassDir($wgBday);
|
||||
isa_ok($dir, 'Path::Class::Dir');
|
||||
$timestampDir = $dir->dir_list(-1, 1);
|
||||
cmp_deeply(
|
||||
[ split /\./, $timestampDir ],
|
||||
[ 'new-bundle', $wgBday ],
|
||||
'... directory has correct name and timestamp when timestamp is specified'
|
||||
);
|
||||
|
||||
###################################################################
|
||||
#
|
||||
# deleteFiles
|
||||
#
|
||||
###################################################################
|
||||
|
||||
$bundle->deleteFiles('JS');
|
||||
$bundle->deleteFiles('CSS');
|
||||
|
||||
cmp_deeply($bundle->get('jsFiles'), [], ' deleteFiles deleted all JS URIs');
|
||||
cmp_deeply($bundle->get('cssFiles'), [], ' ... deleted all CSS URIs');
|
||||
|
||||
###################################################################
|
||||
#
|
||||
# build
|
||||
#
|
||||
###################################################################
|
||||
|
||||
my $oldBuildDir = $bundle->getPathClassDir($wgBday);
|
||||
$oldBuildDir->mkpath;
|
||||
|
||||
ok(-e $oldBuildDir->stringify && -d _, 'No problems creating old build directory');
|
||||
$bundle->update({lastBuild => $wgBday});
|
||||
|
||||
$snippet->update({snippet => qq|\n\nfunction doNothing()\n{ var foo = 'bar';} |});
|
||||
|
||||
$fileAsset->getStorageLocation->deleteFile('pumpfile');
|
||||
$fileAsset->getStorageLocation->addFileFromScalar('pumpfile.css', qq| body {\npadding: 0px;}\n\n|);
|
||||
$fileAsset->update({filename => 'pumpfile.css'});
|
||||
|
||||
$bundle->addFile('JS', 'asset://filePumpSnippet');
|
||||
$bundle->addFile('CSS', 'asset://filePumpFileAsset');
|
||||
my ($buildFlag, $error) = $bundle->build();
|
||||
ok($buildFlag, 'build returns true when there are no errors');
|
||||
isnt($bundle->get('lastBuild'), $wgBday, '... lastBuild time updated');
|
||||
|
||||
my $buildDir = $bundle->getPathClassDir();
|
||||
isnt($buildDir->stringify, $oldBuildDir->stringify, '... build directory did actually change');
|
||||
ok(-e $buildDir->stringify && -d _, '... new build directory created');
|
||||
ok(!-e $oldBuildDir->stringify && !-d _, '... old build directory deleted');
|
||||
my $jsFile = $buildDir->file($bundle->bundleUrl . '.js');
|
||||
my $cssFile = $buildDir->file($bundle->bundleUrl . '.css');
|
||||
ok(-e $jsFile->stringify && -f _ && -s _, '... minified JS file built, not empty');
|
||||
ok(-e $cssFile->stringify && -f _ && -s _, '... minified CSS file built, not empty');
|
||||
|
||||
###################################################################
|
||||
#
|
||||
# delete
|
||||
#
|
||||
###################################################################
|
||||
|
||||
$bundle->delete;
|
||||
ok(!-e $buildDir->stringify && !-d _, 'delete deletes the current build directory deleted');
|
||||
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# Cleanup
|
||||
END {
|
||||
$session->db->write('delete from filePumpBundle');
|
||||
}
|
||||
#vim:ft=perl
|
||||
56
t/Macro/FilePump.t
Normal file
56
t/Macro/FilePump.t
Normal file
|
|
@ -0,0 +1,56 @@
|
|||
# vim:syntax=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
|
||||
#------------------------------------------------------------------
|
||||
|
||||
# Write a little about what this script tests.
|
||||
#
|
||||
#
|
||||
|
||||
use FindBin;
|
||||
use strict;
|
||||
use lib "$FindBin::Bin/../lib";
|
||||
use Test::More;
|
||||
use WebGUI::Test; # Must use this before any other WebGUI modules
|
||||
use WebGUI::Session;
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# Init
|
||||
my $session = WebGUI::Test->session;
|
||||
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# Tests
|
||||
|
||||
my $tests = 0;
|
||||
plan tests => 1 + $tests;
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# put your tests here
|
||||
|
||||
my $macro = 'WebGUI::Macro::FilePump';
|
||||
my $loaded = use_ok($macro);
|
||||
|
||||
my $bundle = WebGUI::FilePump::Bundle->create($session, { bundleName => 'test bundle'});
|
||||
|
||||
SKIP: {
|
||||
|
||||
skip "Unable to load $macro", $tests unless $loaded;
|
||||
|
||||
}
|
||||
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
# Cleanup
|
||||
END {
|
||||
|
||||
$bundle->delete;
|
||||
|
||||
}
|
||||
#vim:ft=perl
|
||||
|
|
@ -56,6 +56,7 @@ my @groupsToDelete;
|
|||
my @usersToDelete;
|
||||
my @sessionsToDelete;
|
||||
my @storagesToDelete;
|
||||
my @tagsToRollback;
|
||||
|
||||
BEGIN {
|
||||
|
||||
|
|
@ -164,6 +165,9 @@ END {
|
|||
$session->var->end;
|
||||
$session->close;
|
||||
}
|
||||
foreach my $tag (@tagsToRollback) {
|
||||
$tag->rollback;
|
||||
}
|
||||
if ($ENV{WEBGUI_TEST_DEBUG}) {
|
||||
$Test->diag('Sessions: '.$SESSION->db->quickScalar('select count(*) from userSession'));
|
||||
$Test->diag('Scratch : '.$SESSION->db->quickScalar('select count(*) from userSessionScratch'));
|
||||
|
|
@ -390,6 +394,20 @@ sub webguiBirthday {
|
|||
return 997966800 ;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 webguiBirthday ( )
|
||||
|
||||
This constant is used in several tests, so it's reproduced here so it can
|
||||
be found easy. This is the epoch date when WebGUI was released.
|
||||
|
||||
=cut
|
||||
|
||||
sub webguiBirthday {
|
||||
return 997966800 ;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
|
@ -461,6 +479,21 @@ sub sessionsToDelete {
|
|||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 tagsToRollback ( $tag )
|
||||
|
||||
Push a list of version tags to rollback at the end of the test.
|
||||
|
||||
This is a class method.
|
||||
|
||||
=cut
|
||||
|
||||
sub tagsToRollback {
|
||||
my $class = shift;
|
||||
push @tagsToRollback, @_;
|
||||
}
|
||||
|
||||
#----------------------------------------------------------------------------
|
||||
|
||||
=head2 usersToDelete ( $user, [$user, ...] )
|
||||
|
||||
Push a list of user objects onto the stack of groups to be automatically deleted
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue