/**
* Copyright 2015 StreamSets Inc.
*
* Licensed under 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 com.streamsets.datacollector.cluster;
import com.streamsets.datacollector.config.PipelineConfiguration;
import com.streamsets.datacollector.config.RuleDefinitions;
import com.streamsets.datacollector.stagelibrary.StageLibraryTask;
import com.streamsets.datacollector.util.SystemProcessFactory;
import com.streamsets.lib.security.acl.dto.Acl;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.File;
import java.net.URLClassLoader;
import java.util.Map;
import java.util.concurrent.TimeoutException;
public class MockClusterProvider implements ClusterProvider {
private static final Logger LOG = LoggerFactory.getLogger(MockClusterProvider.class);
public boolean killTimesOut = false;
public boolean submitTimesOut = false;
public boolean isRunningTimesOut = false;
public boolean isRunningCommandFails = false;
public boolean isSucceeded = false;
public boolean isRunning = true;
public String appId = null;
@Override
public void killPipeline(SystemProcessFactory systemProcessFactory, File sparkManager, File tempDir, String appId,
PipelineConfiguration pipelineConfiguration)
throws TimeoutException {
LOG.info("killPipeline");
if (killTimesOut) {
throw new TimeoutException();
}
}
@Override
public ClusterPipelineStatus getStatus(SystemProcessFactory systemProcessFactory, File sparkManager, File tempDir, String appId,
PipelineConfiguration pipelineConfiguration) throws TimeoutException {
LOG.info("isRunning");
if (isRunningTimesOut) {
throw new TimeoutException();
}
if (isRunningCommandFails) {
throw new RuntimeException("Mocking failure of isRunning");
}
if (isSucceeded) {
return ClusterPipelineStatus.SUCCEEDED;
}
if (isRunning){
return ClusterPipelineStatus.RUNNING;
} else {
return ClusterPipelineStatus.FAILED;
}
}
@Override
public ApplicationState startPipeline(SystemProcessFactory systemProcessFactory, File sparkManager, File tempDir,
Map<String, String> environment, Map<String, String> sourceInfo,
PipelineConfiguration pipelineConfiguration, StageLibraryTask stageLibrary,
File etcDir, File resourcesDir, File staticWebDir, File bootstrapDir, URLClassLoader apiCL,
URLClassLoader containerCL, long timeout, RuleDefinitions ruleDefinitions, Acl acl)
throws TimeoutException {
LOG.info("startPipeline");
if (submitTimesOut) {
throw new TimeoutException();
}
ApplicationState applicationState = new ApplicationState();
applicationState.setId(appId);
return applicationState;
}
}