diff options
author | Rüdiger Timm <rt@openoffice.org> | 2008-06-13 11:47:43 +0000 |
---|---|---|
committer | Rüdiger Timm <rt@openoffice.org> | 2008-06-13 11:47:43 +0000 |
commit | b14f35b46a531b8c9152415f10ae0b43760bf805 (patch) | |
tree | 8e0d122f9830b0ebe1dbdf3836f13f398bada58d | |
parent | dbdd5b2a28e0eb09a34d1dcf9b80ac3bfb6256e5 (diff) |
INTEGRATION: CWS qadev32 (1.2.2); FILE MERGED
2008/06/11 12:31:01 cn 1.2.2.10: #i87389# if a non added module should be tested (-m $moldue) the test does not find the qa/unoapi folder because of not consider .lnk -> fixed
2008/05/28 12:54:05 cn 1.2.2.9: #i87389# enhance logging
2008/05/13 19:09:11 cn 1.2.2.8: #i87389# update logging, ehnance javadoc
2008/05/05 10:05:33 cn 1.2.2.7: #i85370# change header, change parameter String[] to ArrayList, PASSED.OK if no module with qa/unoapi is found
2008/04/17 10:51:21 cn 1.2.2.6: #i85370# header changed
2008/04/03 07:55:04 cn 1.2.2.5: #i87389# new method getTranslatedNames
2008/03/12 10:42:02 cn 1.2.2.4: #i85370# implement setUnoAoiCwsStatus()
2008/03/05 10:46:10 cn 1.2.2.3: #i85370# give the office some more time at its fist start
2008/01/22 11:47:19 cn 1.2.2.2: #i85370#: crestructuring the before method
2008/01/18 15:26:04 cn 1.2.2.1: #i85370#: reorg of test case: some functinalilty has moved to external classes
-rw-r--r-- | qadevOOo/tests/java/complex/unoapi/CheckModuleAPI.java | 517 |
1 files changed, 309 insertions, 208 deletions
diff --git a/qadevOOo/tests/java/complex/unoapi/CheckModuleAPI.java b/qadevOOo/tests/java/complex/unoapi/CheckModuleAPI.java index c3194a949534..734c15c2d92b 100644 --- a/qadevOOo/tests/java/complex/unoapi/CheckModuleAPI.java +++ b/qadevOOo/tests/java/complex/unoapi/CheckModuleAPI.java @@ -1,4 +1,5 @@ -/************************************************************************* +/* + * ************************************************************************ * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * @@ -7,7 +8,7 @@ * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: CheckModuleAPI.java,v $ - * $Revision: 1.4 $ + * $Revision: 1.5 $ * * This file is part of OpenOffice.org. * @@ -26,8 +27,8 @@ * <http://www.openoffice.org/license.html> * for a copy of the LGPLv3 License. * - ************************************************************************/ - + * ********************************************************************** + */ /** complex tests to check the UNO-API **/ package complex.unoapi; @@ -36,15 +37,18 @@ package complex.unoapi; import base.java_complex; import complexlib.ComplexTestCase; import helper.OfficeProvider; +import helper.ParameterNotFoundException; import helper.ProcessHandler; import com.sun.star.lang.XMultiServiceFactory; +import helper.BuildEnvTools; import helper.ComplexDescGetter; -import helper.OfficeWatcher; -import helper.ProcessHandler; +import helper.CwsDataExchangeImpl; import java.io.File; import java.io.FileFilter; -import java.io.PrintWriter; -import java.util.Vector; +import java.util.ArrayList; +import java.util.HashMap; +import java.util.Iterator; +import java.util.Set; import share.DescEntry; import util.PropertyName; import util.utils; @@ -76,35 +80,62 @@ import util.utils; */ public class CheckModuleAPI extends ComplexTestCase { - String mSRC_ROOT = null; - String mCompiler = null; - boolean mIsInitialized = false; - boolean mContinue = false; - boolean mDebug = false; + private String mSRC_ROOT = null; + private boolean mIsInitialized = false; + private final static boolean mContinue = true; + private boolean mDebug = false; + private BuildEnvTools bet = null; + /** + * Initialize the test environment. + * This method checks for all neccesarry parameter and exit if not all parameter are set. + * + * Further this method starts an office instance and gets the office some more time to start. This is because + * some freshly installed offices don not have such a user tree. The office will create it on its first start, + * but this will take some time. + * Note: This funktionality is only reasonable with parameter <CODE>-noOffice true</CODE> + */ public void before() { if (!mIsInitialized) { mIsInitialized = true; - boolean error = false; - String msg = "\nERROR: the following parameter must be set before executing the test:\n"; - String envSet = (String) param.get(PropertyName.OOO_ENVSET); - if (envSet == null) { - msg += PropertyName.OOO_ENVSET + "\n\tThis parameter must ponit to the script to create a build " + "environment like '$SRC_ROOT/SolarisX86Env.Set.sh' or '%SRC_ROOT\\winenv.set.sh'\n" + "In case you are able to use \'setsolar\' or \'setcws\' just type \'setsolar\' value.\n "; - error = true; - } - String shell = (String) param.get(PropertyName.SHELL); - if (shell == null) { - msg += PropertyName.SHELL + "\n\tFill this parameter with a shell which can start 'OOO_ENVSET'" + "\n\t/bin/tcsh c:\\myShell\\myShell.exe\n"; - error = true; - } - makeEnvironment(); - if (mSRC_ROOT == null) { - msg += PropertyName.SRC_ROOT + "\n\tTry to fill this parameter with content of '$SRC_ROOT' like:\n\t" + PropertyName.SRC_ROOT + "=`$SRC_ROOT`\n"; - error = true; + + try { + + bet = new BuildEnvTools(param, log); + + } catch (ParameterNotFoundException ex) { + this.failed(ex.toString(), false); } + + mSRC_ROOT = bet.getSrcRoot(); + mDebug = param.getBool(PropertyName.DEBUG_IS_ACTIVE); - assure(msg, !error, false); + + // this test is desingt to run against a freshly installed office. Maybe this office has currently no + // no user installation. The first start of an office creates this installation and this takes some + // more time to connect to the office. + // Note: This is only usefull with parameter -NoOffice true + try { + final OfficeProvider officeProvider = new OfficeProvider(); + log.println("Receiving the ServiceManager of the Office to create User installation..."); + + final int timeOut = param.getInt(PropertyName.TIME_OUT); + param.put(PropertyName.TIME_OUT, new Integer(4 * timeOut)); + + final XMultiServiceFactory msf = (XMultiServiceFactory) officeProvider.getManager(param); + + officeProvider.backupUserLayer(param, msf); + + param.put(PropertyName.TIME_OUT, new Integer(timeOut)); + + if (msf == null) { + failed("Could not connect the office"); + } + } catch (Throwable t) { + failed("Could not start office " + t.toString()); + } + } } @@ -115,33 +146,36 @@ public class CheckModuleAPI extends ComplexTestCase { public void checkModule(String module) { log.println(utils.getDateTime() + ": start testing module '" + module + "'"); - log.println("start new Office instance..."); - OfficeProvider officeProvider = new OfficeProvider(); - log.println("Receiving the ServiceManager of the Office "); - XMultiServiceFactory msf = (XMultiServiceFactory) officeProvider.getManager(param); + log.println(utils.getDateTime() + "start new Office instance..."); + final OfficeProvider officeProvider = new OfficeProvider(); + log.println(utils.getDateTime() + "Receiving the ServiceManager of the Office "); + final XMultiServiceFactory msf = (XMultiServiceFactory) officeProvider.getManager(param); assure("couldnot get ServiceFarcotry", msf != null, mContinue); param.put("ServiceFactory", msf); - String sep = System.getProperty("file.separator"); - String sUnoapi = getModulePath(module); - File fUnoapi = new File(sUnoapi); - String sMakeFile = sUnoapi + sep + "makefile.mk"; - File fMakeFile = new File(sMakeFile); + final String sep = System.getProperty("file.separator"); + final String sUnoapi = getModulePath(module); + final File fUnoapi = new File(sUnoapi); + final String sMakeFile = sUnoapi + sep + "makefile.mk"; + final File fMakeFile = new File(sMakeFile); assure("ERROR: could not find makefile: '" + sMakeFile + "'", fMakeFile.exists(), mContinue); - String[] cmdLines = getCmdLines(sUnoapi); - ProcessHandler procHdl = runShellCommand(cmdLines, fUnoapi, false); - if (mDebug) { - log.println("---> Output of dmake:"); - log.println(procHdl.getOutputText()); - log.println("<--- Output of dmake file:"); - log.println("---> Error output of dmake file"); - log.println(procHdl.getErrorText()); - log.println("<--- Error output of dmake file"); - } - assure("module failed", verifyOutput(procHdl.getOutputText()), mContinue); - - log.println("kill existing office..."); + final String[] commands = getCommands(sUnoapi); + + final ProcessHandler procHdl = bet.runCommandsInEnvironmentShell(commands, fUnoapi, false); + log.println("exit code of dmake: " + procHdl.getExitCode()); + String test = procHdl.getOutputText(); + test = procHdl.getErrorText(); +// if (mDebug) { +// log.println("---> Output of dmake:"); +// log.println(procHdl.getOutputText()); +// log.println("<--- Output of dmake:"); +// log.println("---> Error output of dmake:"); +// log.println(procHdl.getErrorText()); +// log.println("<--- Error output of dmake:"); +// } + assure("module '" + module + "' failed", verifyOutput(procHdl.getOutputText()), mContinue); + log.println(utils.getDateTime() + " module '" + module + "': kill existing office..."); try { officeProvider.closeExistingOffice(param, true); } catch (java.lang.UnsatisfiedLinkError exception) { @@ -150,161 +184,209 @@ public class CheckModuleAPI extends ComplexTestCase { } - private String[] getCmdLines(String sUnoapi) { + private void addIfQaUnoApiFolderExist(File srcRoot, ArrayList moduleNames) { - String shell = (String) param.get(PropertyName.SHELL); - String envcmd = getEnvCmd(); - String[] cmdLines = null; - String platform = (String) param.get(PropertyName.OPERATING_SYSTEM); - log.println("prepare command for platform " + platform); - if (platform.equals(PropertyName.WNTMSCI)) { - cmdLines = new String[]{shell, "/C ", envcmd + " ^ cdd " + sUnoapi + "^ dmake"}; - } else { - cmdLines = new String[]{shell, "-c ", envcmd + " ; cd " + sUnoapi + "; dmake"}; + if (doesQaUnoApiFolderExist(srcRoot)) { + moduleNames.add(srcRoot.getName()); } - return cmdLines; - } - - private String getEnvValue(String line) { - String[] split = line.split("="); - return split[1]; } - private String getModulePath(String module) { - - String sUnoapi = null; - String sep = System.getProperty("file.separator"); - File srcRoot = new File(mSRC_ROOT); - - FolderFilter qaFilter = new FolderFilter(module); - File[] moduleTree = srcRoot.listFiles(qaFilter); - if (mDebug) { - log.println("moduleTree: " + moduleTree[0].getAbsolutePath()); - } - if (moduleTree != null) { - sUnoapi = moduleTree[0].getAbsolutePath() + sep + "qa" + sep + "unoapi"; + private boolean doesQaUnoApiFolderExist(File srcRoot) { + final FolderFilter qaFilter = new FolderFilter("qa"); + final File[] qaTree = srcRoot.listFiles(qaFilter); + if (qaTree != null) { + for (int j = 0; j < qaTree.length; j++) { + final File qaFolder = qaTree[j]; + final FolderFilter apiFilter = new FolderFilter("unoapi"); + final File[] apiTree = qaFolder.listFiles(apiFilter); + if (apiTree != null && apiTree.length > 0) { + return true; + } + } } - return sUnoapi; + return false; } - private String getSetSolarCmd() { - String cmd = null; - - String version = (String) param.get(PropertyName.VERSION); + private String[] getAllModuleCommand() { + String[] checkModules; - if (version.startsWith("cws_")) { - cmd = "setcws " + version.substring(4, version.length()); - } else { - mCompiler = (String) param.get(PropertyName.COMP_ENV); - assure("If you use 'setsolar' you need to fill parameter 'COMP_ENV' with accordant " + - "value like 'unxsols4' or wntmsci10", mCompiler != null); + final String[] names = getModulesFromSourceRoot(); + checkModules = getCheckModuleCommand(names); - String[] versions = version.split("_"); - - cmd = "setsolar -" + versions[0] + " -ver " + versions[1] + " -jdk14 -pro " + mCompiler; - } - return cmd; + return checkModules; } - private String getEnvCmd() { - String envSet = (String) param.get(PropertyName.OOO_ENVSET); - String cmd = null; - String platform = (String) param.get(PropertyName.OPERATING_SYSTEM); - log.println("prepare command for platform " + platform); + private String[] getCheckModuleCommand(String[] names) { + String[] checkModules; + checkModules = new String[names.length]; - if (envSet.equals("setsolar")) { - cmd = getSetSolarCmd(); - if (platform.equals(PropertyName.WNTMSCI)) { - cmd = "call " + cmd; + for (int i = 0; i < names.length; i++) { + // if a module is not added to a cws it contains a dot in its name (forms.lnk) + if (names[i].indexOf(".") != -1) { + checkModules[i] = "checkModule(" + names[i].substring(0, names[i].indexOf(".")) + ")"; + } else { + checkModules[i] = "checkModule(" + names[i] + ")"; } - } else { - cmd = "source " + envSet; } - return cmd; + return checkModules; } - private void makeEnvironment() { + private String[] getCommands(String sUnoapi) { - String cmd = getEnvCmd(); - - String shell = (String) param.get(PropertyName.SHELL); - String platform = (String) param.get(PropertyName.OPERATING_SYSTEM); String[] cmdLines = null; - + final String platform = (String) param.get(PropertyName.OPERATING_SYSTEM); + log.println("prepare command for platform " + platform); if (platform.equals(PropertyName.WNTMSCI)) { - cmdLines = new String[]{shell, "/C ", cmd + " ^ echo SRC_ROOT=%SRC_ROOT"}; + cmdLines = new String[]{"cdd " + sUnoapi, "dmake"}; +// cmdLines = new String[]{shell, "/C ", "\"echo Test ^ " + envcmd + " ^ cdd " + sUnoapi + "^ pwd ^ dmake\""}; } else { - cmdLines = new String[]{shell, "-c ", cmd + " ; echo \"SRC_ROOT=$SRC_ROOT\""}; + cmdLines = new String[]{"cd " + sUnoapi, "dmake"}; } + return cmdLines; + } - ProcessHandler procHdl = runShellCommand(cmdLines, null, true); - if (mDebug) { - log.println("---> Output of command:"); - log.println(procHdl.getOutputText()); - log.println("<--- Output of command:"); - log.println("---> Error output of command"); - log.println(procHdl.getErrorText()); - log.println("<--- Error output of command"); - } - String output = procHdl.getOutputText(); - String[] outs = output.split("\n"); + private String[] getCwsModuleCommand() { + String[] checkModules; + final String version = (String) param.get(PropertyName.VERSION); + String[] names = null; + if (version.startsWith("cws_")) { + try { + // cws version: all added modules must be tested + final String cws = version.substring(4, version.length()); + final CwsDataExchangeImpl cde = new CwsDataExchangeImpl(cws, param, log); + final ArrayList addedModules = cde.getModules(); + + final ArrayList moduleNames = new ArrayList(); + Iterator iterator = addedModules.iterator(); + while (iterator.hasNext()) { + final File sourceRoot = new File(mSRC_ROOT + File.separator + (String) iterator.next()); + addIfQaUnoApiFolderExist(sourceRoot, moduleNames); - for (int i = 0; i < outs.length; i++) { - String line = outs[i]; - if (line.startsWith("SRC_ROOT")) { - mSRC_ROOT = getEnvValue(line); + } + names = (String[]) moduleNames.toArray(new String[0]); + } catch (ParameterNotFoundException ex) { + this.failed(ex.toString(), false); } + + + } else { + // major version: all modules must be tested + names = getModulesFromSourceRoot(); } + checkModules = getCheckModuleCommand(names); + + return checkModules; } - private ProcessHandler runShellCommand(String[] cmdLines, File workDir, boolean shortWait) { + private String[] getDefinedModuleCommand(String module) { + String[] checkModules = null; + // list of modules to test: (sw,sc,sd) + if (module.indexOf(",") != -1) { + final String[] names = module.split(","); + checkModules = new String[names.length]; + for (int i = 0; i < names.length; i++) { + final String moduleName = names[i].trim(); - boolean changedText = true; - int count = 0; - String memText = ""; - ProcessHandler procHdl = new ProcessHandler(cmdLines, (PrintWriter) log, workDir); - procHdl.executeAsynchronously(); - int timeOut = 0; + File sourceRoot = new File(mSRC_ROOT + File.separator + moduleName); + if (!sourceRoot.exists()) { + sourceRoot = new File(mSRC_ROOT + File.separator + moduleName + ".lnk"); + } - if (shortWait) { - timeOut = 3000; + if (doesQaUnoApiFolderExist(sourceRoot)) { + checkModules[i] = "checkModule(" + moduleName + ")"; + } + } } else { - timeOut = param.getInt(PropertyName.TIME_OUT) / 2; + File sourceRoot = new File(mSRC_ROOT + File.separator + module); + if (!sourceRoot.exists()) { + sourceRoot = new File(mSRC_ROOT + File.separator + module + ".lnk"); + } + if (doesQaUnoApiFolderExist(sourceRoot)) { + checkModules = new String[]{"checkModule(" + module + ")"}; + } } + return checkModules; + } - OfficeWatcher ow = (OfficeWatcher) param.get(PropertyName.OFFICE_WATCHER); + private String getModulePath(String module) { - while (changedText && !procHdl.isFinished()) { - count++; - if (ow != null) { - ow.ping(); - } - log.println("CheckModuleAPI: waiting... " + count); - utils.shortWait(timeOut); - if (ow != null) { - ow.ping(); + String sUnoapi = null; + final String sep = System.getProperty("file.separator"); + final File srcRoot = new File(mSRC_ROOT); + + final FolderFilter qaFilter = new FolderFilter(module); + final File[] moduleTree = srcRoot.listFiles(qaFilter); + if (moduleTree != null) { + if (mDebug) { + log.println("moduleTree length:" + moduleTree.length); + log.println("moduleTree: " + moduleTree[0].getAbsolutePath()); } - // check for changes in the output stream. If there are no changes, the process maybe hangs - if (procHdl.getOutputText().equals(memText)) { - changedText = false; + if (moduleTree != null) { + sUnoapi = moduleTree[0].getAbsolutePath() + sep + "qa" + sep + "unoapi"; } - memText = procHdl.getOutputText(); } + return sUnoapi; + } + + /** + Some modules contains more the one project. This methods translates given project paramater to the + * correspind module name. + * + * fwk -> framework + * fwl -> framework + * sch -> chart2 + * sysmgr1 -> configmgr + * cfgmgr2 -> configmgr + * lnn -> lingu + * lng -> linguistic + * sfx -> sfx2 + * sm -> starmath + */ + private String getTranslatedNames(String module) { + + final HashMap modulez = new HashMap(); + + modulez.put("fwk", "framework"); + modulez.put("fwl", "framework"); + modulez.put("sch", "chart2"); + modulez.put("sysmgr1", "configmgr"); + modulez.put("cfgmag2", "configmgr"); + modulez.put("lnn", "lingu"); + modulez.put("lng", "linguistic"); + modulez.put("sfx", "sfx2"); + modulez.put("sm", "starmath"); + + // it could the that the parameter looks like "fwk,fwl". This results in double "famework,framework". + // The following loop correct this to only one "framework" - if (!procHdl.isFinished()) { - log.println("Process ist not finished but there are no changes in output stream."); + final Set keys = modulez.keySet(); + final Iterator iterator = keys.iterator(); + while (iterator.hasNext()) { + + final String key = (String) iterator.next(); + final String value = (String) modulez.get(key); + + module = module.replaceAll(key, value); + + final int count = module.split(value).length; + if (count > 2) { + for (int i = 2; i < count; i++) { + module.replaceFirst("," + value, ""); + } + + } } - return procHdl; + return module; } private boolean verifyOutput(String output) { log.println("verify output..."); boolean ok = false; - String[] outs = output.split("\n"); + final String[] outs = output.split("\n"); for (int i = 0; i < outs.length; i++) { - String line = outs[i]; + final String line = outs[i]; if (line.matches("[0-9]+? of [0-9]+? tests failed")) { log.println("mached line: " + line); if (line.matches("0 of [0-9]+? tests failed")) { @@ -315,6 +397,11 @@ public class CheckModuleAPI extends ComplexTestCase { } } } + + if (!ok) { + log.println("ERROR: could not find '0 of [0-9]+? tests failed' in output"); + } + return ok; } @@ -324,77 +411,91 @@ public class CheckModuleAPI extends ComplexTestCase { log.println("search for qa/unoapi foldres in all modules based in "); log.println("'" + mSRC_ROOT + "'"); - Vector moduleNames = new Vector(); - File sourceRoot = new File(mSRC_ROOT); - File[] sourceTree = sourceRoot.listFiles(); + final ArrayList moduleNames = new ArrayList(); + final File sourceRoot = new File(mSRC_ROOT); + final File[] sourceTree = sourceRoot.listFiles(); assure("Could not find any files in SOURCE_ROOT=" + mSRC_ROOT, sourceTree != null, false); for (int i = 0; i < sourceTree.length; i++) { - File moduleName = sourceTree[i]; - FolderFilter qaFilter = new FolderFilter("qa"); - File[] qaTree = moduleName.listFiles(qaFilter); - if (qaTree != null) { - for (int j = 0; j < qaTree.length; j++) { - File qaFolder = qaTree[j]; - FolderFilter apiFilter = new FolderFilter("unoapi"); - File[] apiTree = qaFolder.listFiles(apiFilter); - if (apiTree != null && apiTree.length > 0) { - moduleNames.add(moduleName.getName()); - } - } - } + final File moduleName = sourceTree[i]; + addIfQaUnoApiFolderExist(moduleName, moduleNames); } - String[] names = (String[]) moduleNames.toArray( new String[0] ); + final String[] names = (String[]) moduleNames.toArray(new String[0]); return names; } + /** + * This function generates a list of modules to test and call <CODE>checkModule</CODE> for every module. + * <p> + * + * @param module names to test. This could be + * <ul> + * <li>a comma separated list of modules like 'sw,sc,sd'</li> + * <li>'all' to test all modules </li> + * <li>'auto' to check only modules which are added to the ChildWorkSpace</li> + * </ul> + */ public void module(String module) { - String[] checkModules = null; - ComplexDescGetter desc = new ComplexDescGetter(); + String[] checkModules; + final ComplexDescGetter desc = new ComplexDescGetter(); DescEntry entry = null; module = module.trim(); - /* all: check all modules which contains a qa/unoapi folder + /* + all: check all modules which contains a qa/unoapi folder auto: check all modules which contains a qa/unoapi folder except the module is not added */ if (module.equals("all")) { + checkModules = getAllModuleCommand(); + } else if (module.equals("auto")) { + checkModules = getCwsModuleCommand(); + } else { + module = getTranslatedNames(module); + checkModules = getDefinedModuleCommand(module); + } - String[] names = getModulesFromSourceRoot(); - checkModules = new String[names.length]; + if (checkModules != null && checkModules.length > 0) { + + entry = desc.createTestDesc("complex.unoapi.CheckModuleAPI", "complex.unoapi.CheckModuleAPI", checkModules, + log); + + final java_complex complex = new java_complex(); + + log.println("********** start test *************"); + final boolean result = complex.executeTest(param, new DescEntry[]{entry}); + log.println("********** end test *************"); + + assure("CheckModuleAPI.module(" + module + ") PASSED.FAILED", result); - for (int i = 0; i < names.length; i++) { - // if a module is not added to a cws it contains a dot in its name (forms.lnk) - if (names[i].indexOf(".") != -1) { - checkModules[i] = "checkModule(" + names[i].substring(0, names[i].indexOf(".")) + ")"; - } else { - checkModules[i] = "checkModule(" + names[i] + ")"; - } - } } else { - // list of modules to test: (sw,sc,sd) - if (module.indexOf(",") != -1) { - String[] names = module.split(","); - checkModules = new String[names.length]; - for (int i = 0; i < names.length; i++) { - String trim = names[i].trim(); - checkModules[i] = "checkModule(" + trim + ")"; - } - } else { - checkModules = new String[]{"checkModule(" + module + ")"}; - } + log.println("No modules containing qa/unoapi foder found => OK"); + state = true; } - entry = desc.createTestDesc("complex.unoapi.CheckModuleAPI", "complex.unoapi.CheckModuleAPI", checkModules, log); - java_complex complex = new java_complex(); + setUnoApiCwsStatus(state); - log.println("********** start test *************"); - boolean result = complex.executeTest(param, new DescEntry[]{entry}); - log.println("********** end test *************"); + } + + private void setUnoApiCwsStatus(boolean status) { + + if (!param.getBool(PropertyName.NO_CWS_ATTACH)) { + + final String version = (String) param.get(PropertyName.VERSION); + if (version.startsWith("cws_")) { + try { - assure("CheckModuleAPI.module(" + module + ") PASSED.FAILED", result); + // cws version: all added modules must be tested + final String cws = version.substring(4, version.length()); + final CwsDataExchangeImpl cde = new CwsDataExchangeImpl(cws, param, log); + cde.setUnoApiCwsStatus(status); + } catch (ParameterNotFoundException ex) { + log.println("ERROR: could not wirte status to EIS database: " + ex.toString()); + } + } + } } public String[] getTestMethodNames() { |