/**
* 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.camel.component.salesforce;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.apache.camel.component.salesforce.api.dto.bulk.BatchInfo;
import org.apache.camel.component.salesforce.api.dto.bulk.BatchStateEnum;
import org.apache.camel.component.salesforce.api.dto.bulk.ContentType;
import org.apache.camel.component.salesforce.api.dto.bulk.JobInfo;
import org.apache.camel.component.salesforce.api.dto.bulk.OperationEnum;
import org.apache.camel.component.salesforce.dto.generated.Merchandise__c;
import org.junit.experimental.theories.DataPoints;
import org.junit.experimental.theories.Theory;
public class BulkApiBatchIntegrationTest extends AbstractBulkApiTestBase {
private static final String TEST_REQUEST_XML = "/test-request.xml";
private static final String TEST_REQUEST_CSV = "/test-request.csv";
@DataPoints
public static BatchTest[] getBatches() {
List<BatchTest> result = new ArrayList<BatchTest>();
BatchTest test = new BatchTest();
test.contentType = ContentType.XML;
test.stream = BulkApiBatchIntegrationTest.class.getResourceAsStream(TEST_REQUEST_XML);
result.add(test);
test = new BatchTest();
test.contentType = ContentType.CSV;
test.stream = BulkApiBatchIntegrationTest.class.getResourceAsStream(TEST_REQUEST_CSV);
result.add(test);
// TODO test ZIP_XML and ZIP_CSV
return result.toArray(new BatchTest[result.size()]);
}
@Theory
public void testBatchLifecycle(BatchTest request) throws Exception {
log.info("Testing Batch lifecycle with {} content", request.contentType);
// create an UPSERT test Job for this batch request
JobInfo jobInfo = new JobInfo();
jobInfo.setOperation(OperationEnum.UPSERT);
jobInfo.setContentType(request.contentType);
jobInfo.setObject(Merchandise__c.class.getSimpleName());
jobInfo.setExternalIdFieldName("Name");
jobInfo = createJob(jobInfo);
// test createBatch
Map<String, Object> headers = new HashMap<String, Object>();
headers.put(SalesforceEndpointConfig.JOB_ID, jobInfo.getId());
headers.put(SalesforceEndpointConfig.CONTENT_TYPE, jobInfo.getContentType());
BatchInfo batchInfo = template().requestBodyAndHeaders("direct:createBatch",
request.stream, headers, BatchInfo.class);
assertNotNull("Null batch", batchInfo);
assertNotNull("Null batch id", batchInfo.getId());
// test getAllBatches
@SuppressWarnings("unchecked")
List<BatchInfo> batches = template().requestBody("direct:getAllBatches", jobInfo, List.class);
assertNotNull("Null batches", batches);
assertFalse("Empty batch list", batches.isEmpty());
// test getBatch
batchInfo = batches.get(0);
batchInfo = getBatchInfo(batchInfo);
// test getRequest
InputStream requestStream = template().requestBody("direct:getRequest", batchInfo, InputStream.class);
assertNotNull("Null batch request", requestStream);
// wait for batch to finish
log.info("Waiting for batch to finish...");
while (!batchProcessed(batchInfo)) {
// sleep 5 seconds
Thread.sleep(5000);
// check again
batchInfo = getBatchInfo(batchInfo);
}
log.info("Batch finished with state " + batchInfo.getState());
assertEquals("Batch did not succeed", BatchStateEnum.COMPLETED, batchInfo.getState());
// test getResults
InputStream results = template().requestBody("direct:getResults", batchInfo, InputStream.class);
assertNotNull("Null batch results", results);
// close the test job
template().requestBody("direct:closeJob", jobInfo, JobInfo.class);
}
private static class BatchTest {
public InputStream stream;
public ContentType contentType;
}
}