diff -r 238f4cb8391f -r ad8ffc8e1982 buildframework/helium/tools/preparation/getenv.pl --- a/buildframework/helium/tools/preparation/getenv.pl Thu Jun 10 13:50:24 2010 +0800 +++ b/buildframework/helium/tools/preparation/getenv.pl Mon Jul 26 11:04:29 2010 +0800 @@ -17,55 +17,59 @@ #Description: Cleaned version. #============================================================================ -use strict; # strict naming rules -use Cwd; # figuring out directories -use Data::Dumper; # debugging purposes -use XML::Simple; # for using xml parser -use File::Copy; # for copying files -use SOAP::Lite; # SOAP interface for s60build server -use Getopt::Long; # parameter handling +use strict; # strict naming rules +use Cwd; # figuring out directories +use Data::Dumper; # debugging purposes +use XML::Simple; # for using xml parser +use File::Copy; # for copying files +use Getopt::Long; # parameter handling Getopt::Long::Configure( "bundling_override","ignore_case_always" ); -# uncomment to get SOAP debug traces -# use SOAP::Lite +trace => 'debug'; +use File::Temp qw/ tempdir /; # for creating unique temp directories + +# uncomment to get temp dir debug traces +$File::Temp::DEBUG = 1; # variables for commandline params -my( $param_help, # print help - $param_server, # manually select server - $param_release_path, # where are the releases located in the server - $param_debug, # parameter for controlling extra debug prints - $param_latest, # just grab the latest build (requires product name) - $param_keepgoing, # continue even if dependency is missing - $param_print_only, # do nothing but print system calls - $param_skipITD, # do not extract internal, testsources and documentation - $param_emuenv, # extract only emulator environment - $param_start_directly,# starts extracting directly without waiting user acceptance - $param_product, # manually insert product name - $param_skip_deps, # do not extract dependencies - $param_grace, # do not check for grace access - $param_no_soap, # dont use soap connection - @param_exclude, # exclude list - @param_include ); # include list +my( $param_help, # print help + $param_server, # manually select server + $param_release_path, # where are the releases located in the server + $param_debug, # parameter for controlling extra debug prints + $param_latest, # just grab the latest build (requires product name) + $param_keepgoing, # continue even if dependency is missing + $param_print_only, # do nothing but print system calls + $param_skipITD, # do not extract internal, testsources and documentation + $param_emuenv, # extract only emulator environment + $param_start_directly,# starts extracting directly without waiting user acceptance + $param_product, # manually insert product name + $param_skip_deps, # do not extract dependencies + $param_grace, # do not check for grace access + @param_exclude, # exclude list + @param_include, # include list + @force_include, # force include list + $param_all ); # extract all zips # read commandline parameters -my $result = GetOptions('help' => \$param_help, # print help - 'h' => \$param_help, # print help - 'latest' => \$param_latest, # just grab the latest build (requires product name) - 'server=s' => \$param_server, # manually select server - 'path=s' => \$param_release_path, # extract this release directly - 'verbose' => \$param_debug, # verbose debug print - 'k' => \$param_keepgoing, # continue even if there is any problems - 'p' => \$param_print_only, # do nothing but print system calls - 'skipitd' => \$param_skipITD, # Deprecated: do not extract internal, testsources and documentation - 'emu' => \$param_emuenv, # Deprecated: extract only emulator environment - 'start' => \$param_start_directly, # starts extracting directly without waiting user acceptance - 'product=s' => \$param_product, # manually insert product name - 'x=s' => \@param_exclude, # filer list for excluding zips - 'exclude=s' => \@param_exclude, # filer list for excluding zips - 'i=s' => \@param_include, # filer list for including zips - 'include=s' => \@param_include, # filer list for including zips - 'nodeps' => \$param_skip_deps, # do not extract dependencies - 'grace' => \$param_grace, # try to DL from GRACE - 'nosoap' => \$param_no_soap ); # dont try using SOAP for s60builds server +my $result = GetOptions('help' => \$param_help, # print help + 'h' => \$param_help, # print help + 'latest' => \$param_latest, # just grab the latest build (requires product name) + 'server=s' => \$param_server, # manually select server + 'path=s' => \$param_release_path, # extract this release directly + 'verbose' => \$param_debug, # verbose debug print + 'k' => \$param_keepgoing, # continue even if there is any problems + 'p' => \$param_print_only, # do nothing but print system calls + 'skipitd' => \$param_skipITD, # Deprecated: do not extract internal, testsources and documentation + 'emu' => \$param_emuenv, # Deprecated: extract only emulator environment + 'start' => \$param_start_directly, # starts extracting directly without waiting user acceptance + 'product=s' => \$param_product, # manually insert product name + 'x=s' => \@param_exclude, # filer list for excluding zips + 'exclude=s' => \@param_exclude, # filer list for excluding zips + 'i=s' => \@param_include, # filer list for including zips + 'include=s' => \@param_include, # filer list for including zips + 'f=s' => \@force_include, # filer list for including zips if default tag is false + 'force=s' => \@force_include, # filer list for including zips if default tag is false + 'all' => \$param_all, # extract all zip whether default tag is true or false + 'nodeps' => \$param_skip_deps, # do not extract dependencies + 'grace' => \$param_grace); # try to DL from GRACE # enums for error situations my $warning = 1; @@ -74,28 +78,25 @@ my $cannotContinue = 4; # common global variables -my $metaDataXml; # path to metadata file +my $metaDataXml; # path to metadata file my $currentReleaseXml; # path to currentRelease.xml if exists my $pathToReleaseFolder; # path to server that has releases my $defaultServiceName; # default name for service (s60rnd) -my $pathToUnzip; # path to unzip tool -my $tmpDlDir; # path to temp dir where we'll DL packages to -my $tmpDir; # path to temp dir where we extract packages from -my $returnValue; # holds the error codes coming from 7-zip -my $graceServer; # path to local grace server if accessible -my $logFile; # log file for troubleshooting -my %packageHash; # hash containing zips to extract -my @finalZipList; # contains final list of files to unzip -my $getEnvVersion; # version of this getenv script -my $soapConnection; # holding boolean value wheter we have connection s60builds server -my $soapSessionID; # holds the session ID received from SOAP server +my $pathToUnzip; # path to unzip tool +my $tmpDlDir; # path to temp dir where we'll DL packages to +my $tmpDir; # path to temp dir where we extract packages from +my $returnValue; # holds the error codes coming from 7-zip +my $graceServer; # path to local grace server if accessible +my $logFile; # log file for troubleshooting +my %packageHash; # hash containing zips to extract +my @finalZipList; # contains final list of files to unzip +my $getEnvVersion; # version of this getenv script my $defaultPathToServer; # default value for the server -my $soapServiceURL = undef; # list of GRACE samba shares - must match to @graceNameList -my @graceList = (); +my @hydraList = (); # must match to @graceList -my @graceNameList = (); +my @hydraNameList = (); #these 2 lists need to match my @serviceList = (); @@ -109,18 +110,8 @@ $pathToReleaseFolder = undef; $defaultPathToServer = undef; $pathToUnzip = "7za"; -$getEnvVersion = "2.4.0"; - -# first open/create log file -#open( LOGFILE, ">> $logFile" ) or handleError( "cant create log file: $!", $warning ); -eval { - open( LOGFILE, ">> getcwd.'/output/logs/getenv.log'" ); -}; - if ($@) #if exception - { - open( LOGFILE, ">> getcwd.'/getenv.log'" ) ; - } - +$getEnvVersion = "2.4.9"; + print "S60 RnD environment getter v.$getEnvVersion\n\n"; printLog( "getenv.pl version $getEnvVersion" ); @@ -136,273 +127,253 @@ printLog( "Following release we will extract: $metaDataXml" ); PrintFinalWarning( ); DownloadRelease( ); -# if we have SOAP connection we should end it -if( $soapConnection ) { - my $sessionInfo = EndSoapConnection( ); - print "\n\n".$sessionInfo->{'Info'}."\n\n" if( $sessionInfo->{'Info'} ); -} exit 0; sub ValidateInputs { - print_help( ) if ( $param_help ); - - # try to get version info from s60builds SOAP server - my $versionInfoFromServer = GetSoapVersion( ) if( !$param_no_soap ); - if( $versionInfoFromServer ) { - # we have access to SOAP server - printLog( "SOAP: access OK" ); - $soapConnection = 1; - - # lets not start soap if prompt only is defined - $soapConnection = 0 if $param_print_only; - - printLog( "SOAP: latest OK version: ".$versionInfoFromServer->{'LatestOK'}->{'Version'} ); - printLog( "SOAP: latest OK date: ".$versionInfoFromServer->{'LatestOK'}->{'Date'} ); - printLog( "SOAP: latest version: ".$versionInfoFromServer->{'Latest'}->{'Version'} ); - printLog( "SOAP: latest date: ".$versionInfoFromServer->{'Latest'}->{'Date'} ); - - # compare version nmbrs and prompt user if outdated getenv - if( $getEnvVersion < $versionInfoFromServer->{'LatestOK'}->{'Version'} ) { - HandleError( "Your getenv is outdated and can not be usedanymore\nPlease get newer from the server.", $cannotContinue ); - } - } - else { - printLog( "SOAP: we dont have SOAP access" ); - $soapConnection = 0; - } + print_help( ) if ( $param_help ); + + if( @param_exclude and @param_include ) { + HandleError( "you cant specify include and exclude lists at the same time!", $cannotContinue ); + } - if( @param_exclude and @param_include ) { - HandleError( "you cant specify include and exclude lists at the same time!", $cannotContinue ); - } + # checking wheter we are in root of the substituted drive (if -start param is not specified) + if( ! $param_start_directly and + ! getcwd =~ /[a-zA-Z]:\// and + $param_keepgoing ) { + HandleError( "You should run getenv only in root of the substituted drive\nYou can use -k as keep going parameter if you think it is ok to proceed", $cannotContinue ); + } - # checking wheter we are in root of the substituted drive (if -start param is not specified) - if( ! $param_start_directly and - ! getcwd =~ /[a-zA-Z]:\// and - $param_keepgoing ) { - HandleError( "You should run getenv only in root of the substituted drive\nYou can use -k as keep going parameter if you think it is ok to proceed", $cannotContinue ); - } + # ok we are in root. Is the drive empty? + my $xmlFile = 0; + my $driveEmpty = 1; + + opendir( ROOT, "/" ) or HandleError( "cant read root dir: $!", $warning ); + my @filesFound = readdir( ROOT ); + closedir( ROOT ); + foreach my $file( @filesFound ) { + next if $file =~ /^\.[\.]?$/; + next if $file =~ /getenv/; + $xmlFile = 1 if $file =~ /.*metadata.*\.xml/; + $xmlFile = 1 if $file =~ /currentRelease\.xml/; + $driveEmpty = 0; + } + + printLog( "xml files: $xmlFile" ); + printLog( "drive empty: $driveEmpty" ); - # ok we are in root. Is the drive empty? - my $xmlFile = 0; - my $driveEmpty = 1; - - opendir( ROOT, "/" ) or HandleError( "cant read root dir: $!", $warning ); - my @filesFound = readdir( ROOT ); - closedir( ROOT ); - foreach my $file( @filesFound ) { - next if $file =~ /^\.[\.]?$/; - next if $file =~ /getenv/; - $xmlFile = 1 if $file =~ /.*metadata.*\.xml/; - $xmlFile = 1 if $file =~ /currentRelease\.xml/; - $driveEmpty = 0; - } - - printLog( "xml files: $xmlFile" ); - printLog( "drive empty: $driveEmpty" ); + # if drive is not empty and no xmls found ==> print warning (if -start param not specified) + if( ! $param_start_directly and ! $xmlFile and ! $driveEmpty ) { + HandleError( "The drive you are about to extract environment is not empty!\nHit CTRL-C to break now or to continue", $promptUser ); + } - # if drive is not empty and no xmls found ==> print warning (if -start param not specified) - if( ! $param_start_directly and ! $xmlFile and ! $driveEmpty ) { - HandleError( "The drive you are about to extract environment is not empty!\nHit CTRL-C to break now or to continue", $promptUser ); - } + # if there is valid metadata.xml in root, params like path or latest doesn't make any sense + if( $xmlFile ) { + foreach my $file( @filesFound ) { + if( $file =~ /.*metadata(_(\d*))?.xml$/i ) { + print "metadata file found!\n"; + if( ValidateXmlFile( getcwd.$file ) ) { + $metaDataXml = getcwd.$file; + last; + } + } + } + } - # if there is valid metadata.xml in root, params like path or latest doesn't make any sense - if( $xmlFile ) { - foreach my $file( @filesFound ) { - if( $file =~ /.*metadata(_(\d*))?.xml$/i ) { - print "metadata file found!\n"; - if( ValidateXmlFile( getcwd.$file ) ) { - $metaDataXml = getcwd.$file; - last; - } - } - } + if( $metaDataXml ) { + if( $param_latest or $param_release_path ) { + print "It doesnt make sense to use 'path' or 'latest' parameter while having metadata.xml in root!\n\n"; + print_help( ); + exit 0; } - if( $metaDataXml ) { - if( $param_latest or $param_release_path ) { - print "It doesnt make sense to use 'path' or 'latest' parameter while having metadata.xml in root!\n\n"; - print_help( ); - exit 0; - } - - # we should ask correct grace share if xmlfile !server !start - if( !$param_server and ! $param_start_directly ) { - print "For your convenience it is recommended to use GRACE samba share close to you.\n"; - # prompt user wheter he wants to use GRACE - my $networkAccessVerified = 0; - while( $networkAccessVerified eq 0 ) { - my $wantedServer = FixPaths( $graceList[ ReturnMenuIndex( "Please select share closest to you", @graceNameList ) ] ); - - if( $wantedServer eq FixPaths( $graceList[0] ) ) { - HandleError( "Please notice that access to $graceList[0] will be removed from wk50 onwards. Now would be perfect time to get yourself a GRACE access.", $promptUser ); - } - - printLog( "selected: $wantedServer - accessing.." ); - if( opendir( GRACETEST, $wantedServer ) ) { - printLog( "connection tested OK" ); - $networkAccessVerified = 1; - $pathToReleaseFolder = $wantedServer; - } - else { - print "Unable to access $wantedServer\nPlease select another network share.\n"; - } - } - } - - # in case we have metadata in \ and -start defined, look grace automatically - elsif( !$param_server and $param_start_directly ) { - $pathToReleaseFolder = FindGraceServer( ); - } - } + # we should ask correct grace share if xmlfile !server !start + if( !$param_server and ! $param_start_directly ) { + print "For your convenience it is recommended to use HYDRA samba share close to you.\n"; + # prompt user wheter he wants to use GRACE + my $networkAccessVerified = 0; + while( $networkAccessVerified eq 0 ) { + my $wantedServer = FixPaths( $hydraList[ ReturnMenuIndex( "Please select share closest to you", @hydraNameList ) ] ); - # ToDo: if there is not metadata.xml in root check if we have already env. Possibly update? - - # is 'path' parameter is used, find out (wheter there exists) valid metadata.xml - if( $param_release_path ) { - if( $param_latest or $param_product ) { - print "It doesnt make sense to use 'path' or 'latest' parameter while having metadata.xml in root!\n\n"; - print_help( ); - exit 0; + if( $wantedServer eq FixPaths( $hydraList[0] ) ) { + HandleError( "Please notice that access to $hydraList[0] will be removed from wk50 onwards. Now would be perfect time to get yourself a GRACE access.", $promptUser ); } - $metaDataXml = FixPaths( $param_release_path ); - $metaDataXml .= SearchValidXml( $metaDataXml ); - printLog( "setting metadata: $metaDataXml" ); - } - - # handle server parameter - # simply just verify accessablility and fix path - if( $param_server ) { - $pathToReleaseFolder = FixPaths( $param_server ); - opendir( OPENTEST, $pathToReleaseFolder ) or HandleError( "Unable to access given server path: $pathToReleaseFolder\n$!", $cannotContinue ); - closedir( OPENTEST ); - } - - # param_latest is used to just get latest release - requires product - if( $param_latest ) { - if( $param_product ) { - $param_product = FixPaths( $param_product ); - - # once the network share is unavailable then tries to find grace share - $pathToReleaseFolder = FindGraceServer( ); - - opendir( RELDIR, $pathToReleaseFolder.$defaultServiceName.$param_product ) or die "unable to open $pathToReleaseFolder$defaultServiceName$param_product\n$!"; - # scan all xml files to @files_found -# salmarko starts - my @files_found = grep { /^pf_|^S60_|^dfs_/i } readdir RELDIR; -# salmarko ends - close RELDIR; - - if( @files_found ) { - foreach( reverse sort ( @files_found ) ) { - # we only want to get the last dir name.. - s/.*\///i; - my $productToDl = $pathToReleaseFolder.$defaultServiceName.$param_product; - $productToDl .= FixPaths( $_ ); - print "Searching metadata.xml files from $productToDl\n" if $param_debug; - - $metaDataXml = SearchValidXml( $productToDl ) ; - if( $metaDataXml ) { - $metaDataXml = $productToDl.$metaDataXml; - printLog( "selected xml: $metaDataXml" ); - last; - } - } - } - else { - HandleError( "cannot find releases from $pathToReleaseFolder$defaultServiceName$param_product", $cannotContinue ); - } + + printLog( "selected: $wantedServer - accessing.." ); + if( opendir( GRACETEST, $wantedServer ) ) { + printLog( "connection tested OK" ); + $networkAccessVerified = 1; + $pathToReleaseFolder = $wantedServer; } else { - die "If you specify -latest parameter you have to define -product also!\n"; + print "Unable to access $wantedServer\nPlease select another network share.\n"; } + } } - - # use wizard to find out what to DL - if( ! $metaDataXml ) { - printLog( "Not enought valid inputs provided - running wizard..." ); - RunWizard( ); + + # in case we have metadata in \ and -start defined, look grace automatically + elsif( !$param_server and $param_start_directly ) { + $pathToReleaseFolder = FindGraceServer( ); } + } - # check wheter metadata and currentRelease adds up - if( -e FixPaths( getcwd )."currentRelease.xml") { - printLog( "CurrenRelease.xml exists. Checking wheter update is possible" ); - - # compare service, product and release with xml files - my $CurrentRelXmlParser = new XML::Simple( ); - my $currentReleaseData = $CurrentRelXmlParser->XMLin( FixPaths( getcwd )."currentRelease.xml" ); - - my $xmlParser = new XML::Simple( ); - my $xmlData = $xmlParser->XMLin( $metaDataXml ); + # ToDo: if there is not metadata.xml in root check if we have already env. Possibly update? + + # is 'path' parameter is used, find out (wheter there exists) valid metadata.xml + if( $param_release_path ) { + if( $param_latest or $param_product ) { + print "It doesnt make sense to use 'path' or 'latest' parameter while having metadata.xml in root!\n\n"; + print_help( ); + exit 0; + } + $metaDataXml = FixPaths( $param_release_path ); + $metaDataXml .= SearchValidXml( $metaDataXml ); + printLog( "setting metadata: $metaDataXml" ); + } + + # handle server parameter + # simply just verify accessablility and fix path + if( $param_server ) { + $pathToReleaseFolder = FixPaths( $param_server ); + opendir( OPENTEST, $pathToReleaseFolder ) or HandleError( "Unable to access given server path: $pathToReleaseFolder\n$!", $cannotContinue ); + closedir( OPENTEST ); + } + + # param_latest is used to just get latest release - requires product + if( $param_latest ) { + if( $param_product ) { + $param_product = FixPaths( $param_product ); + + # once the network share is unavailable then tries to find grace share + $pathToReleaseFolder = FindGraceServer( ); + + opendir( RELDIR, $pathToReleaseFolder.$defaultServiceName.$param_product ) or die "unable to open $pathToReleaseFolder$defaultServiceName$param_product\n$!"; + # scan all xml files to @files_found +# salmarko starts + my @files_found = grep { /^pf_|^S60_|^dfs_/i } readdir RELDIR; +# salmarko ends + close RELDIR; + + if( @files_found ) { + foreach( reverse sort ( @files_found ) ) { + # we only want to get the last dir name.. + s/.*\///i; + my $productToDl = $pathToReleaseFolder.$defaultServiceName.$param_product; + $productToDl .= FixPaths( $_ ); + print "Searching metadata.xml files from $productToDl\n" if $param_debug; + + $metaDataXml = SearchValidXml( $productToDl ) ; + if( $metaDataXml ) { + $metaDataXml = $productToDl.$metaDataXml; + printLog( "selected xml: $metaDataXml" ); + last; + } + } + } + else { + HandleError( "cannot find releases from $pathToReleaseFolder$defaultServiceName$param_product", $cannotContinue ); + } + } + else { + die "If you specify -latest parameter you have to define -product also!\n"; + } + } + + # use wizard to find out what to DL + if( ! $metaDataXml ) { + printLog( "Not enought valid inputs provided - running wizard..." ); + RunWizard( ); + } + + # check wheter metadata and currentRelease adds up + if( -e FixPaths( getcwd )."currentRelease.xml") { + printLog( "CurrenRelease.xml exists. Checking wheter update is possible" ); + + # compare service, product and release with xml files + my $CurrentRelXmlParser = new XML::Simple( ); + my $currentReleaseData = $CurrentRelXmlParser->XMLin( FixPaths( getcwd )."currentRelease.xml" ); + + my $xmlParser = new XML::Simple( ); + my $xmlData = $xmlParser->XMLin( $metaDataXml ); # salmarko starts - my $currentRelease = ''; - my $newRelease = ''; + my $currentRelease = ''; + my $newRelease = ''; - if ( !defined $xmlData->{releaseDetails}->{dependsOf}->{service}->{name} ) { # no dependencies, lets compare current to new - # compare services - if( $currentReleaseData->{releaseDetails}->{releaseID}->{service}->{name} ne - $xmlData->{releaseDetails}->{releaseID}->{service}->{name} ) { - HandleError( "Can not extract ".$xmlData->{releaseDetails}->{releaseID}->{service}->{name} . - " release on top of ".$currentReleaseData->{releaseDetails}->{releaseID}->{service}->{name}, $cannotContinue ); - } - # compare products - if( $currentReleaseData->{releaseDetails}->{releaseID}->{product}->{name} ne - $xmlData->{releaseDetails}->{releaseID}->{product}->{name} ) { - HandleError( "Can not extract ".$xmlData->{releaseDetails}->{releaseID}->{product}->{name} . - " release on top of ".$currentReleaseData->{releaseDetails}->{releaseID}->{product}->{name}, $cannotContinue ); - } - printLog( "service and product matches.. checking release" ); + if ( !defined $xmlData->{releaseDetails}->{dependsOf}->{service}->{name} ) { # no dependencies, lets compare current to new + # compare services + if( $currentReleaseData->{releaseDetails}->{releaseID}->{service}->{name} ne + $xmlData->{releaseDetails}->{releaseID}->{service}->{name} ) { + HandleError( "Can not extract ".$xmlData->{releaseDetails}->{releaseID}->{service}->{name} . + " release on top of ".$currentReleaseData->{releaseDetails}->{releaseID}->{service}->{name}, $cannotContinue ); + } + # compare products + if( $currentReleaseData->{releaseDetails}->{releaseID}->{product}->{name} ne + $xmlData->{releaseDetails}->{releaseID}->{product}->{name} ) { + HandleError( "Can not extract ".$xmlData->{releaseDetails}->{releaseID}->{product}->{name} . + " release on top of ".$currentReleaseData->{releaseDetails}->{releaseID}->{product}->{name}, $cannotContinue ); + } + printLog( "service and product matches.. checking release" ); - $currentRelease = $currentReleaseData->{releaseDetails}->{releaseID}->{release}->{name}; - $newRelease = $xmlData->{releaseDetails}->{releaseID}->{release}->{name}; - } - else{ - # compare services - if( $currentReleaseData->{releaseDetails}->{releaseID}->{service}->{name} ne - $xmlData->{releaseDetails}->{dependsOf}->{service}->{name} ) { - HandleError( "Can not extract ".$xmlData->{releaseDetails}->{dependsOf}->{service}->{name} . - " release on top of ".$currentReleaseData->{releaseDetails}->{releaseID}->{service}->{name}, $cannotContinue ); - } - # compare products - if( $currentReleaseData->{releaseDetails}->{releaseID}->{product}->{name} ne - $xmlData->{releaseDetails}->{dependsOf}->{product}->{name} ) { - HandleError( "Can not extract ".$xmlData->{releaseDetails}->{dependsOf}->{product}->{name} . - " release on top of ".$currentReleaseData->{releaseDetails}->{releaseID}->{product}->{name}, $cannotContinue ); - } - printLog( "service and product matches.. checking release" ); - - # compare releases - $currentRelease = $currentReleaseData->{releaseDetails}->{releaseID}->{release}->{name}; - $newRelease = $xmlData->{releaseDetails}->{dependsOf}->{release}->{name}; + $currentRelease = $currentReleaseData->{releaseDetails}->{releaseID}->{release}->{name}; + $newRelease = $xmlData->{releaseDetails}->{releaseID}->{release}->{name}; + } + else{ + # compare services + if( $currentReleaseData->{releaseDetails}->{releaseID}->{service}->{name} ne + $xmlData->{releaseDetails}->{dependsOf}->{service}->{name} ) { + HandleError( "Can not extract ".$xmlData->{releaseDetails}->{dependsOf}->{service}->{name} . + " release on top of ".$currentReleaseData->{releaseDetails}->{releaseID}->{service}->{name}, $cannotContinue ); + } + # compare products + if( $currentReleaseData->{releaseDetails}->{releaseID}->{product}->{name} ne + $xmlData->{releaseDetails}->{dependsOf}->{product}->{name} ) { + HandleError( "Can not extract ".$xmlData->{releaseDetails}->{dependsOf}->{product}->{name} . + " release on top of ".$currentReleaseData->{releaseDetails}->{releaseID}->{product}->{name}, $cannotContinue ); + } + printLog( "service and product matches.. checking release" ); + + # compare releases + $currentRelease = $currentReleaseData->{releaseDetails}->{releaseID}->{release}->{name}; + $newRelease = $xmlData->{releaseDetails}->{dependsOf}->{release}->{name}; + + if ( $currentRelease =~ m/^(S60_\d_\d+_\d{6})/i or $currentRelease =~ m/^(pf_\d{4}_\d{6})/ ) { + $currentRelease = $1; + } + else { + HandleError( "Current release info unknown or missing: $currentRelease", $cannotContinue ); + } - if ( $currentRelease =~ m/^(S60_\d_\d+_\d{6})/i or $currentRelease =~ m/^(pf_\d{4}_\d{6})/ ) { - $currentRelease = $1; - } - else { - HandleError( "Current release info unknown or missing: $currentRelease", $cannotContinue ); - } + if ( $newRelease =~ m/^(S60_\d_\d+_\d{6})/i or $newRelease =~ m/^(pf_\d{4}_\d{6})/ ) { + $newRelease = $1; + } + else { + HandleError( "New release info unknown or missing: $newRelease", $cannotContinue ); + } + } + + printLog( "current release: $currentRelease" ); + printLog( "release to extract: $newRelease" ); +#salmarko ends - if ( $newRelease =~ m/^(S60_\d_\d+_\d{6})/i or $newRelease =~ m/^(pf_\d{4}_\d{6})/ ) { - $newRelease = $1; - } - else { - HandleError( "New release info unknown or missing: $newRelease", $cannotContinue ); - } - } - - printLog( "current release: $currentRelease" ); - printLog( "release to extract: $newRelease" ); -# salmarko ends - - if( $currentRelease ne $newRelease ) { - HandleError( "Can not extract $newRelease release on top of $currentRelease", $cannotContinue ); - } - printLog( "release matches - update possible" ); - - $currentRelease = FixPaths( getcwd )."currentRelease.xml"; - } + if( $currentRelease ne $newRelease ) { + HandleError( "Can not extract $newRelease release on top of $currentRelease", $cannotContinue ); + } + printLog( "release matches - update possible" ); + + $currentRelease = FixPaths( getcwd )."currentRelease.xml"; + } + # check wheter we can use c-disc as temp + my $df = getFreeDisk( $ENV{'TEMP'} ); + + if( $df > 2147483648 && $df < 2147483648000 ) { + printLog( "amount of free space seems sane: $df" ); + $tmpDir = FixPaths( tempdir( CLEANUP => 0 ) ); + printLog( "setting tmpDir: $tmpDir" ); + $tmpDlDir = FixPaths( tempdir( CLEANUP => 0 ) ); + printLog( "setting tmpDlDir: $tmpDlDir" ); + } } @@ -430,10 +401,20 @@ print $trace."\n"; } + # first open/create log file + #open( LOGFILE, ">> $logFile" ) or handleError( "cant create log file: $!", $warning ); + eval { + open( LOGFILE, ">> getcwd.'/output/logs/getenv.log'" ); + }; + if ($@) #if exception + { + open( LOGFILE, ">> getcwd.'/getenv.log'" ) or handleError( "cant create log file: $!", $warning ); + } # we should print traces for log file my ($sec,$min,$hr) = localtime(); - printf LOGFILE ( "%02d:%02d:%02d: ", $hr, $min, $sec ); + printf LOGFILE ( "%02d:%02d:%02d: ", $hr, $min, $sec ); print LOGFILE $trace."\n"; + close (LOGFILE); } } @@ -502,11 +483,12 @@ getenv.pl -emu DEPRECATED - prefer filtering: get only emulator environment getenv.pl -start starts extracting without user confirmation (nice for scripts) getenv.pl -nodeps do not download dependencies for the release - getenv.pl -nosoap dont try to use SOAP connection for s60builds server getenv.pl -skipitd DEPRECATED - prefer filtering: skips useless doc, internal, tsrc zips getenv.pl -verbose print debug traces getenv.pl -Include include only some types of packages (emu, src, tsrc) getenv.pl -eXclude exclude some types of packages (emu, src, tsrc) + getenv.pl -all extract all zips + getenv.pl -Force forces to extract some filtered packages ( tsrc ) including default zips examples ======== @@ -580,10 +562,10 @@ my $wantedServer; my $networkAccessVerified = 0; while( $networkAccessVerified eq 0 ) { - $wantedServer = FixPaths( $graceList[ ReturnMenuIndex( "Please select share closest to you", @graceNameList ) ] ); + $wantedServer = FixPaths( $hydraList[ ReturnMenuIndex( "Please select share closest to you", @hydraNameList ) ] ); - if( $wantedServer eq FixPaths( $graceList[0] ) ) { - HandleError( "Please notice that access to $graceList[0] will be removed from wk50 onwards. Now would be perfect time to get yourself GRACE access.", $promptUser ); + if( $wantedServer eq FixPaths( $hydraList[0] ) ) { + HandleError( "Please notice that access to $hydraList[0] will be removed from wk50 onwards. Now would be perfect time to get yourself GRACE access.", $promptUser ); } printLog( "selected: $wantedServer - accessing.." ); @@ -593,7 +575,7 @@ $pathToReleaseFolder = $wantedServer; } else { - print "Unable to access $wantedServer\nPlease select another network share.\n"; + die "Unable to access $wantedServer\nPlease select another network share.\n"; } } my $wantedService = $serviceList[ ReturnMenuIndex( "Please select GRACE Service.", @serviceNameList)]; @@ -604,7 +586,7 @@ $defaultServiceName = $wantedService } else { - print "Unable to access $wantedServer.$wantedService\nPlease select another network share or service.\n"; + die "Unable to access $wantedServer.$wantedService\nPlease select another network share or service.\n"; } } @@ -636,11 +618,7 @@ sub FindAvailableProducts { opendir( DIR, $pathToReleaseFolder.$defaultServiceName ) or HandleError( "Can't open directory: $pathToReleaseFolder$defaultServiceName\n$!", $cannotContinue ); -#change to match only for directories -# my @productFiles = grep { /s(eries_)?60_\d_\d/i } readdir (DIR); -# salmarko starts - my @productFiles = grep /^pf_|^S60_|^DFS/i, readdir (DIR); -# salmarko ends + my @productFiles = grep /^pf_|^S60|^DFS|^50_|^pf./i, readdir (DIR); printLog( @productFiles ); closedir( DIR ); @@ -750,7 +728,10 @@ opendir( DIR, $pathToReleaseFolder.$defaultServiceName .$selectedProduct ) or die "Can't open dir: $!\n"; # my @releaseFiles = grep { /S60_\d_\d.*/ } readdir (DIR); # salmarko starts - my @releaseFiles = grep /^pf_|^S60/i, readdir (DIR); + #my @releaseFiles = grep /^pf_|^S60|^DFS|^50_|^pf./i, readdir (DIR); + # s3laine: Better way to exclude "." and ".." entries. The previous will fail + # if the release name includes dots. + my @releaseFiles = grep { $_ ne '.' and $_ ne '..' } readdir (DIR); # salmarko ends # print Dumper( @releaseFiles ); closedir (DIR); @@ -813,17 +794,6 @@ RemoveThisXmlFromFinalList( FixPaths( getcwd )."currentRelease.xml", 1 ); } if( VerifyFinalZipList( ) or $param_keepgoing ) { - # start SOAP session - if( $soapConnection ) { - my $soapSessionInfo = StartSoapSession( ); - printLog( "SOAP: note ".$soapSessionInfo->{'HelloNote'} ); - printLog( "SOAP: sessionid ".$soapSessionInfo->{'SessionID'} ); - - print "\n".$soapSessionInfo->{'HelloNote'}."\n\n" if( $soapSessionInfo->{'HelloNote'} ); - $soapSessionID = $soapSessionInfo->{'SessionID'}; - printLog( "SOAP: soapSessionID set: $soapSessionID" ); - } - # extract the environment GetEnv( ); } @@ -893,8 +863,10 @@ ${packageHash}{$key}{state} = $xmlDataHandle->{releaseFiles}->{package}->{$key}->{'state'}; ${packageHash}{$key}{extract} = $xmlDataHandle->{releaseFiles}->{package}->{$key}->{'extract'}; ${packageHash}{$key}{default} = $xmlDataHandle->{releaseFiles}->{package}->{$key}->{'default'}; - - # added 31.7.2007 : check filters -attribute + # added 5th of September 2008 by salmarko, include all zips + if ( $param_all ) { + ${packageHash}{$key}{default} = "true"; + } if ($xmlDataHandle->{releaseFiles}->{package}->{$key}->{'filters'}){ ${packageHash}{$key}{s60filter} = $xmlDataHandle->{releaseFiles}->{package}->{$key}->{'filters'}; } @@ -902,6 +874,23 @@ ${packageHash}{$key}{s60filter} = $xmlDataHandle->{releaseFiles}->{package}->{$key}->{'s60filter'}; } + # added 5th of September 2008 by salmarko, include zips marked as false if -f parameter equals + if ( ${packageHash}{$key}{default} eq "false" ) { + if ( @force_include ) { + foreach my $include( @force_include ) { + if ( FindFromList( $include,${packageHash}{$key}{s60filter} ) ) { + ${packageHash}{$key}{default} = "true"; + } + } + } + if ( @param_include ){ + foreach my $include( @param_include ) { + if ( FindFromList( $include,${packageHash}{$key}{s60filter} ) ) { + ${packageHash}{$key}{default} = "true"; + } + } + } + } # find out what is the latest state if( $finalState < $xmlDataHandle->{releaseFiles}->{package}->{$key}->{'state'} ) { $finalState = $xmlDataHandle->{releaseFiles}->{package}->{$key}->{'state'}; @@ -932,7 +921,6 @@ printLog( "read special instructions" ); } } - # this is needed due to SymSEE's obsolete xml library # in case there is > 1 SP's in one XML file else { foreach( keys(%{$xmlDataHandle->{servicePacks}->{servicePack} } ) ) { @@ -1129,7 +1117,7 @@ # if( $finalZip->{filename} eq $zips and # $finalZip->{path} eq %packageHash->{$zips}->{'path'} ) { if( $finalZip->{filename} eq $zips ) { - printLog( "removing $finalZip->{path}/$finalZip->{filename} from dl list" ); + printLog( "removing $finalZip->{path} $finalZip->{filename} from dl list" ); $finalZip->{default} = "false"; } } @@ -1167,19 +1155,23 @@ sub GetEnv { - # first thing is to copy 7zip - if( ! $param_print_only ) { - `7za --help`; - HandleError( "couldnt copy 7zip! make sure you have it in your system path!", $warning ) if ($? != 0); - mkdir $tmpDir; - mkdir $tmpDlDir; - } + my $fileCounter = 0; + # first thing is to copy 7zip + if( ! $param_print_only ) { + `7za --help`; + HandleError( "couldnt copy 7zip! make sure you have it in your system path!", $warning ) if ($? != 0); + mkdir $tmpDir; + mkdir $tmpDlDir; + } + + my $nmbrOfFiles = returnNmbrOfFiles( ); printLog( "final zip list:" ); printLog( Dumper( @finalZipList ) ); # symsee 3.3.0 contains obsolete archive::zip, so we'll have to use system calls foreach my $file( @finalZipList ) { + $fileCounter ++; $returnValue = 0; # skip not mandatory files @@ -1218,18 +1210,22 @@ # exclude files that has s60filter matching with exclude array if( @param_exclude ) { foreach my $exclude( @param_exclude ) { - if( $exclude eq $file->{s60filter} ) { - $skipByFilter = 1; - last; - } +# if( $exclude eq $file->{s60filter} ) { + if( FindFromList( $exclude, $file->{s60filter} ) ) { + printLog( "excluding $file->{filename} because $exclude matches $file->{s60filter}" ); + $skipByFilter = 1; + last; + } } } # include only files that has s60filter matching with include array elsif( @param_include ) { $skipByFilter = 1; foreach my $include( @param_include ) { - if( $include eq $file->{s60filter} ) { - $skipByFilter = 0; +# if( $include eq $file->{s60filter} ) { + if( FindFromList( $include, $file->{s60filter} ) ) { + printLog( "including $file->{filename} because $include matches $file->{s60filter}" ); + $skipByFilter = 0; last; } } @@ -1245,15 +1241,22 @@ # parent process copies/unzips packages to tmpDlDir printLog( "parent: extract packages to $tmpDlDir" ); printLog( "parent: Processing: $file->{filename}... " ); - print "Processing: $file->{filename}... "; + print "Downloading[$fileCounter\/$nmbrOfFiles] $file->{filename}... "; if( $file->{extract} eq 'single' ) { # copy single zipped packages to $tmpDlDir printLog( "parent: single zipped - copy to $tmpDlDir" ); - if( ! $param_print_only ) { - copy( $file->{path} . $file->{filename}, $tmpDlDir ) or - HandleError( "cant copy file $file->{path}$file->{filename} to $tmpDlDir", $cannotContinue); - } + if( ! $param_print_only ) { + # Let's try 3 times to copy the file in case the server is busy, note this is a hack, + # the correct way would be either to remove the file from release list so that the next run would get the file + # or to check the for the error value before trying again. Although the error code seems to be '2' ie. + # 'File not found' so it is a little bit hard to distinguish between removed file and the server being busy. + # With more testing it some times returns also error code '9' ie. 'Bad file descriptor'. + copy( $file->{path} . $file->{filename}, $tmpDlDir ) or + copy( $file->{path} . $file->{filename}, $tmpDlDir ) or + copy( $file->{path} . $file->{filename}, $tmpDlDir ) or + HandleError( "cant copy file $file->{path}$file->{filename} to $tmpDlDir", $warning ); + } } elsif( $file->{extract} eq 'double' ) { # unzip double zipped zips to $tmpDlDir @@ -1307,12 +1310,14 @@ # this is after forking # move files from tmpDlDir => tmpDir + printLog( "check is there file to move in tmpdldir" ); my $somethingToCopy = 0; opendir( DLTEMP, $tmpDlDir ) or HandleError( "cant read $tmpDlDir dir: $!", $warning ); my @filesFound = readdir( DLTEMP ); closedir( DLTEMP ); foreach my $file( @filesFound ) { next if $file =~ /^\.[\.]?$/; + printLog( "in tmpdldir: $file" ); $somethingToCopy = 1; } @@ -1436,15 +1441,12 @@ # return path to accessible GRACE samba share sub FindGraceServer { -# added 27.2.2007 : skip seeking if server has given from commandline -# salmarko starts if (defined $param_server) {return FixPaths( $param_server );} -# salmarko ends - print "\nseeking possible grace accesses. This might take a while.. "; + print "\nseeking possible hydra accesses. This might take a while.. "; my @graceAccessArray; - foreach my $address( @graceList ) { + foreach my $address( @hydraList ) { printLog( "accessing $address..." ); if( opendir( GRACETEST, $address ) ) { push @graceAccessArray, $address; @@ -1457,23 +1459,23 @@ } if( @graceAccessArray ) { - print "done\nSelected GRACE server: ", $graceAccessArray[0]; + print "done\nSelected HYDRA server: ", $graceAccessArray[0]; if( scalar( @graceAccessArray ) > 1 ) { # if start is defined && >1 grace shares available, we'll have to just guess correct share if( $param_start_directly ) { - print( "More than one grace shares accessible\n" ); + print( "More than one HYDRA shares accessible\n" ); print Dumper( @graceAccessArray ); print "\nBecause -start parameter is provided we cant prompt user to select correct, lets pick first one from the list\n"; print "You should use -server parameter to define the server\n"; - printLog( "-start defined and >1 grace shares accessible" ); + printLog( "-start defined and >1 hydra shares accessible" ); printLog( @graceAccessArray ); printLog( "selecting first one: $graceAccessArray[0]" ); return FixPaths( $graceAccessArray[0] ); } else { # salmarko starts - return FixPaths( PrintSelectMenu( "Select reasonable GRACE share", @graceAccessArray ) ); + return FixPaths( PrintSelectMenu( "Select reasonable HYDRA share", @graceAccessArray ) ); # salmarko ends } } @@ -1509,65 +1511,6 @@ return $tempXmlHandle->{releaseDetails}->{releaseID}->{product}->{name}; } -sub GetSoapVersion { - printLog( "Trying to access SOAP server" ); - - my $soapVersion = eval { SOAP::Lite - ->uri('GetEnv') - ->on_action(sub{ sprintf('%s/%s', @_ )}) - ->proxy($soapServiceURL) - ->GetVersionInfo( ) - ->result } ; - - print Dumper( $soapVersion ) if( $param_debug ); - - return $soapVersion; -} - -sub StartSoapSession { - printLog( "fetching session start info from SOAP" ); - my $netPath = FixPaths( $pathToReleaseFolder ); - $netPath .= FixPaths( $defaultServiceName ); - $netPath .= FixPaths( ReturnProductName( $metaDataXml ) ); - $netPath .= FixPaths( ReturnReleaseName( $metaDataXml ) ); -# $netPath .= $metaDataXml; - printLog( "about to fetch: $netPath" ); - - return SOAP::Lite - ->uri('GetEnv') - ->on_action(sub{ sprintf('%s/%s', @_ )}) - ->proxy($soapServiceURL) - ->StartGetEnv( SOAP::Data->name( BuildName=> ReturnReleaseName( $metaDataXml ) ) - ->type('string') - ->uri('GetEnv'), - SOAP::Data->name( NetworkPath=> $netPath ) - ->type('string') - ->uri('GetEnv'), - SOAP::Data->name( UserName=> $ENV{'USERNAME'} ) - ->type('string') - ->uri('GetEnv'), - SOAP::Data->name( MachineName=> $ENV{'COMPUTERNAME'} ) - ->type('string') - ->uri('GetEnv') ) - ->result; -} - -sub EndSoapConnection { - printLog( "SOAP: Finishing SOAP session: $soapSessionID" ); - printLog( "SOAP: release downloaded: $metaDataXml" ); - - return SOAP::Lite - ->uri('GetEnv') - ->on_action(sub{ sprintf('%s/%s', @_ )}) - ->proxy($soapServiceURL) - ->DoneGetEnv( SOAP::Data->name( ID=> $soapSessionID ) - ->type('string') - ->uri('GetEnv')) - ->result; - -} - - sub FindTempDir { # it'll speed up extraction if we put temp dir to separate disk @@ -1594,4 +1537,48 @@ } return $pid; } +# try to grep amount of free disk space +sub getFreeDisk { + printLog( "getFreeDisk: $_[0]" ); + my $bytesfree; + my $d = $_[0]; + chomp($d); + my $cmd = "call dir $d"; + my @dir = `$cmd 2>&1`; + return -1 if ($? != 0); + my $dir = $dir[scalar(@dir) - 1]; # the last line + chop($dir); + + printLog( "dir: $dir" ); + + # clean up whitespaces + $dir =~ s/^\s+//g; + $dir =~ s/\s+$//g; + $dir =~ s/\s{1,}/ /g; + + # get rid of `X Dir(s)' + @dir = split(/\s/, $dir); + $dir = join("", @dir[2 .. scalar(@dir)]); + # get digits only + $dir =~ s/[^0-9]//g; + + # free space in gigabytes +# $bytesfree = $dir/1073741824; + $bytesfree = $dir; + + printLog( "returning: $bytesfree" ); + return $bytesfree; +} + +# returns amount of files set for extract from finalZipList +sub returnNmbrOfFiles { + my $count = 0; + + foreach( @finalZipList ) { + $count++ if $_->{default}; + } + + return $count; +} +