org.rhq.plugins.perftest.PerfTestRogueDiscoveryComponent.java Source code

Java tutorial

Introduction

Here is the source code for org.rhq.plugins.perftest.PerfTestRogueDiscoveryComponent.java

Source

/*
 * RHQ Management Platform
 * Copyright (C) 2005-2008 Red Hat, Inc.
 * All rights reserved.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation version 2 of the License.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */
package org.rhq.plugins.perftest;

import java.util.Set;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

import org.rhq.core.domain.resource.ResourceType;
import org.rhq.core.pluginapi.inventory.DiscoveredResourceDetails;
import org.rhq.core.pluginapi.inventory.InvalidPluginConfigurationException;
import org.rhq.core.pluginapi.inventory.ResourceDiscoveryComponent;
import org.rhq.core.pluginapi.inventory.ResourceDiscoveryContext;
import org.rhq.plugins.perftest.resource.ResourceFactory;

@SuppressWarnings("unchecked")
public class PerfTestRogueDiscoveryComponent implements ResourceDiscoveryComponent {
    private Log log = LogFactory.getLog(PerfTestRogueDiscoveryComponent.class);

    private static final String SYSPROP_DISCOVERY = "rhq.perftest.server-rogue-discovery";
    private static final String SYSPROP_DISCOVERY_INT = "rhq.perftest.server-rogue-discovery-interruptable";

    public Set<DiscoveredResourceDetails> discoverResources(ResourceDiscoveryContext context)
            throws InvalidPluginConfigurationException, Exception {
        ResourceType resourceType = context.getResourceType();

        ScenarioManager manager = ScenarioManager.getInstance();
        Set<DiscoveredResourceDetails> allResourceDetails = null;
        if (manager.isEnabled()) {
            ResourceFactory resourceFactory = manager.getResourceFactory(resourceType.getName());
            allResourceDetails = resourceFactory.discoverResources(context);

            String value = System.getProperty(SYSPROP_DISCOVERY);
            if (value != null) {
                if (value.equalsIgnoreCase("error")) {
                    throw new Exception("The rogue discovery component was configured to throw this exception");
                }
                try {
                    long ms = Long.parseLong(value); // throws number format exception if not a number
                    log.info("The rogue discovery component was told to sleep: " + ms + "ms");
                    sleep(ms);
                    log.info("The rogue discovery component has finished its sleep of " + ms + "ms");
                } catch (Exception e) {
                    throw new InvalidPluginConfigurationException(
                            "The rogue discovery component was configured to throw this invalid config exception",
                            e);
                }
            } else {
                log.info(
                        "The rogue discovery component was not configured to do anything bad - returning normally");
            }
        }

        return allResourceDetails;
    }

    /**
     * Ensure we sleep for the full amount of millis, even if interrupted.
     * If the thread is interrupted, but our sysprop {@link #SYSPROP_DISCOVERY_INT} is set
     * to true, this method will abort.
     * 
     * @param ms millis to sleep
     */
    private void sleep(long ms) {
        long start = System.currentTimeMillis();
        long finish = start + ms;

        while (System.currentTimeMillis() < finish) {
            try {
                Thread.sleep(finish - System.currentTimeMillis());
            } catch (InterruptedException e) {
                log.warn("The rogue discovery component was interrupted during its sleep", e);
                if (Boolean.getBoolean(SYSPROP_DISCOVERY_INT)) {
                    log.warn("The rogue discovery component will abort its sleep due to the interrupt");
                    return;
                }
            }
        }
    }
}