blob: ac093c4ea261eb1de3ce09874a19125b2fa44556 [file] [log] [blame]
/*
* Copyright 2019 WeBank
*
* 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.webank.wedatasphere.linkis.engine.execute
import com.webank.wedatasphere.linkis.protocol.engine.RequestTask
import com.webank.wedatasphere.linkis.scheduler.executer.{ErrorExecuteResponse, ExecuteRequest, JobExecuteRequest, RunTypeExecuteRequest}
import com.webank.wedatasphere.linkis.scheduler.queue.{Job, JobInfo}
/**
* Created by enjoyyin on 2018/9/25.
*/
abstract class EngineJob extends Job with SenderContainer
class CommonEngineJob extends EngineJob with SyncSenderContainer {
protected var request: RequestTask = _
override def init(): Unit = {}
def setRequestTask(request: RequestTask) = this.request = request
def getRequestTask = request
override def isJobSupportRetry: Boolean = false
override protected def jobToExecuteRequest: ExecuteRequest = {
if (request.getProperties.containsKey("runType") && request.getProperties.containsKey(RequestTask.RESULT_SET_STORE_PATH))
return new ExecuteRequest with JobExecuteRequest with StorePathExecuteRequest with RunTypeExecuteRequest{
override val code: String = request.getCode
override val jobId: String = CommonEngineJob.this.getId
override val storePath: String = request.getProperties.get(RequestTask.RESULT_SET_STORE_PATH).toString
override val runType: String = request.getProperties.get("runType").toString
}
if(request.getProperties.containsKey(RequestTask.RESULT_SET_STORE_PATH)) new ExecuteRequest with JobExecuteRequest with StorePathExecuteRequest {
override val code: String = request.getCode
override val jobId: String = CommonEngineJob.this.getId
override val storePath: String = request.getProperties.get(RequestTask.RESULT_SET_STORE_PATH).toString
} else new ExecuteRequest with JobExecuteRequest {
override val code: String = request.getCode
override val jobId: String = CommonEngineJob.this.getId
}
}
override def getName: String = getId
override def getJobInfo: JobInfo = new JobInfo(getId, null, getState.toString, getProgress, s"StartTime: $createTime, endTime: $endTime.") //TODO
override protected def existsJobDaemon: Boolean = true
override def close(): Unit = kill()
}