Search in sources :

Example 1 with InvalidConfigurationException

use of org.walkmod.exceptions.InvalidConfigurationException in project walkmod-core by walkmod.

the class WalkModFacade method readConfig.

private Configuration readConfig(ConfigurationProvider... cp) throws InvalidConfigurationException {
    Configuration config = null;
    try {
        ConfigurationManager cfgManager = new ConfigurationManager(cfg, cp);
        config = cfgManager.getConfiguration();
        config.setParameters(options.getMutableCopyOfDynamicArgs());
    } catch (Exception e) {
        printConfigError(e);
    }
    return config;
}
Also used : Configuration(org.walkmod.conf.entities.Configuration) ConfigurationManager(org.walkmod.conf.ConfigurationManager) WalkModException(org.walkmod.exceptions.WalkModException) IOException(java.io.IOException) InvalidConfigurationException(org.walkmod.exceptions.InvalidConfigurationException)

Example 2 with InvalidConfigurationException

use of org.walkmod.exceptions.InvalidConfigurationException in project walkmod-core by walkmod.

the class WalkModFacade method install.

/**
 * Downloads the list of declared plugins in the configuration file using Ivy. Ignores the
 * ConfigurationProvided if passed in the constructor.
 *
 * @throws InvalidConfigurationException
 *             if the walkmod configuration is invalid and it is working in no verbose mode.
 */
public void install() throws InvalidConfigurationException {
    if (cfg.exists()) {
        if (options.isVerbose()) {
            log.info(cfg.getAbsoluteFile() + " [ok]");
        }
        // Uses Ivy always
        ConfigurationProvider cp = new IvyConfigurationProvider(options.isOffline(), options.isVerbose());
        if (options.isVerbose()) {
            log.info("** THE PLUGIN INSTALLATION STARTS **");
            System.out.print("----------------------------------------");
            System.out.println("----------------------------------------");
        }
        long startTime = System.currentTimeMillis();
        long endTime = startTime;
        DecimalFormat myFormatter = new DecimalFormat("###.###");
        DateFormat df = new SimpleDateFormat("EEE, d MMM yyyy HH:mm:ss", Locale.US);
        boolean error = false;
        try {
            userDir = new File(System.getProperty("user.dir")).getAbsolutePath();
            System.setProperty("user.dir", options.getExecutionDirectory().getCanonicalPath());
            ConfigurationManager cfgManager = new ConfigurationManager(cfg, cp);
            Configuration cf = cfgManager.getConfiguration();
            List<String> modules = cf.getModules();
            if (modules != null && !modules.isEmpty()) {
                for (String module : modules) {
                    File aux = new File(module).getAbsoluteFile();
                    if (aux.isDirectory()) {
                        if (options.isVerbose()) {
                            log.info("** MODULE " + aux.getAbsoluteFile() + " [ok] **");
                        }
                        WalkModFacade facade = new WalkModFacade(OptionsBuilder.options(options).executionDirectory(aux).build());
                        facade.install();
                    } else {
                        log.error("The module " + aux.getAbsolutePath() + " is not an existing directory");
                    }
                }
            }
        } catch (Exception e) {
            System.setProperty("user.dir", userDir);
            if (options.isVerbose()) {
                error = true;
                endTime = System.currentTimeMillis();
                double time = 0;
                if (endTime > startTime) {
                    time = (double) (endTime - startTime) / (double) 1000;
                }
                String timeMsg = myFormatter.format(time);
                System.out.print("----------------------------------------");
                System.out.println("----------------------------------------");
                log.info("PLUGIN INSTALLATION FAILS");
                System.out.println();
                System.out.print("----------------------------------------");
                System.out.println("----------------------------------------");
                log.info("Total time: " + timeMsg + " seconds");
                log.info("Finished at: " + df.format(new Date()));
                log.info("Final memory: " + (Runtime.getRuntime().freeMemory()) / 1048576 + " M/ " + (Runtime.getRuntime().totalMemory() / 1048576) + " M");
                System.out.print("----------------------------------------");
                System.out.println("----------------------------------------");
                if (options.isPrintErrors()) {
                    log.error("Plugin installations fails", e);
                } else {
                    log.info("Plugin installations fails. Please, execute walkmod with -e to see the details");
                }
                if (options.isThrowException()) {
                    RuntimeException re = new RuntimeException();
                    re.setStackTrace(e.getStackTrace());
                    throw re;
                }
            } else {
                throw new InvalidConfigurationException(e);
            }
        }
        if (!error) {
            System.setProperty("user.dir", userDir);
            if (options.isVerbose()) {
                endTime = System.currentTimeMillis();
                double time = 0;
                if (endTime > startTime) {
                    time = (double) (endTime - startTime) / (double) 1000;
                }
                String timeMsg = myFormatter.format(time);
                System.out.print("----------------------------------------");
                System.out.println("----------------------------------------");
                System.out.println();
                log.info("PLUGIN INSTALLATION COMPLETE");
                System.out.print("----------------------------------------");
                System.out.println("----------------------------------------");
                log.info("Total time: " + timeMsg + " seconds");
                log.info("Finished at: " + df.format(new Date()));
                log.info("Final memory: " + (Runtime.getRuntime().freeMemory()) / 1048576 + " M/ " + (Runtime.getRuntime().totalMemory() / 1048576) + " M");
                System.out.print("----------------------------------------");
                System.out.println("----------------------------------------");
            }
        }
    } else {
        if (options.isVerbose()) {
            log.error(cfg.getAbsolutePath() + " does not exist. The root directory of your project must contain a walkmod.xml");
        } else {
            throw new WalkModException(cfg.getAbsolutePath() + " does not exist. The root directory of your project must contain a walkmod.xml");
        }
    }
}
Also used : WalkModException(org.walkmod.exceptions.WalkModException) Configuration(org.walkmod.conf.entities.Configuration) DynamicModulesConfigurationProvider(org.walkmod.conf.providers.DynamicModulesConfigurationProvider) ConfigurationProvider(org.walkmod.conf.ConfigurationProvider) ProjectConfigurationProvider(org.walkmod.conf.ProjectConfigurationProvider) DynamicConfigurationProvider(org.walkmod.conf.providers.DynamicConfigurationProvider) IvyConfigurationProvider(org.walkmod.conf.providers.IvyConfigurationProvider) DecimalFormat(java.text.DecimalFormat) WalkModException(org.walkmod.exceptions.WalkModException) IOException(java.io.IOException) InvalidConfigurationException(org.walkmod.exceptions.InvalidConfigurationException) Date(java.util.Date) InvalidConfigurationException(org.walkmod.exceptions.InvalidConfigurationException) SimpleDateFormat(java.text.SimpleDateFormat) DateFormat(java.text.DateFormat) SimpleDateFormat(java.text.SimpleDateFormat) File(java.io.File) ConfigurationManager(org.walkmod.conf.ConfigurationManager) IvyConfigurationProvider(org.walkmod.conf.providers.IvyConfigurationProvider)

Example 3 with InvalidConfigurationException

use of org.walkmod.exceptions.InvalidConfigurationException in project walkmod-core by walkmod.

the class WalkModFacade method run.

private void run(List<File> result, WalkmodCommand command, ExecutionModeEnum execMode, String... chains) throws InvalidConfigurationException {
    userDir = new File(System.getProperty("user.dir")).getAbsolutePath();
    System.setProperty("user.dir", options.getExecutionDirectory().getAbsolutePath());
    Configuration config = null;
    if (cfg.exists()) {
        if (options.isVerbose()) {
            log.info(cfg.getAbsoluteFile() + " [ok]");
        }
        config = readConfig(locateConfigurationProvider(), new ExecutionModeProvider(execMode));
    } else {
        config = createConfig(chains, locateConfigurationProvider(), new ExecutionModeProvider(execMode));
    }
    try {
        config.executeModuleChains(options, command, chains);
    } catch (Exception e) {
        System.setProperty("user.dir", userDir);
        if (options.isVerbose()) {
            if (!options.isPrintErrors()) {
                log.error(cfg.getAbsolutePath() + " is invalid. Please, execute walkmod with -e to see the details.");
            } else {
                log.error("Invalid configuration", e);
            }
            if (options.isThrowException()) {
                RuntimeException re = new RuntimeException();
                re.setStackTrace(e.getStackTrace());
                throw re;
            }
        } else {
            throw new InvalidConfigurationException(e);
        }
    }
    config.execute(userDir, options, chains);
    result.addAll(Summary.getInstance().getWrittenFiles());
    System.setProperty("user.dir", userDir);
}
Also used : Configuration(org.walkmod.conf.entities.Configuration) File(java.io.File) ExecutionModeProvider(org.walkmod.conf.providers.ExecutionModeProvider) WalkModException(org.walkmod.exceptions.WalkModException) IOException(java.io.IOException) InvalidConfigurationException(org.walkmod.exceptions.InvalidConfigurationException) InvalidConfigurationException(org.walkmod.exceptions.InvalidConfigurationException)

Example 4 with InvalidConfigurationException

use of org.walkmod.exceptions.InvalidConfigurationException in project walkmod-core by walkmod.

the class WalkModFacade method createConfig.

private Configuration createConfig(String[] chains, ConfigurationProvider... cp) throws InvalidConfigurationException {
    Configuration config = new ConfigurationImpl();
    try {
        DynamicConfigurationProvider prov = new DynamicConfigurationProvider(options, chains);
        prov.init(config);
        prov.load();
        ConfigurationManager cfgManager = new ConfigurationManager(config, cp);
        DynamicModulesConfigurationProvider prov2 = new DynamicModulesConfigurationProvider();
        prov2.init(config);
        prov2.load();
        config = cfgManager.getConfiguration();
        config.setParameters(options.getMutableCopyOfDynamicArgs());
    } catch (Exception e) {
        printConfigError(e);
    }
    return config;
}
Also used : Configuration(org.walkmod.conf.entities.Configuration) DynamicConfigurationProvider(org.walkmod.conf.providers.DynamicConfigurationProvider) ConfigurationImpl(org.walkmod.conf.entities.impl.ConfigurationImpl) ConfigurationManager(org.walkmod.conf.ConfigurationManager) DynamicModulesConfigurationProvider(org.walkmod.conf.providers.DynamicModulesConfigurationProvider) WalkModException(org.walkmod.exceptions.WalkModException) IOException(java.io.IOException) InvalidConfigurationException(org.walkmod.exceptions.InvalidConfigurationException)

Aggregations

IOException (java.io.IOException)4 Configuration (org.walkmod.conf.entities.Configuration)4 InvalidConfigurationException (org.walkmod.exceptions.InvalidConfigurationException)4 WalkModException (org.walkmod.exceptions.WalkModException)4 ConfigurationManager (org.walkmod.conf.ConfigurationManager)3 File (java.io.File)2 DynamicConfigurationProvider (org.walkmod.conf.providers.DynamicConfigurationProvider)2 DynamicModulesConfigurationProvider (org.walkmod.conf.providers.DynamicModulesConfigurationProvider)2 DateFormat (java.text.DateFormat)1 DecimalFormat (java.text.DecimalFormat)1 SimpleDateFormat (java.text.SimpleDateFormat)1 Date (java.util.Date)1 ConfigurationProvider (org.walkmod.conf.ConfigurationProvider)1 ProjectConfigurationProvider (org.walkmod.conf.ProjectConfigurationProvider)1 ConfigurationImpl (org.walkmod.conf.entities.impl.ConfigurationImpl)1 ExecutionModeProvider (org.walkmod.conf.providers.ExecutionModeProvider)1 IvyConfigurationProvider (org.walkmod.conf.providers.IvyConfigurationProvider)1