moving into sub folders
This commit is contained in:
parent
175871d7b7
commit
dc74b0da8d
6 changed files with 16 additions and 16 deletions
253
t/i18n/label.t
Normal file
253
t/i18n/label.t
Normal file
|
|
@ -0,0 +1,253 @@
|
|||
#-------------------------------------------------------------------
|
||||
# WebGUI is Copyright 2001-2006 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
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
# ---- BEGIN DO NOT EDIT ----
|
||||
use strict;
|
||||
use lib '../../lib';
|
||||
use Text::Balanced qw(extract_codeblock);
|
||||
use Getopt::Long;
|
||||
use WebGUI::Operation::Help;
|
||||
use WebGUI::International;
|
||||
use WebGUI::Session;
|
||||
use Data::Dumper;
|
||||
use File::Find;
|
||||
# ---- END DO NOT EDIT ----
|
||||
|
||||
#The goal of this test is to locate all of the international labels that it
|
||||
#can and verify that they exist in all loaded language models
|
||||
|
||||
use Test::More; # increment this value for each test you create
|
||||
my $numTests = 0;
|
||||
|
||||
my $session = initialize(); # this line is required
|
||||
|
||||
# put your tests here
|
||||
|
||||
my $digits = qr/(\d+)/;
|
||||
my $bareword = qr/(\w+)/;
|
||||
my $quotelike = qr/((['"])([^'"\s]+\s*)+(['"]))/;
|
||||
my $sub_args = qr/(($quotelike|$digits)(,\s*)?)+/;
|
||||
my $sess_arg = qr/(?:\$session|\$self->session)/;
|
||||
my $subroutine = qr/
|
||||
WebGUI::International::get
|
||||
\( ##Opening paren for optional arguments
|
||||
($sub_args)
|
||||
\) ##Closing paren
|
||||
/x;
|
||||
|
||||
|
||||
my %helpTable;
|
||||
|
||||
my @helpFileSet = WebGUI::Operation::Help::_getHelpFilesList($session);
|
||||
|
||||
foreach my $helpSet (@helpFileSet) {
|
||||
my $helpName = $helpSet->[1];
|
||||
my $help = WebGUI::Operation::Help::_load($session, $helpName);
|
||||
$helpTable{ $helpName } = $help;
|
||||
}
|
||||
|
||||
##Scan #1, find all labels in the help system. body, title, @fields
|
||||
|
||||
## Array of hashes
|
||||
## each hash will have:
|
||||
## topic -> which help file it is from
|
||||
## entry -> which entry in the help file
|
||||
## tag -> which tag in the entry in the help file
|
||||
## namespace -> which help file it is form
|
||||
## label -> which help file it is form
|
||||
|
||||
my @helpLabels;
|
||||
my @sqlLabels;
|
||||
my @libLabels;
|
||||
my @objLabels;
|
||||
|
||||
diag("Getting Help labels");
|
||||
@helpLabels = getHelpLabels();
|
||||
|
||||
#diag("Getting SQL labels");
|
||||
#@sqlLabels = getSQLLabels();
|
||||
|
||||
diag("Getting subroutine labels");
|
||||
find(\&label_finder_pm, '../../lib/');
|
||||
|
||||
diag("Getting object labels");
|
||||
find(\&obj_finder_pm, '../../lib/');
|
||||
|
||||
diag ("Checking ". scalar(@helpLabels). " help labels");
|
||||
#diag ("Checking ". scalar(@sqlLabels). " SQL labels");
|
||||
diag ("Checking ". scalar(@libLabels). " library code labels");
|
||||
diag ("Checking ". scalar(@objLabels). " library code labels via object");
|
||||
|
||||
$numTests = scalar(@helpLabels)
|
||||
# + scalar(@sqlLabels)
|
||||
+ scalar(@libLabels)
|
||||
+ scalar(@objLabels)
|
||||
;
|
||||
|
||||
diag("Planning on running $numTests tests\n");
|
||||
|
||||
plan tests => $numTests;
|
||||
|
||||
diag("Help Label tests\n");
|
||||
|
||||
my $i18n = WebGUI::International->new($session);
|
||||
|
||||
foreach my $label ( @helpLabels ) {
|
||||
ok($i18n->get(@{ $label }{qw(label namespace )} ),
|
||||
sprintf "label: %s->%s inside %s->%s->%s", @{ $label }{'namespace', 'label', 'topic', 'entry', 'tag', });
|
||||
}
|
||||
|
||||
#diag("SQL Label tests\n");
|
||||
#
|
||||
#foreach my $label ( @sqlLabels ) {
|
||||
# ok($i18n->get(@{ $label }{qw(label namespace )} ),
|
||||
# sprintf "label: %s->%s inside %s", @{ $label }{'namespace', 'label', 'file', });
|
||||
#}
|
||||
#
|
||||
##Subroutine calls are now illegal, everything must be done by object methods.
|
||||
diag("Subroutine Call Label tests\n");
|
||||
|
||||
foreach my $label ( @libLabels ) {
|
||||
ok(0,
|
||||
sprintf "label: %s->%s inside %s", @{ $label }{'namespace', 'label', 'file', });
|
||||
}
|
||||
|
||||
diag("Object Method Label tests\n");
|
||||
|
||||
foreach my $label ( @objLabels ) {
|
||||
ok($i18n->get(@{ $label }{qw(label namespace )} ),
|
||||
sprintf "label: %s->%s inside %s", @{ $label }{'namespace', 'label', 'file', });
|
||||
}
|
||||
|
||||
cleanup($session); # this line is required
|
||||
|
||||
sub label_finder_pm {
|
||||
next unless /\.pm$/;
|
||||
open my $pmf, $_
|
||||
or die "unable to open file $File::Find::name: $!\n";
|
||||
my $libFile = '';
|
||||
{
|
||||
local $/;
|
||||
$libFile = <$pmf>;
|
||||
}
|
||||
close $pmf;
|
||||
while ($libFile =~ m/$subroutine/gc) {
|
||||
my ($label, $namespace) = split /,\s*/, $1;
|
||||
push @libLabels, {
|
||||
file=>$File::Find::name,
|
||||
label=>$label,
|
||||
namespace=>$namespace || 'WebGUI',
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
sub obj_finder_pm {
|
||||
next unless /\.pm$/;
|
||||
open my $pmf, $_
|
||||
or die "unable to open file $File::Find::name: $!\n";
|
||||
my $libFile = '';
|
||||
{
|
||||
local $/;
|
||||
$libFile = <$pmf>;
|
||||
}
|
||||
close $pmf;
|
||||
##Advance pos to first subroutine
|
||||
while ( my $subBody = extract_codeblock($libFile, '{}', qr/(?ms).*?^sub (\w+)\s*/) ) {
|
||||
next unless $subBody =~ /(\w+)\s*=\s*WebGUI::International->new\($sess_arg(?:,\s*($quotelike))?\)/;
|
||||
my ($obj, $namespace) = ($1,$2);
|
||||
while ( $subBody =~ /$obj\->get\(($sub_args)\)/msgc ) {
|
||||
my ($label, $local_name) = split /,\s*/, $1;
|
||||
push @objLabels, {
|
||||
file=>$File::Find::name,
|
||||
label=>$label,
|
||||
namespace=>$local_name || $namespace || 'WebGUI',
|
||||
};
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
sub getHelpLabels {
|
||||
my @helpLabels = ();
|
||||
foreach my $topic ( keys %helpTable ) {
|
||||
foreach my $entry ( keys %{ $helpTable{$topic} }) {
|
||||
##Check the title and body data
|
||||
foreach my $tag ('title','body') {
|
||||
push @helpLabels, {
|
||||
topic=>$topic,
|
||||
entry=>$entry,
|
||||
tag=>$tag,
|
||||
namespace=>$topic, ##default
|
||||
label=>$helpTable{$topic}{$entry}{$tag},
|
||||
};
|
||||
}
|
||||
|
||||
##Add all labels in the fields array
|
||||
foreach my $field (@{ $helpTable{$topic}{$entry}{fields} }) {
|
||||
push @helpLabels, {
|
||||
topic=>$topic,
|
||||
entry=>$entry,
|
||||
tag=>'fields',
|
||||
namespace=>$field->{namespace},
|
||||
label=>$field->{title},
|
||||
},
|
||||
{
|
||||
topic=>$topic,
|
||||
entry=>$entry,
|
||||
tag=>'fields',
|
||||
namespace=>$field->{namespace},
|
||||
label=>$field->{description},
|
||||
},;
|
||||
}
|
||||
}
|
||||
}
|
||||
return @helpLabels;
|
||||
}
|
||||
|
||||
sub getSQLLabels {
|
||||
my @sqlLabels = ();
|
||||
foreach my $file (qw/create.sql previousVersion.sql/) {
|
||||
my $file2 = join '/', '../..', 'docs', $file;
|
||||
open my $fh, $file2 or
|
||||
die "Unable to open $file2: $!\n";
|
||||
local $/;
|
||||
my $sql = <$fh>;
|
||||
while ($sql =~ /WebGUI::International::get\(([^\)]+)\)/gs) {
|
||||
my $args;
|
||||
($args = $1) =~ tr{\\"}{}d;
|
||||
my ($label,$namespace) = split ',', $args;
|
||||
$namespace = "WebGUI" unless $namespace;
|
||||
push @sqlLabels, {
|
||||
label => $label,
|
||||
namespace => $namespace,
|
||||
file => $file,
|
||||
};
|
||||
}
|
||||
close $fh;
|
||||
}
|
||||
return @sqlLabels;
|
||||
}
|
||||
|
||||
# ---- DO NOT EDIT BELOW THIS LINE -----
|
||||
|
||||
sub initialize {
|
||||
$|=1; # disable output buffering
|
||||
my $configFile;
|
||||
GetOptions(
|
||||
'configFile=s'=>\$configFile
|
||||
);
|
||||
exit 1 unless ($configFile);
|
||||
return WebGUI::Session->open("../..",$configFile);
|
||||
}
|
||||
|
||||
sub cleanup {
|
||||
my $session = shift;
|
||||
$session->close();
|
||||
}
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue