package org.ourgrid.acceptance.broker;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import org.junit.Test;
import org.junit.experimental.categories.Category;
import org.ourgrid.acceptance.util.ClassAdsUtils;
import org.ourgrid.acceptance.util.JDLCompliantTest;
import org.ourgrid.acceptance.util.JDLUtils;
import org.ourgrid.acceptance.util.broker.Operations;
import org.ourgrid.acceptance.util.broker.Req_302_Util;
import org.ourgrid.acceptance.util.broker.Req_304_Util;
import org.ourgrid.acceptance.util.broker.Req_309_Util;
import org.ourgrid.acceptance.util.broker.Req_311_Util;
import org.ourgrid.acceptance.util.broker.Req_312_Util;
import org.ourgrid.acceptance.util.broker.Req_313_Util;
import org.ourgrid.acceptance.util.broker.Req_314_Util;
import org.ourgrid.acceptance.util.broker.Req_321_Util;
import org.ourgrid.acceptance.util.broker.Req_324_Util;
import org.ourgrid.acceptance.util.broker.Req_325_Util;
import org.ourgrid.acceptance.util.broker.Req_327_Util;
import org.ourgrid.acceptance.util.broker.Req_328_Util;
import org.ourgrid.acceptance.util.broker.Req_329_Util;
import org.ourgrid.acceptance.util.broker.Req_330_Util;
import org.ourgrid.acceptance.util.broker.States;
import org.ourgrid.acceptance.util.broker.TestJob;
import org.ourgrid.broker.BrokerComponentContextFactory;
import org.ourgrid.broker.BrokerServerModule;
import org.ourgrid.common.interfaces.LocalWorkerProvider;
import org.ourgrid.common.interfaces.to.GridProcessHandle;
import org.ourgrid.common.specification.OurGridSpecificationConstants;
import org.ourgrid.common.specification.job.IOBlock;
import org.ourgrid.common.specification.job.IOEntry;
import org.ourgrid.common.specification.job.TaskSpecification;
import org.ourgrid.common.specification.main.SDFClassAdsSemanticAnalyzer;
import org.ourgrid.common.specification.worker.WorkerSpecification;
import org.ourgrid.reqtrace.ReqTest;
import br.edu.ufcg.lsd.commune.context.PropertiesFileParser;
import br.edu.ufcg.lsd.commune.identification.DeploymentID;
import br.edu.ufcg.lsd.commune.processor.filetransfer.OutgoingTransferHandle;
import br.edu.ufcg.lsd.commune.testinfra.util.TestContext;
import br.edu.ufcg.lsd.commune.testinfra.util.TestStub;
@ReqTest(reqs="REQ313")
public class Req_313_Test extends BrokerAcceptanceTestCase {
private Req_302_Util req_302_Util;
private Req_304_Util req_304_Util;
private Req_309_Util req_309_Util;
private Req_311_Util req_311_Util;
private Req_312_Util req_312_Util;
private Req_313_Util req_313_Util;
private Req_314_Util req_314_Util;
private Req_324_Util req_324_Util;
private Req_327_Util req_327_Util;
private Req_328_Util req_328_Util;
private Req_329_Util req_329_Util;
private Req_321_Util req_321_Util;
private Req_325_Util req_325_Util;
private Req_330_Util req_330_Util;
private String peerUserAtServer;
private static final String PROPERTIES_FILENAME_2_PEERS = BROKER_TEST_DIR + "broker2peers.properties";
@Override
public void setUp() throws Exception {
req_302_Util = new Req_302_Util(super.createComponentContext());
req_304_Util = new Req_304_Util(super.createComponentContext());
req_309_Util = new Req_309_Util(super.createComponentContext());
req_311_Util = new Req_311_Util(super.createComponentContext());
req_312_Util = new Req_312_Util(super.createComponentContext());
req_313_Util = new Req_313_Util(getComponentContext());
req_314_Util = new Req_314_Util(getComponentContext());
req_321_Util = new Req_321_Util(getComponentContext());
req_324_Util = new Req_324_Util(getComponentContext());
req_325_Util = new Req_325_Util(getComponentContext());
req_327_Util = new Req_327_Util(super.createComponentContext());
req_328_Util = new Req_328_Util(super.createComponentContext());
req_329_Util = new Req_329_Util(super.createComponentContext());
req_330_Util = new Req_330_Util(super.createComponentContext());
peerUserAtServer = "test@servertest";
}
private TestContext createComponentContext_2_peers() {
return new TestContext(
new BrokerComponentContextFactory(
new PropertiesFileParser(PROPERTIES_FILENAME_2_PEERS
)).createContext());
}
/**
* This test contains the following steps:
*
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* + Init Block:
* # Condition: mem = 256
* # IOEntry:
* * Command: PUT
* * Source File: file.txt
* * Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Verify if the following info message was logged:
* o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
*/
@ReqTest(test="AT-313.1", reqs="REQ313")
@Test public void test_at_313_1_WorkerReadyToReceiveFiles() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
IOEntry entry = new IOEntry("PUT", BrokerAcceptanceTestCase.BROKER_TEST_DIR + "file.txt", "Class.class");
TestJob testJob = req_304_Util.addJob(true, 1, broker, "echo Hello World", "Test Job", "mem = 256", entry, peers);
req_304_Util.addJob(true, 2, broker, "echo Hello World 2", "Test Job 2", peers);
//try to receive worker
List<TestStub> workerTestStubs = new LinkedList<TestStub>();
Map<String, String> attributes = new HashMap<String, String>();
attributes.put(OurGridSpecificationConstants.ATT_MEM, "mem = 256");
attributes.put(OurGridSpecificationConstants.ATT_SERVERNAME, "xmpp.ourgrid.org");
attributes.put(OurGridSpecificationConstants.ATT_USERNAME, "username");
WorkerSpecification workerSpec = new WorkerSpecification(attributes);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//verify messages
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, null);
}
/**
*This test contains the following steps:
*
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Verify if the Worker receveid a RemoteExecute? message;
*/
@ReqTest(test="AT-313.2", reqs="REQ313")
@Test public void test_at_313_2_WorkerReadyToExecuteRemoteCommands() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
TestJob testJob = req_304_Util.addJob(true, 1, broker, "echo Hello World", "Test Job", peers);
req_304_Util.addJob(true, 2, broker, "echo Hello World 2", "Test Job 2", peers);
//try to receive worker
List<TestStub> workerTestStubs = new ArrayList<TestStub>();
Map<String, String> attributes = new HashMap<String, String>();
attributes.put(OurGridSpecificationConstants.ATT_MEM, "mem = 256");
attributes.put(OurGridSpecificationConstants.ATT_SERVERNAME, "xmpp.ourgrid.org");
attributes.put(OurGridSpecificationConstants.ATT_USERNAME, "username");
WorkerSpecification workerSpec = new WorkerSpecification(attributes);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//verify messages
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.EXECUTE_COMMAND_OPERATION, requestID, null);
}
/**
*This test contains the following steps:
*
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* + Init Block:
* # Condition: mem = 256
* # IOEntry:
* * Command: STORE
* * Source File: file.txt
* * Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Verify if the following info message was logged:
* o File info requested: file.txt, handle: X, replica: 1.1.1 Where X is the TransferHandle? ID;
* Verify if the Worker receveid a GetFileInfo? message;
*/
@ReqTest(test="AT-313.3", reqs="REQ313")
@Test public void test_at_313_3_WorkerReadyToSendFileInformation() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
IOEntry entry = new IOEntry("STORE", BROKER_TEST_DIR + "file.txt", "Class.class");
TestJob testJob1 = req_304_Util.addJob(true, 1, broker, "echo Hello World", "Test Job", "mem = 256", entry, peers);
req_304_Util.addJob(true, 2, broker, "echo Hello World 2", "Test Job 2", peers);
//try to receive worker
List<TestStub> workerTestStubs = new ArrayList<TestStub>();
Map<String, String> attributes = new HashMap<String, String>();
attributes.put(OurGridSpecificationConstants.ATT_MEM, "mem = 256");
attributes.put(OurGridSpecificationConstants.ATT_SERVERNAME, "xmpp.ourgrid.org");
attributes.put(OurGridSpecificationConstants.ATT_USERNAME, "username");
WorkerSpecification workerSpec = new WorkerSpecification(attributes);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob1);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob1, new GridProcessHandle(1, 1, 1));
//verify
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_INFO_OPERATION, requestID, testJob1);
}
/**
* * Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
o Label: Test Job
o Task Spec:
+ Remote Execute: echo Hello World;
+ Init Block:
# Condition: mem = 256
# IOEntry:
* Command: PUT
* Source File: file.txt
* Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote
* attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
o Public Key: workerPublicKey;
o Request ID: generated by job 1;
o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the
Worker;
* Verify if the worker's startWork message was called;
* Verify if the following info message was logged:
o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
* Call WorkerIsReady? message;
* Verify if the following warn message was logged:
o Invalid operation. The execution is on the state: Init
* @throws Exception
*/
@ReqTest(test="AT-313.4", reqs="REQ313")
@Test public void test_at_313_4_WorkerReadyToExecuteOnInitialState() throws Exception {
//start broker
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
//call doNotifyRecovery passing a peer with username test
DeploymentID deploymentID1 = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID1, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login with peer
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
IOEntry entry = new IOEntry("PUT", BROKER_TEST_DIR + "file.txt", "Class.class");
TestJob testJob = req_304_Util.addJob(true, 1, broker, "echo Hello World", "Test Job", "mem = 256", entry, peers);
req_304_Util.addJob(true, 2, broker, "echo Hello World 2", "Test Job 2", peers);
//try to receive worker
List<TestStub> workerTestStubs = new ArrayList<TestStub>();
Map<String, String> attributes = new HashMap<String, String>();
attributes.put(OurGridSpecificationConstants.ATT_MEM, "mem = 256");
attributes.put(OurGridSpecificationConstants.ATT_SERVERNAME, "xmpp.ourgrid.org");
attributes.put(OurGridSpecificationConstants.ATT_USERNAME, "username");
WorkerSpecification workerSpec = new WorkerSpecification(attributes);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call WorkerIsReady
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, null);
//call WorkerIsReady
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, true,
States.INIT_STATE, 1, 1, null, null, null, null);
}
/**
*This test contains the following steps:
*
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* + Init Block:
* # Condition: mem = 256
* # IOEntry:
* * Command: STORE
* * Source File: file.txt
* * Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Verify if the following info message was logged:
* o File info requested: file.txt, handle: X, replica: 1.1.1 Where X is the TransferHandle? ID;
* Verify if the Worker receveid a GetFileInfo? message;
* Call WorkerIsReady? message;
* Verify if the following warn message was logged:
* o Invalid operation. The execution is on the state: Init
*/
@ReqTest(test="AT-313.5", reqs="REQ313")
@Test public void test_at_313_5_WorkerReadyToExecuteOnInitStatWithFileInformation() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
IOEntry entry = new IOEntry("STORE", BROKER_TEST_DIR + "file.txt", "Class.class");
TestJob testJob1 = req_304_Util.addJob(true, 1, broker, "echo Hello World", "Test Job", "mem = 256", entry, peers);
req_304_Util.addJob(true, 2, broker, "echo Hello World 2", "Test Job 2", peers);
//try to receive worker
List<TestStub> workerTestStubs = new ArrayList<TestStub>();
Map<String, String> attributes = new HashMap<String, String>();
attributes.put(OurGridSpecificationConstants.ATT_MEM, "mem = 256");
attributes.put(OurGridSpecificationConstants.ATT_SERVERNAME, "xmpp.ourgrid.org");
attributes.put(OurGridSpecificationConstants.ATT_USERNAME, "username");
WorkerSpecification workerSpec = new WorkerSpecification(attributes);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob1);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob1, new GridProcessHandle(1, 1, 1) );
//call WorkerIsReady
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_INFO_OPERATION, requestID, testJob1);
String[] localFiles = {"Class.class"};
//call WorkerIsReady
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_INFO_OPERATION, true,
States.INIT_STATE, 1, 1, requestID, testJob1, localFiles, localFiles);
}
/**
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* + Init Block:
* # Condition: mem = 256
* # IOEntry:
* * Command: PUT
* * Source File: file.txt
* * Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Verify if the following info message was logged:
* o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
* Call outgoingTransferCompleted message;
* Verify if the following debug message was logged:
* o File transfer finished: file.txt, replica: X Where X is the Grid Process Handle.
* Call WorkerIsReady? message;
* Verify if the following warn message was logged:
* o Invalid operation. The execution is on the state: Remote
*/
@ReqTest(test="AT-313.6", reqs="REQ313")
@Test public void test_at_313_6_WorkerReadyToExecuteOnRemoteStatWithFileInformation() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
IOEntry entry = new IOEntry("PUT", BROKER_TEST_DIR + "file.txt", "Class.class");
TestJob testJob = req_304_Util.addJob(true, 1, broker, "echo Hello World", "Test Job", "mem = 256", entry, peers);
req_304_Util.addJob(true, 2, broker, "echo Hello World 2", "Test Job 2", peers);
//try to receive worker
List<TestStub> workerTestStubs = new ArrayList<TestStub>();
Map<String, String> attributes = new HashMap<String, String>();
attributes.put(OurGridSpecificationConstants.ATT_SERVERNAME, "xmpp.ourgrid.org");
attributes.put(OurGridSpecificationConstants.ATT_USERNAME, "username");
attributes.put(OurGridSpecificationConstants.ATT_MEM, "mem = 256");
WorkerSpecification workerSpec = new WorkerSpecification(attributes);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call WorkerIsReady
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, null);
//Call outgoingTransferCompleted message
OutgoingTransferHandle handle = req_321_Util.getOutgoingTransferHandle(testJob, "Class.class");
req_321_Util.testOutgoingTransferCompleted(broker, States.INIT_STATE, Operations.SEND_FILE_OPERATION, workerTestStub, handle, requestID);
String[] remoteFileNames = new String[1];
remoteFileNames[0] = "Class.class";
String[] localFileNames = new String[1];
localFileNames[0] = BrokerAcceptanceTestCase.BROKER_TEST_DIR + "file.txt";
//call WorkerIsReady
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, true, States.REMOTE_STATE,
1, 1, null, null, localFileNames, remoteFileNames);
}
/**
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* + Init Block:
* # Condition: mem = 256
* # IOEntry:
* * Command: PUT
* * Source File: file.txt
* * Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Call workerIsReady message;
* Verify if the following info message was logged:
* o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
* Call outgoingTransferCompleted message;
* Verify if the following debug message was logged:
* o File transfer finished: file.txt, replica: X Where X is the Grid Process Handle.
* Call hereIsGridProcessResult message;
* Verify if the Worker receveid a getFiles message;
* Call WorkerIsReady? message;
* Verify if the following warn message was logged:
* o Invalid operation. The execution is on the state: Final
*/
@ReqTest(test="AT-313.7", reqs="REQ313")
@Test public void test_at_313_7_WorkerReadyMessageOnFinalState() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
IOEntry entry = new IOEntry("PUT", BROKER_TEST_DIR + "file.txt", "Class.class");
TestJob testJob = req_304_Util.addJob(true, 1, broker, "echo Hello World", "Test Job", "mem = 256", entry, peers);
req_304_Util.addJob(true, 2, broker, "echo Hello World 2", "Test Job 2", peers);
//try to receive worker
List<TestStub> workerTestStubs = new LinkedList<TestStub>();
Map<String, String> attributes = new HashMap<String, String>();
attributes.put(OurGridSpecificationConstants.ATT_MEM, "mem = 256");
attributes.put(OurGridSpecificationConstants.ATT_SERVERNAME, "xmpp.ourgrid.org");
attributes.put(OurGridSpecificationConstants.ATT_USERNAME, "username");
WorkerSpecification workerSpec = new WorkerSpecification(attributes);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call workerIsReady
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, null, null);
//Call outgoingTransferCompleted message
OutgoingTransferHandle handle = req_321_Util.getOutgoingTransferHandle(testJob, "Class.class");
req_321_Util.testOutgoingTransferCompleted(broker, States.INIT_STATE, Operations.SEND_FILE_OPERATION, workerTestStub, handle, requestID);
//call hereIsGridProcessResult message
req_314_Util.executionResult(broker, States.REMOTE_STATE, workerTestStub, false, peerTestStub, testJob);
//call workerIsReady
req_313_Util.callWorkerIsReadyWithoutWorkers(broker, workerTestStub);
}
/**
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* + Init Block:
* # Condition: mem = 256
* # IOEntry:
* * Command: PUT
* * Source File: file.txt
* * Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Call workerIsReady message;
* Verify if the following info message was logged:
* o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
* Call outgoingTransferCompleted message;
* Verify if the following debug message was logged:
* o File transfer finished: file.txt, replica: X Where X is the Grid Process Handle.
* Call hereIsGridProcessResult message;
* Verify if the Worker receveid a getFiles message;
* Call fileTransferRequestReceived message;
* Call WorkerIsReady? message;
* Verify if the following warn message was logged:
* o Invalid operation. The execution is on the state: Final
*/
@ReqTest(test="AT-313.8", reqs="REQ313")
@Test public void test_at_313_8_WorkerReadyMessageOnWorkerReadyToExecutionDoingDownload() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
IOEntry entry = new IOEntry("PUT", BROKER_TEST_DIR + "file.txt", "Class.class");
TestJob testJob = req_304_Util.addJob(true, 1, broker, "echo Hello World", "Test Job", "mem = 256", entry, peers);
req_304_Util.addJob(true, 2, broker, "echo Hello World 2", "Test Job 2", peers);
//try to receive worker
List<TestStub> workerTestStubs = new LinkedList<TestStub>();
Map<String, String> attributes = new HashMap<String, String>();
attributes.put(OurGridSpecificationConstants.ATT_MEM, "mem = 256");
attributes.put(OurGridSpecificationConstants.ATT_SERVERNAME, "xmpp.ourgrid.org");
attributes.put(OurGridSpecificationConstants.ATT_USERNAME, "username");
WorkerSpecification workerSpec = new WorkerSpecification(attributes);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call workerIsReady
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, null);
//Call outgoingTransferCompleted message
OutgoingTransferHandle handle = req_321_Util.getOutgoingTransferHandle(testJob, "Class.class");
req_321_Util.testOutgoingTransferCompleted(broker, States.INIT_STATE, Operations.SEND_FILE_OPERATION, workerTestStub, handle, requestID);
//call hereIsGridProcessResult message
req_314_Util.executionResult(broker, States.REMOTE_STATE, workerTestStub, false, peerTestStub, testJob);
//call fileTransferRequestReceived message
req_324_Util.transferRequestReceived(broker, workerTestStub, BROKER_TEST_DIR + "file.txt", true);
//call workerIsReady
req_313_Util.callWorkerIsReadyWithoutWorkers(broker, workerTestStub);
}
/**
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
o Label: Test Job
o Task Spec:
+ Remote Execute: echo Hello World;
+ Init Block:
# Condition: mem = 256
# IOEntry:
* Command: PUT
* Source File: file.txt
* Destination Class.class
+ Final Block:
# Condition: mem = 256
# IOEntry:
* Command: GET
* Source File: remoteFile1.txt
* Destination localFile1.txt
# IOEntry:
* Command: GET
* Source File: remoteFile2.txt
* Destination localFile2.txt
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
o Public Key: workerPublicKey;
o Request ID: generated by job 1;
o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Call workerIsReady message;
* Verify if the following info message was logged:
o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
* Call outgoingTransferCompleted message;
* Verify if the following debug message was logged:
o File transfer finished: file.txt, replica: X Where X is the Grid Process Handle.
* Call hereIsGridProcessResult message;
* Verify if the Worker receveid a getFiles message;
* Call fileTransferRequestReceived message with fileName remoteFile1.txt;
* Call fileTransferRequestReceived message again with filename remoteFile2.txt;
* Call incomingTransferCompleted message with fileName remoteFile1.txt;
* Call incomingTransferCompleted message again with filename remoteFile2.txt;
* Verify if the following info message was logged:
o Worker dispose X Where X is the worker deployment ID;
* Verify if the local worker provider's disposeWorker message was called;
* Verify if the local worker provider's finishRequest message was called;
* Call WorkerIsReady? message;
* Verify if the following warn message was logged:
o Invalid operation. The execution is on the state: Final
* @throws Exception
*/
@ReqTest(test="AT-313.9", reqs="REQ313")
@Test public void test_at_313_9_WorkerReadyMessage() throws Exception {
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
//call doNotifyRecovery passing a peer with username test
DeploymentID peerDeploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), peerDeploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login with peer
req_311_Util.verifyLogin(broker, "publickey1", false, false, null, peerTestStub);
//add jobs
IOBlock initBlock = new IOBlock();
initBlock.putEntry(new IOEntry("PUT", BROKER_TEST_DIR + "file.txt", "Class.class"));
IOBlock finalBlock = new IOBlock();
finalBlock.putEntry(new IOEntry("GET", "remoteFile1.txt", "localFile1.txt"));
finalBlock.putEntry(new IOEntry("GET", "remoteFile2.txt", "localFile2.txt"));
TaskSpecification task = new TaskSpecification(initBlock, "echo Hello World", finalBlock, "echo");
task.setSourceDirPath(BROKER_TEST_DIR);
TestJob testJob = req_304_Util.addJob(true, 1, broker, "Test Job", "mem = 256", task, peers);
req_304_Util.addJob(true, 2, broker, "echo Hello World 2", "Test Job 2", peers);
//try to receive worker
List<TestStub> workerTestStubs = new LinkedList<TestStub>();
Map<String, String> attributes = new HashMap<String, String>();
attributes.put(OurGridSpecificationConstants.ATT_MEM, "mem = 256");
attributes.put(OurGridSpecificationConstants.ATT_SERVERNAME, "xmpp.ourgrid.org");
attributes.put(OurGridSpecificationConstants.ATT_USERNAME, "username");
WorkerSpecification workerSpec = new WorkerSpecification(attributes);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call workerIsReady
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, null);
//Call outgoingTransferCompleted message
OutgoingTransferHandle handle = req_321_Util.getOutgoingTransferHandle(testJob, "Class.class");
req_321_Util.testOutgoingTransferCompleted(broker, States.INIT_STATE, Operations.SEND_FILE_OPERATION, workerTestStub, handle, requestID);
//call hereIsGridProcessResult
String[] fileNames = new String[2];
fileNames[0] = "remoteFile1.txt";
fileNames[1] = "remoteFile2.txt";
req_314_Util.executionResult(broker, States.REMOTE_STATE, workerTestStub, true, fileNames);
//Call fileTransferRequestReceived message again with filename remoteFile1.txt
req_324_Util.transferRequestReceived(broker, States.FINAL_STATE, "remoteFile1.txt", workerTestStub, testJob);
//Call fileTransferRequestReceived message again with filename remoteFile2.txt
req_324_Util.transferRequestReceived(broker, States.FINAL_STATE, "remoteFile2.txt", workerTestStub, testJob);
//call incomingTransferCompleted message with fileName remoteFile1.txt;
req_325_Util.testIncomingTransferCompleted(broker, States.FINAL_STATE, true, "remoteFile1.txt", false,
(LocalWorkerProvider)peerTestStub.getObject(), workerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call incomingTransferCompleted message with fileName remoteFile2.txt;
req_325_Util.testIncomingTransferCompleted(broker, States.FINAL_STATE, true, "remoteFile2.txt", true,
(LocalWorkerProvider)peerTestStub.getObject(), workerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call workerIsReady
req_313_Util.callWorkerIsReadyWithoutWorkers(broker, workerTestStub);
}
/**
* This test contains the following steps:
*
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* + Init Block:
* # Condition: mem = 256
* # IOEntry:
* * Command: PUT
* * Source File: file.txt
* * Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Verify if the following info message was logged:
* o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
*/
@ReqTest(test="AT-313.1", reqs="REQ313")
@Category(JDLCompliantTest.class) @Test public void test_at_313_1_1_WorkerReadyToReceiveFiles() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
TestJob testJob = req_304_Util.addJob( true, 1, broker, JDLUtils.JAVA_JOB, peers );
req_304_Util.addJob( true, 2, broker, JDLUtils.ECHO_JOB, peers );
//try to receive worker
List<TestStub> workerTestStubs = new LinkedList<TestStub>();
WorkerSpecification workerSpec = SDFClassAdsSemanticAnalyzer.compile(ClassAdsUtils.SIMPLE_MACHINE_WITH_MEMORY).get(0);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//verify messages
String[] localFileNames = new String[1];
localFileNames[0] = testJob.getJobSpec().getTaskSpecs().get(0).getInitBlock().getEntry("").get(0).getSourceFile();
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, false, null, 1, 1,
null, null, localFileNames);
}
/**
*This test contains the following steps:
*
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Verify if the Worker receveid a RemoteExecute? message;
*/
@ReqTest(test="AT-313.2", reqs="REQ313")
@Category(JDLCompliantTest.class) @Test public void test_at_313_2_1_WorkerReadyToExecuteRemoteCommands() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
TestJob testJob = req_304_Util.addJob(true, 1, broker, JDLUtils.ECHO_JOB, peers);
req_304_Util.addJob(true, 2, broker, JDLUtils.ECHO_JOB, peers);
//try to receive worker
List<TestStub> workerTestStubs = new ArrayList<TestStub>();
WorkerSpecification workerSpec = SDFClassAdsSemanticAnalyzer.compile(ClassAdsUtils.SIMPLE_MACHINE_WITH_MEMORY).get(0);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.EXECUTE_COMMAND_OPERATION, false, null, 1, 1,
requestID, null, null);
}
/**
* * Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
o Label: Test Job
o Task Spec:
+ Remote Execute: echo Hello World;
+ Init Block:
# Condition: mem = 256
# IOEntry:
* Command: PUT
* Source File: file.txt
* Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote
* attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
o Public Key: workerPublicKey;
o Request ID: generated by job 1;
o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the
Worker;
* Verify if the worker's startWork message was called;
* Verify if the following info message was logged:
o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
* Call WorkerIsReady? message;
* Verify if the following warn message was logged:
o Invalid operation. The execution is on the state: Init
* @throws Exception
*/
@ReqTest(test="AT-313.4", reqs="REQ313")
@Category(JDLCompliantTest.class) @Test public void test_at_313_4_1_WorkerReadyToExecuteOnInitialState() throws Exception {
//start broker
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
//call doNotifyRecovery passing a peer with username test
DeploymentID deploymentID1 = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID1, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login with peer
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
TestJob testJob = req_304_Util.addJob( true, 1, broker, JDLUtils.JAVA_JOB, peers );
req_304_Util.addJob( true, 2, broker, JDLUtils.ECHO_JOB, peers );
//try to receive worker
List<TestStub> workerTestStubs = new ArrayList<TestStub>();
WorkerSpecification workerSpec = SDFClassAdsSemanticAnalyzer.compile(ClassAdsUtils.SIMPLE_MACHINE_WITH_MEMORY).get(0);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call WorkerIsReady
String[] localFileNames = new String[1];
localFileNames[0] = testJob.getJobSpec().getTaskSpecs().get(0).getInitBlock().getEntry("").get(0).getSourceFile();
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, false, null, 1, 1,
null, null, localFileNames);
//call WorkerIsReady
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, true,
States.INIT_STATE, 1, 1, null, null, null);
}
/**
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* + Init Block:
* # Condition: mem = 256
* # IOEntry:
* * Command: PUT
* * Source File: file.txt
* * Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Verify if the following info message was logged:
* o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
* Call outgoingTransferCompleted message;
* Verify if the following debug message was logged:
* o File transfer finished: file.txt, replica: X Where X is the Grid Process Handle.
* Call WorkerIsReady? message;
* Verify if the following warn message was logged:
* o Invalid operation. The execution is on the state: Remote
*/
@ReqTest(test="AT-313.6", reqs="REQ313")
@Category(JDLCompliantTest.class) @Test public void test_at_313_6_1_WorkerReadyToExecuteOnInitStatWithFileInformation() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
TestJob testJob = req_304_Util.addJob( true, 1, broker, JDLUtils.JAVA_JOB, peers );
req_304_Util.addJob( true, 2, broker, JDLUtils.ECHO_JOB, peers );
//try to receive worker
List<TestStub> workerTestStubs = new ArrayList<TestStub>();
WorkerSpecification workerSpec = SDFClassAdsSemanticAnalyzer.compile(ClassAdsUtils.SIMPLE_MACHINE_WITH_MEMORY).get(0);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call WorkerIsReady
String[] localFileNames = new String[1];
localFileNames[0] = testJob.getJobSpec().getTaskSpecs().get(0).getInitBlock().getEntry("").get(0).getSourceFile();
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, false, null, 1, 1,
null, null, localFileNames);
//Call outgoingTransferCompleted message
OutgoingTransferHandle handle = req_321_Util.getOutgoingTransferHandle(testJob, "Class.class");
req_321_Util.testOutgoingTransferCompleted(broker, States.INIT_STATE, Operations.SEND_FILE_OPERATION, workerTestStub, localFileNames[0], 1, 1, handle, requestID, false);
String[] localFiles = {"Class.class"};
//call WorkerIsReady
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, true, States.REMOTE_STATE,
1, 1, null, null, localFiles);//TODO BrokerTestDir? Does it really transfer the file in the test?
}
/**
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* + Init Block:
* # Condition: mem = 256
* # IOEntry:
* * Command: PUT
* * Source File: file.txt
* * Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Call workerIsReady message;
* Verify if the following info message was logged:
* o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
* Call outgoingTransferCompleted message;
* Verify if the following debug message was logged:
* o File transfer finished: file.txt, replica: X Where X is the Grid Process Handle.
* Call hereIsGridProcessResult message;
* Verify if the Worker receveid a getFiles message;
* Call WorkerIsReady? message;
* Verify if the following warn message was logged:
* o Invalid operation. The execution is on the state: Final
*/
@ReqTest(test="AT-313.7", reqs="REQ313")
@Category(JDLCompliantTest.class) @Test public void test_at_313_7_1_WorkerReadyMessageOnFinalState() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
TestJob testJob = req_304_Util.addJob( true, 1, broker, JDLUtils.JAVA_JOB, peers );
req_304_Util.addJob( true, 2, broker, JDLUtils.ECHO_JOB, peers );
//try to receive worker
List<TestStub> workerTestStubs = new LinkedList<TestStub>();
WorkerSpecification workerSpec = SDFClassAdsSemanticAnalyzer.compile(ClassAdsUtils.SIMPLE_MACHINE_WITH_MEMORY).get(0);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call workerIsReady
String[] localFileNames = new String[1];
localFileNames[0] = testJob.getJobSpec().getTaskSpecs().get(0).getInitBlock().getEntry("").get(0).getSourceFile();
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, false, null, 1, 1,
null, null, localFileNames);
//Call outgoingTransferCompleted message
OutgoingTransferHandle handle = req_321_Util.getOutgoingTransferHandle(testJob, "Class.class");
req_321_Util.testOutgoingTransferCompleted(broker, States.INIT_STATE, Operations.SEND_FILE_OPERATION, workerTestStub, localFileNames[0], 1, 1, handle, requestID, false);
//call hereIsGridProcessResult message
req_314_Util.executionResult(broker, States.REMOTE_STATE, workerTestStub, false, peerTestStub, testJob);
//call workerIsReady
req_313_Util.callWorkerIsReadyWithoutWorkers(broker, workerTestStub);
}
/**
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
* o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
* o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
* o Label: Test Job
* o Task Spec:
* + Remote Execute: echo Hello World;
* + Init Block:
* # Condition: mem = 256
* # IOEntry:
* * Command: PUT
* * Source File: file.txt
* * Destination Class.class
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
* o Public Key: workerPublicKey;
* o Request ID: generated by job 1;
* o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
* o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Call workerIsReady message;
* Verify if the following info message was logged:
* o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
* Call outgoingTransferCompleted message;
* Verify if the following debug message was logged:
* o File transfer finished: file.txt, replica: X Where X is the Grid Process Handle.
* Call hereIsGridProcessResult message;
* Verify if the Worker receveid a getFiles message;
* Call fileTransferRequestReceived message;
* Call WorkerIsReady? message;
* Verify if the following warn message was logged:
* o Invalid operation. The execution is on the state: Final
*/
@ReqTest(test="AT-313.8", reqs="REQ313")
@Category(JDLCompliantTest.class) @Test public void test_at_313_8_1_WorkerReadyMessageOnWorkerReadyToExecutionDoingDownload() throws Exception {
//Creates and starts
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
DeploymentID deploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
//notify and verify if the debug message was logged
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), deploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login
req_311_Util.verifyLogin(broker, "publicKey1", false, false, null, peerTestStub);
//add jobs
TestJob testJob = req_304_Util.addJob( true, 1, broker, JDLUtils.JAVA_JOB, peers );
req_304_Util.addJob( true, 2, broker, JDLUtils.ECHO_JOB, peers );
//try to receive worker
List<TestStub> workerTestStubs = new LinkedList<TestStub>();
WorkerSpecification workerSpec = SDFClassAdsSemanticAnalyzer.compile(ClassAdsUtils.SIMPLE_MACHINE_WITH_MEMORY).get(0);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call workerIsReady
String[] localFileNames = new String[1];
localFileNames[0] = testJob.getJobSpec().getTaskSpecs().get(0).getInitBlock().getEntry("").get(0).getSourceFile();
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, false, null, 1, 1,
null, null, localFileNames);
//Call outgoingTransferCompleted message
OutgoingTransferHandle handle = req_321_Util.getOutgoingTransferHandle(testJob, "Class.class");
req_321_Util.testOutgoingTransferCompleted(broker, States.INIT_STATE, Operations.SEND_FILE_OPERATION, workerTestStub, localFileNames[0], 1, 1, handle, requestID, false);
//call hereIsGridProcessResult message
req_314_Util.executionResult(broker, States.REMOTE_STATE, workerTestStub, false, peerTestStub, testJob);
//call fileTransferRequestReceived message
req_324_Util.transferRequestReceived(broker, workerTestStub, "Class.class", true);
//call workerIsReady
req_313_Util.callWorkerIsReadyWithoutWorkers(broker, workerTestStub);
}
/**
* Create and start the Broker with the correct public key;
* Call setPeers giving a list containing one peer with the following attributes:
o First peer = username = test and servername = servertest
* Call doNotifyRecovery passing a peer with username = test on the parameter;
* Verify if the following debug message was logged:
o Peer with object id: [X] is UP. Where X is the objectID generated.
* Do login with the public key property set to "publicKey1"in the worker provider.
* Add a job with the attributes:
o Label: Test Job
o Task Spec:
+ Remote Execute: echo Hello World;
+ Init Block:
# Condition: mem = 256
# IOEntry:
* Command: PUT
* Source File: file.txt
* Destination Class.class
+ Final Block:
# Condition: mem = 256
# IOEntry:
* Command: GET
* Source File: remoteFile1.txt
* Destination localFile1.txt
# IOEntry:
* Command: GET
* Source File: remoteFile2.txt
* Destination localFile2.txt
* Verify if the operation result contains a jobID with value 1.
* Add a job with the attributes: label: "Test Job 2" and one Task with remote attribute "echo Hello World 2"
* Verify if the operation result contains a jobID with value 2.
* Call hereIsWorker giving a worker with the attributes:
o Public Key: workerPublicKey;
o Request ID: generated by job 1;
o Worker Spec: an attribute mem = 256;
* Call schedule with the correct public key;
* Verify if the following debug message was logged:
o Executing replica: 1.1.1, Worker: X. Where X is the toString() method of the Worker;
* Verify if the worker's startWork message was called;
* Call workerIsReady message;
* Verify if the following info message was logged:
o Sending file file.txt to X Where X is the worker deployment ID;
* Verify if the Worker receveid a transferRequestReceived message;
* Call outgoingTransferCompleted message;
* Verify if the following debug message was logged:
o File transfer finished: file.txt, replica: X Where X is the Grid Process Handle.
* Call hereIsGridProcessResult message;
* Verify if the Worker receveid a getFiles message;
* Call fileTransferRequestReceived message with fileName remoteFile1.txt;
* Call fileTransferRequestReceived message again with filename remoteFile2.txt;
* Call incomingTransferCompleted message with fileName remoteFile1.txt;
* Call incomingTransferCompleted message again with filename remoteFile2.txt;
* Verify if the following info message was logged:
o Worker dispose X Where X is the worker deployment ID;
* Verify if the local worker provider's disposeWorker message was called;
* Verify if the local worker provider's finishRequest message was called;
* Call WorkerIsReady? message;
* Verify if the following warn message was logged:
o Invalid operation. The execution is on the state: Final
* @throws Exception
*/
@ReqTest(test="AT-313.9", reqs="REQ313")
@Category(JDLCompliantTest.class) @Test public void test_at_313_9_1_WorkerReadyMessage() throws Exception {
BrokerServerModule broker = req_302_Util.startBroker(peerUserAtServer);
//call doNotifyRecovery passing a peer with username test
DeploymentID peerDeploymentID = req_328_Util.createPeerDeploymentID("publicKey1", getPeerSpec());
List<LocalWorkerProvider> peers = new LinkedList<LocalWorkerProvider>();
TestStub peerTestStub = req_327_Util.notifyPeerRecovery(getPeerSpec(), peerDeploymentID, broker);
peers.add((LocalWorkerProvider)peerTestStub.getObject());
//do login with peer
req_311_Util.verifyLogin(broker, "publickey1", false, false, null, peerTestStub);
//add jobs TODO Sabotage check command? Epilogue =
TestJob testJob = req_304_Util.addJob( true, 1, broker, JDLUtils.JAVA_IO_JOB, peers );
req_304_Util.addJob( true, 2, broker, JDLUtils.ECHO_JOB, peers );
//try to receive worker
List<TestStub> workerTestStubs = new LinkedList<TestStub>();
WorkerSpecification workerSpec = SDFClassAdsSemanticAnalyzer.compile(ClassAdsUtils.SIMPLE_MACHINE_WITH_MEMORY).get(0);
TestStub workerTestStub = req_312_Util.receiveWorker(broker, "workerPublicKey", true, true, true, true,
workerSpec, "publicKey1", peerTestStub, testJob);
req_330_Util.notifyWorkerRecovery(broker, workerTestStub.getDeploymentID());
workerTestStubs.add(workerTestStub);
//call scheduler
long requestID = req_329_Util.doSchedule(broker, workerTestStubs, peerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call workerIsReady
String[] localFileNames = new String[1];
localFileNames[0] = testJob.getJobSpec().getTaskSpecs().get(0).getInitBlock().getEntry("").get(0).getSourceFile();
req_313_Util.callWorkerIsReady(broker, workerTestStubs, Operations.SEND_FILE_OPERATION, false, null, 1, 1,
null, null, localFileNames);
//Call outgoingTransferCompleted message
OutgoingTransferHandle handle = req_321_Util.getOutgoingTransferHandle(testJob, "Class.class");
req_321_Util.testOutgoingTransferCompleted(broker, States.INIT_STATE, Operations.SEND_FILE_OPERATION, workerTestStub, localFileNames[0], 1, 1, handle, requestID, false);
//call hereIsGridProcessResult
String[] fileNames = new String[2];
fileNames[0] = "remoteFile1.txt";
fileNames[1] = "remoteFile2.txt";
req_314_Util.executionResult(broker, States.REMOTE_STATE, workerTestStub, true, fileNames);
//Call fileTransferRequestReceived message again with filename remoteFile1.txt
req_324_Util.transferRequestReceived(broker, States.FINAL_STATE, "remoteFile1.txt", workerTestStub, testJob);
//Call fileTransferRequestReceived message again with filename remoteFile2.txt
req_324_Util.transferRequestReceived(broker, States.FINAL_STATE, "remoteFile2.txt", workerTestStub, testJob);
//call incomingTransferCompleted message with fileName remoteFile1.txt;
req_325_Util.testIncomingTransferCompleted(broker, States.FINAL_STATE, true, "remoteFile1.txt", false,
(LocalWorkerProvider)peerTestStub.getObject(), workerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call incomingTransferCompleted message with fileName remoteFile2.txt;
req_325_Util.testIncomingTransferCompleted(broker, States.FINAL_STATE, true, "remoteFile2.txt", true,
(LocalWorkerProvider)peerTestStub.getObject(), workerTestStub, testJob, new GridProcessHandle(1, 1, 1));
//call workerIsReady
req_313_Util.callWorkerIsReadyWithoutWorkers(broker, workerTestStub);
}
}