/* * © Copyright IBM Corp. 2014 * * Licensed 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 com.ibm.sbt.services.client.connections.activities; import java.util.Arrays; import org.junit.Assert; import org.junit.Test; import com.ibm.sbt.services.client.ClientServicesException; import com.ibm.sbt.services.client.base.datahandlers.EntityList; /** * @author mwallace * */ public class ActivityMoveEntryPerformanceTest extends BaseActivityServiceTest { @Test @org.junit.Ignore("Issue with Mime Depdency") public void testMoveEntry() throws ClientServicesException { long start = System.currentTimeMillis(); Activity activitySrc = createActivity("ActivityMoveEntryPerformanceTest Source"); Activity activityDst = createActivity("ActivityMoveEntryPerformanceTest Destination"); byte[] bytes = new byte[Integer.valueOf(1024)]; Arrays.fill(bytes, (byte)0); ActivityNode nodeMove = new ActivityNode(); nodeMove.setActivityUuid(activitySrc.getActivityUuid()); nodeMove.setTitle("NodeToMove"); nodeMove.setType(ActivityNode.TYPE_ENTRY); for (int j=0; j<10; j++) { TextField textField = new TextField(); textField.setName("test_text"+j); textField.setPosition(1000); textField.setSummary("Test_Text_Field"); nodeMove.addField(textField); } for (int j=0; j<10; j++) { FileField fileField = new FileField(); fileField.setName("test_file"+j); fileField.setHidden(true); fileField.setPosition(2000); nodeMove.addField(fileField); nodeMove.addAttachment(new ActivityAttachment("test_file"+j, new String(bytes), "text/plain")); } activityService.createActivityNode(nodeMove); for (int i=0; i<300; i++) { try { ActivityNode activityNode = new ActivityNode(); activityNode.setActivityUuid(activityDst.getActivityUuid()); activityNode.setTitle("DestinationNode" + "-" + i); activityNode.setType(ActivityNode.TYPE_ENTRY); for (int j=0; j<5; j++) { TextField textField = new TextField(); textField.setName("test_text"+j); textField.setPosition(1000); textField.setSummary("Test_Text_Field"); activityNode.addField(textField); } activityNode = activityService.createActivityNode(activityNode); System.out.print("."); } catch (Exception e) { } } long duration = System.currentTimeMillis() - start; System.out.println("Created Activities took "+duration+"(ms)"); // move node from source to destination start = System.currentTimeMillis(); activityService.moveNode(nodeMove.getActivityNodeUuid(), activityDst.getActivityUuid()); duration = System.currentTimeMillis() - start; System.out.println(activityService.getEndpoint().getUrl()+" Moving node:"+nodeMove.getActivityNodeUuid()+" to activity:"+activityDst.getActivityUuid()+" took "+duration+"(ms)"); EntityList<ActivityNode> descendants = activityDst.getDescendants(); Assert.assertEquals("Invalid activity node uuid", descendants.get(0).getActivityNodeUuid(), nodeMove.getActivityNodeUuid()); } }