2016-07-29 09:58:23 +02:00
|
|
|
# # @file
|
|
|
|
# Test Install distribution package
|
|
|
|
#
|
2017-08-10 10:36:47 +02:00
|
|
|
# Copyright (c) 2016 - 2017, Intel Corporation. All rights reserved.<BR>
|
2016-07-29 09:58:23 +02:00
|
|
|
#
|
2019-04-04 01:03:11 +02:00
|
|
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
2016-07-29 09:58:23 +02:00
|
|
|
#
|
|
|
|
"""
|
|
|
|
Test Install multiple distribution package
|
|
|
|
"""
|
|
|
|
# #
|
|
|
|
# Import Modules
|
|
|
|
#
|
|
|
|
from Library import GlobalData
|
|
|
|
import Logger.Log as Logger
|
|
|
|
from Logger import StringTable as ST
|
|
|
|
import Logger.ToolError as TE
|
|
|
|
from Core.DependencyRules import DependencyRules
|
|
|
|
from InstallPkg import UnZipDp
|
|
|
|
|
|
|
|
import shutil
|
|
|
|
from traceback import format_exc
|
|
|
|
from platform import python_version
|
|
|
|
from sys import platform
|
|
|
|
|
|
|
|
# # Tool entrance method
|
|
|
|
#
|
|
|
|
# This method mainly dispatch specific methods per the command line options.
|
|
|
|
# If no error found, return zero value so the caller of this tool can know
|
|
|
|
# if it's executed successfully or not.
|
|
|
|
#
|
|
|
|
# @param Options: command Options
|
|
|
|
#
|
|
|
|
def Main(Options=None):
|
|
|
|
ContentZipFile, DistFile = None, None
|
|
|
|
ReturnCode = 0
|
|
|
|
|
|
|
|
try:
|
|
|
|
DataBase = GlobalData.gDB
|
|
|
|
WorkspaceDir = GlobalData.gWORKSPACE
|
|
|
|
if not Options.DistFiles:
|
|
|
|
Logger.Error("TestInstallPkg", TE.OPTION_MISSING, ExtraData=ST.ERR_SPECIFY_PACKAGE)
|
|
|
|
|
|
|
|
DistPkgList = []
|
|
|
|
for DistFile in Options.DistFiles:
|
|
|
|
DistPkg, ContentZipFile, __, DistFile = UnZipDp(WorkspaceDir, DistFile)
|
|
|
|
DistPkgList.append(DistPkg)
|
|
|
|
|
|
|
|
#
|
|
|
|
# check dependency
|
|
|
|
#
|
|
|
|
Dep = DependencyRules(DataBase)
|
|
|
|
Result = True
|
|
|
|
DpObj = None
|
|
|
|
try:
|
|
|
|
Result, DpObj = Dep.CheckTestInstallPdDepexSatisfied(DistPkgList)
|
|
|
|
except:
|
|
|
|
Result = False
|
|
|
|
|
|
|
|
if Result:
|
|
|
|
Logger.Quiet(ST.MSG_TEST_INSTALL_PASS)
|
|
|
|
else:
|
|
|
|
Logger.Quiet(ST.MSG_TEST_INSTALL_FAIL)
|
|
|
|
|
2018-06-25 12:31:25 +02:00
|
|
|
except TE.FatalError as XExcept:
|
2016-07-29 09:58:23 +02:00
|
|
|
ReturnCode = XExcept.args[0]
|
|
|
|
if Logger.GetLevel() <= Logger.DEBUG_9:
|
|
|
|
Logger.Quiet(ST.MSG_PYTHON_ON % (python_version(), platform) + format_exc())
|
|
|
|
|
2018-06-25 12:31:25 +02:00
|
|
|
except Exception as x:
|
2016-07-29 09:58:23 +02:00
|
|
|
ReturnCode = TE.CODE_ERROR
|
|
|
|
Logger.Error(
|
|
|
|
"\nTestInstallPkg",
|
|
|
|
TE.CODE_ERROR,
|
|
|
|
ST.ERR_UNKNOWN_FATAL_INSTALL_ERR % Options.DistFiles,
|
2019-05-21 04:06:52 +02:00
|
|
|
ExtraData=ST.MSG_SEARCH_FOR_HELP % ST.MSG_EDKII_MAIL_ADDR,
|
2016-07-29 09:58:23 +02:00
|
|
|
RaiseError=False
|
|
|
|
)
|
|
|
|
Logger.Quiet(ST.MSG_PYTHON_ON % (python_version(), platform) + format_exc())
|
|
|
|
|
|
|
|
finally:
|
|
|
|
Logger.Quiet(ST.MSG_REMOVE_TEMP_FILE_STARTED)
|
|
|
|
if DistFile:
|
|
|
|
DistFile.Close()
|
|
|
|
if ContentZipFile:
|
|
|
|
ContentZipFile.Close()
|
2017-08-10 10:36:47 +02:00
|
|
|
for TempDir in GlobalData.gUNPACK_DIR:
|
|
|
|
shutil.rmtree(TempDir)
|
|
|
|
GlobalData.gUNPACK_DIR = []
|
2016-07-29 09:58:23 +02:00
|
|
|
Logger.Quiet(ST.MSG_REMOVE_TEMP_FILE_DONE)
|
|
|
|
if ReturnCode == 0:
|
|
|
|
Logger.Quiet(ST.MSG_FINISH)
|
|
|
|
return ReturnCode
|
|
|
|
|