Package org.apache.airavata.integration

Source Code of org.apache.airavata.integration.BaseCaseIT

/*
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements.  See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership.  The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License.  You may obtain a copy of the License at
*
*   http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied.  See the License for the
* specific language governing permissions and limitations
* under the License.
*
*/

package org.apache.airavata.integration;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Set;

import junit.framework.Assert;

import org.apache.airavata.client.api.exception.AiravataAPIInvocationException;
import org.apache.airavata.client.tools.DocumentCreator;
import org.apache.airavata.model.util.ExperimentModelUtil;
import org.apache.airavata.model.util.ProjectModelUtil;
import org.apache.airavata.model.workspace.Project;
import org.apache.airavata.model.workspace.experiment.ComputationalResourceScheduling;
import org.apache.airavata.model.workspace.experiment.DataObjectType;
import org.apache.airavata.model.workspace.experiment.DataType;
import org.apache.airavata.model.workspace.experiment.Experiment;
import org.apache.airavata.model.workspace.experiment.JobState;
import org.apache.airavata.model.workspace.experiment.JobStatus;
import org.apache.airavata.model.workspace.experiment.UserConfigurationData;
import org.apache.airavata.registry.api.workflow.ApplicationJob;
import org.apache.airavata.workflow.model.wf.Workflow;
import org.apache.airavata.ws.monitor.EventData;
import org.apache.airavata.ws.monitor.EventDataListenerAdapter;
import org.apache.airavata.ws.monitor.EventDataRepository;
import org.apache.airavata.ws.monitor.Monitor;
import org.apache.airavata.ws.monitor.MonitorUtil;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test;

/**
* Integration test class.
*/
public class BaseCaseIT extends WorkflowIntegrationTestBase {


    public BaseCaseIT() throws Exception {
        setUpEnvironment();
    }

    @BeforeTest
    public void setUp() throws Exception {
        this.airavataAPI = getAiravataAPI();
        this.client = getClient();
    }

    @Test(groups = {"setupTests"})
    public void testSetup() throws Exception {
        String version = this.client.getAPIVersion();
        Assert.assertNotNull(version);
        log("Airavata version - " + version);

    }

//    @Test(groups = {"setupTests"}, dependsOnMethods = {"testSetup"})
//    public void testURLs() throws AiravataAPIInvocationException {
//        URI eventingServiceURL = this.airavataAPI.getAiravataManager().getEventingServiceURL();
//        Assert.assertNotNull(eventingServiceURL);
//
//        URI messageBoxServiceURL = this.airavataAPI.getAiravataManager().getMessageBoxServiceURL();
//        Assert.assertNotNull(messageBoxServiceURL);
//    }

    @Test(groups = {"echoGroup"}, dependsOnGroups = {"setupTests"})
    public void testEchoService() throws Exception {
        log.info("Running job in trestles...");
        DocumentCreator documentCreator = new DocumentCreator(airavataAPI);
        documentCreator.createPBSDocsForOGCE();
        List<DataObjectType> exInputs = new ArrayList<DataObjectType>();
        DataObjectType input = new DataObjectType();
        input.setKey("echo_input");
        input.setType(DataType.STRING);
        input.setValue("echo_output=Hello World");
        exInputs.add(input);

        List<DataObjectType> exOut = new ArrayList<DataObjectType>();
        DataObjectType output = new DataObjectType();
        output.setKey("echo_output");
        output.setType(DataType.STRING);
        output.setValue("");
        exOut.add(output);

        Project project = ProjectModelUtil.createProject("project1", "admin", "test project");
        String projectId = getClient().createProject(project);

        Experiment simpleExperiment = ExperimentModelUtil.createSimpleExperiment(projectId, "admin", "echoExperiment", "SimpleEcho2", "SimpleEcho2", exInputs);
        simpleExperiment.setExperimentOutputs(exOut);

        ComputationalResourceScheduling scheduling = ExperimentModelUtil.createComputationResourceScheduling("trestles.sdsc.edu", 1, 1, 1, "normal", 0, 0, 1, "sds128");
        scheduling.setResourceHostId("gsissh-trestles");
        UserConfigurationData userConfigurationData = new UserConfigurationData();
        userConfigurationData.setAiravataAutoSchedule(false);
        userConfigurationData.setOverrideManualScheduledParams(false);
        userConfigurationData.setComputationalResourceScheduling(scheduling);
        simpleExperiment.setUserConfigurationData(userConfigurationData);
        final String expId = createExperiment(simpleExperiment);
        System.out.println("Experiment Id returned : " + expId);
        log.info("Experiment Id returned : " + expId );
        launchExperiment(expId);
        System.out.println("Launched successfully");

        Thread monitor = (new Thread(){
            public void run() {
                Map<String, JobStatus> jobStatuses = null;
                while (true) {
                    try {
                        jobStatuses = client.getJobStatuses(expId);
                        Set<String> strings = jobStatuses.keySet();
                        for (String key : strings) {
                            JobStatus jobStatus = jobStatuses.get(key);
                            if(jobStatus == null){
                                return;
                            }else {
                                if (JobState.COMPLETE.equals(jobStatus.getJobState())) {
                                    log.info("Job completed Job ID: " + key);
                                    return;
                                }else{
                                    log.info("Job ID:" + key + "  Job Status : " + jobStatuses.get(key).getJobState().toString());
                                }
                            }
                        }
                        Thread.sleep(5000);
                    } catch (Exception e) {
                        log.error("Thread interrupted", e.getMessage());
                    }
                }
            }
        });
            monitor.start();
        try {
            monitor.join();
        } catch (InterruptedException e) {
            log.error("Thread interrupted..", e.getMessage());
        }

    }

    @Test(groups = {"echoGroup"}, dependsOnGroups = {"setupTests"})
    public void testEchoServiceStampede() throws Exception {
        log.info("Running job in Stampede...");
        DocumentCreator documentCreator = new DocumentCreator(airavataAPI);
        documentCreator.createSlurmDocs();
        List<DataObjectType> exInputs = new ArrayList<DataObjectType>();
        DataObjectType input = new DataObjectType();
        input.setKey("echo_input");
        input.setType(DataType.STRING);
        input.setValue("echo_output=Hello World");
        exInputs.add(input);

        List<DataObjectType> exOut = new ArrayList<DataObjectType>();
        DataObjectType output = new DataObjectType();
        output.setKey("echo_output");
        output.setType(DataType.STRING);
        output.setValue("");
        exOut.add(output);

        Project project = ProjectModelUtil.createProject("project1", "admin", "test project");
        String projectId = getClient().createProject(project);

        Experiment simpleExperiment = ExperimentModelUtil.createSimpleExperiment(projectId, "admin", "echoExperiment", "SimpleEcho3", "SimpleEcho3", exInputs);
        simpleExperiment.setExperimentOutputs(exOut);

        ComputationalResourceScheduling scheduling = ExperimentModelUtil.createComputationResourceScheduling("stampede.tacc.xsede.org", 1, 1, 1, "normal", 0, 0, 1, "TG-STA110014S");
        scheduling.setResourceHostId("stampede-host");
        UserConfigurationData userConfigurationData = new UserConfigurationData();
        userConfigurationData.setAiravataAutoSchedule(false);
        userConfigurationData.setOverrideManualScheduledParams(false);
        userConfigurationData.setComputationalResourceScheduling(scheduling);
        simpleExperiment.setUserConfigurationData(userConfigurationData);
        final String expId = createExperiment(simpleExperiment);
        System.out.println("Experiment Id returned : " + expId);
        log.info("Experiment Id returned : " + expId );
        launchExperiment(expId);
        System.out.println("Launched successfully");

        Thread monitor = (new Thread(){
            public void run() {
                Map<String, JobStatus> jobStatuses = null;
                while (true) {
                    try {
                        jobStatuses = client.getJobStatuses(expId);
                        Set<String> strings = jobStatuses.keySet();
                        for (String key : strings) {
                            JobStatus jobStatus = jobStatuses.get(key);
                            if(jobStatus == null){
                                return;
                            }else {
                                if (JobState.COMPLETE.equals(jobStatus.getJobState())) {
                                    log.info("Job completed Job ID: " + key);
                                    return;
                                }else{
                                    log.info("Job ID:" + key + "  Job Status : " + jobStatuses.get(key).getJobState().toString());
                                }
                            }
                        }
                        Thread.sleep(5000);
                    } catch (Exception e) {
                        log.error("Thread interrupted", e.getMessage());
                    }
                }
            }
        });
        monitor.start();
        try {
            monitor.join();
        } catch (InterruptedException e) {
            log.error("Thread interrupted..", e.getMessage());
        }

    }

    @Test(groups = {"performanceTesting"})
    public void testExistsHostDescriptor() throws AiravataAPIInvocationException {
        airavataAPI.getApplicationManager().isHostDescriptorExists("trestles.sdsc.edu");
    }

//    @Test(groups = {"echoGroup"}/* , dependsOnMethods = { "testEchoService" } */)
//    public void testUpdateEchoService() throws Exception {
//
//        DescriptorBuilder descriptorBuilder = airavataAPI.getDescriptorBuilder();
//
//        HostDescription hostDescription = descriptorBuilder.buildHostDescription(HostDescriptionType.type, "localhost",
//                "127.0.0.1");
//
//        log("Trying to add host description ....");
//        try {
//            airavataAPI.getApplicationManager().addHostDescription(hostDescription);
//            Assert.fail("Host Descriptor should already exists and should go to update.");
//        } catch (DescriptorAlreadyExistsException e) {
//
//            log("Updating host description ....");
//            airavataAPI.getApplicationManager().updateHostDescription(hostDescription);
//        }
//
//        Assert.assertTrue(airavataAPI.getApplicationManager().isHostDescriptorExists(
//                hostDescription.getType().getHostName()));
//
//        List<InputParameterType> inputParameters = new ArrayList<InputParameterType>();
//        inputParameters.add(descriptorBuilder.buildInputParameterType("echo_input", "echo input", DataType.STRING));
//
//        List<OutputParameterType> outputParameters = new ArrayList<OutputParameterType>();
//        outputParameters.add(descriptorBuilder.buildOutputParameterType("echo_output", "Echo output", DataType.STRING));
//
//        ServiceDescription serviceDescription = descriptorBuilder.buildServiceDescription("Echo", "Echo service",
//                inputParameters, outputParameters);
//
//        log("Adding service description ...");
//        try {
//            airavataAPI.getApplicationManager().addServiceDescription(serviceDescription);
//            Assert.fail("Service Descriptor should already exists and should go to update.");
//        } catch (DescriptorAlreadyExistsException e) {
//
//            log("Updating service description ....");
//            airavataAPI.getApplicationManager().updateServiceDescription(serviceDescription);
//        }
//
//        Assert.assertTrue(airavataAPI.getApplicationManager().isServiceDescriptorExists(
//                serviceDescription.getType().getName()));
//
//        // Deployment descriptor
//        ApplicationDescription applicationDeploymentDescription = descriptorBuilder
//                .buildApplicationDeploymentDescription("EchoApplication", OsUtils.getEchoExecutable(), OsUtils.getTempFolderPath());
//
//        log("Adding deployment description ...");
//        try {
//            airavataAPI.getApplicationManager().addApplicationDescription(serviceDescription, hostDescription,
//                    applicationDeploymentDescription);
//            Assert.fail("Application Descriptor should already exists and should go to update.");
//        } catch (DescriptorAlreadyExistsException e) {
//
//            log("Updating application description ....");
//            airavataAPI.getApplicationManager().updateApplicationDescription(serviceDescription, hostDescription,
//                    applicationDeploymentDescription);
//        }
//
//        Assert.assertTrue(airavataAPI.getApplicationManager().isApplicationDescriptorExists(
//                serviceDescription.getType().getName(), hostDescription.getType().getHostName(),
//                applicationDeploymentDescription.getType().getApplicationName().getStringValue()));
//
//        log("Saving workflow ...");
//        Workflow workflow = new Workflow(getWorkflowComposeContent("src/test/resources/EchoWorkflow.xwf"));
//
//        try {
//            airavataAPI.getWorkflowManager().addWorkflow(workflow);
//            Assert.fail("Workflow should already exists and should go to update.");
//        } catch (WorkflowAlreadyExistsException e) {
//
//            log("Updating workflow...");
//            airavataAPI.getWorkflowManager().updateWorkflow(workflow);
//        }
//
//        Assert.assertTrue(airavataAPI.getWorkflowManager().isWorkflowExists(workflow.getName()));
//
//        log("Workflow setting up completed ...");
//
//        try {
//            /**
//             * FIXME : Saving to GFAC_JOB_DATA is commented out due to new orchestrator changes. Due to that, this test will fail. Once it is fixed we need to uncomment this too.
//             **/
////            runWorkFlowWithoutMonitor(workflow, Arrays.asList("echo_output=Airavata_Test"));
//        } catch (Exception e) {
//            log.error("An error occurred while invoking workflow", e);
//            throw e;
//        }
//    }

    protected void runWorkFlow(Workflow workflow, List<String> inputValues) throws Exception {

        String experimentId = executeWorkflow(workflow, inputValues);
        monitor(experimentId);
    }

    protected void runWorkFlowWithoutMonitor(Workflow workflow, List<String> inputValues) throws Exception {

        String experimentId = executeWorkflow(workflow, inputValues);

        verifyOutput(experimentId, "echo_output=Airavata_Test");

        log.info("Verifying application jobs ....");

        List<ApplicationJob> applicationJobs = airavataAPI.getProvenanceManager().getApplicationJobs(experimentId, null, null);
        Assert.assertEquals(applicationJobs.size(), 1);
    }

//    protected String getWorkflowComposeContent(String fileName) throws IOException {
//        File f = new File(".");
//        log.debug(f.getAbsolutePath());
//
//        File echoWorkflow = new File(fileName);
//        if (!echoWorkflow.exists()) {
//            fileName = "modules/integration-tests/src/test/resources/EchoWorkflow.xwf";
//        }
//
//        BufferedReader reader = new BufferedReader(new FileReader(fileName));
//        String line;
//        StringBuilder buffer = new StringBuilder();
//        while ((line = reader.readLine()) != null) {
//            buffer.append(line);
//        }
//        reader.close();
//        log.debug("Workflow compose - " + buffer.toString());
//        return buffer.toString();
//    }

    public void monitor(final String experimentId) throws Exception {
        final Monitor experimentMonitor = airavataAPI.getExecutionManager().getExperimentMonitor(experimentId,
                new EventDataListenerAdapter() {

                    public void notify(EventDataRepository eventDataRepo, EventData eventData) {
                        Assert.assertNotNull(eventDataRepo);
                        Assert.assertNotNull(eventData);
                        if (MonitorUtil.EventType.WORKFLOW_TERMINATED.equals(eventData.getType())) {
                            try {
                                BaseCaseIT.this.verifyOutput(experimentId, "echo_output=Airavata_Test");
                            } catch (Exception e) {
                                log.error("Error verifying output", e);
                                Assert.fail("Error occurred while verifying output.");
                            } finally {
                                getMonitor().stopMonitoring();
                            }
                        }
                        log.info("No of events: " + eventDataRepo.getEvents().size());
                    }
                });
        experimentMonitor.startMonitoring();
        experimentMonitor.waitForCompletion();
    }
}
TOP

Related Classes of org.apache.airavata.integration.BaseCaseIT

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.