當前位置: 首頁>>代碼示例>>Java>>正文


Java TaskExecutionException類代碼示例

本文整理匯總了Java中io.digdag.spi.TaskExecutionException的典型用法代碼示例。如果您正苦於以下問題:Java TaskExecutionException類的具體用法?Java TaskExecutionException怎麽用?Java TaskExecutionException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


TaskExecutionException類屬於io.digdag.spi包,在下文中一共展示了TaskExecutionException類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: processFinish

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
private TaskResult processFinish(int result, Config state) {
    if (result != 0) {
        throw new TaskExecutionException(String.format(
                "retz_run: Job(id=%s) failed. " +
                        "| retz-info: state=%s, reason=%s " +
                        "| log: `digdag log %s %s`",
                state.get(STATE_JOB_ID, String.class),
                state.get(STATE_JOB_STATE, String.class), state.get(STATE_REASON, String.class),
                request.getAttemptId(), request.getTaskName()));
    }

    TaskResult taskResult = TaskResult.empty(request);
    taskResult.getStoreParams()
            .getNestedOrSetEmpty(RetzOperatorConfig.KEY_CONFIG_ROOT)
            .set("last_job_id", state.get(STATE_JOB_ID, String.class));

    return taskResult;
}
 
開發者ID:retz,項目名稱:retz-digdag-plugin,代碼行數:19,代碼來源:RetzRunApiOperator.java

示例2: processSchedule

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
private Job processSchedule(Client webClient, Config state) {
    Job job = createJob();
    Response res;
    try {
        res = webClient.schedule(job);
    } catch (IOException ex) {
        throw new RuntimeException("Failed to schedule Retz job", ex);
    }
    if (!(res instanceof ScheduleResponse)) {
        throw new TaskExecutionException(String.format(
                "Failed to schedule Retz job: %s",
                res.status()));
    }

    Job scheduled = ((ScheduleResponse) res).job();
    LOGGER.info("Job(id={}) scheduled: {}", scheduled.id(), scheduled.state());

    initializeTaskState(scheduled, state);

    return scheduled;
}
 
開發者ID:retz,項目名稱:retz-digdag-plugin,代碼行數:22,代碼來源:RetzRunApiOperator.java

示例3: processGetFile

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
private TaskExecutionException processGetFile(Job job, Client webClient, Config state) {

        switch(job.state()) {
            case QUEUED:
                checkTimeout(job, webClient);
                return nextPolling(state);
            case STARTING:
            case STARTED:
                checkTimeout(job, webClient);
                getWholeFileByState(job, webClient, "stdout", state);
                return nextPolling(state);
            case FINISHED:
            case KILLED:
                getWholeFileByState(job, webClient, "stdout", state);
                if (config.getVerbose()) {
                    LOGGER.info("Job(id={}) finished to get stdout, will get stderr", job.id());
                }
                getWholeFile(job, webClient, "stderr", 0);
                return finishJob(job, state);
            default:
                throw new IllegalStateException("unexpected status: " + job.state());
        }
    }
 
開發者ID:retz,項目名稱:retz-digdag-plugin,代碼行數:24,代碼來源:RetzRunApiOperator.java

示例4: finishJob

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
private TaskExecutionException finishJob(Job job, Config state) {
    String duration = getDuration(job.started(), job.finished());

    LOGGER.info("Job(id={}) finished in {}. status: {}",
            job.id(), duration, job.state());

    state.set(STATE_RESULT_CODE, job.result());
    state.set(STATE_DURATION, duration);
    state.remove(STATE_POLL_ITERATION);
    state.remove(STATE_OFFSET);

    if (job.result() != 0) {
        state.set(STATE_REASON, job.reason());
    }

    return TaskExecutionException.ofNextPolling(0, ConfigElement.copyOf(state));
}
 
開發者ID:retz,項目名稱:retz-digdag-plugin,代碼行數:18,代碼來源:RetzRunApiOperator.java

示例5: getJob

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
private Job getJob(int id, Client webClient) {
    Response res;
    try {
        res = webClient.getJob(id);
    } catch (IOException ex) {
        throw Throwables.propagate(ex);
    }

    if (res instanceof GetJobResponse) {
        GetJobResponse getJobResponse = (GetJobResponse) res;
        if (getJobResponse.job().isPresent()) {
            return getJobResponse.job().get();
        } else {
            throw Throwables.propagate(new JobNotFoundException(id));
        }
    } else {
        throw new TaskExecutionException(String.format(
                "Job(id=%s) getJob received invalid response: %s",
                id, res.status()));
    }
}
 
開發者ID:retz,項目名稱:retz-digdag-plugin,代碼行數:22,代碼來源:RetzRunApiOperator.java

示例6: storeResultsInTaskResult

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
private void storeResultsInTaskResult(JdbcResultSet jdbcResultSet, StoreLastResultsOption option, ImmutableTaskResult.Builder builder)
{
    int columnsCount = jdbcResultSet.getColumnNames().size();
    if (columnsCount > maxStoreLastResultsColumns) {
        throw new TaskExecutionException("The number of result columns exceeded the limit: " + columnsCount + " > " + maxStoreLastResultsColumns);
    }

    Object lastResults;
    switch (option) {
    case ALL:
        lastResults = collectAllResults(jdbcResultSet);
        break;
    case FIRST:
        lastResults = collectFirstResults(jdbcResultSet);
        break;
    default:
        throw new AssertionError("Unexpected StoreLastResultsOption: " + option);
    }

    Config storeParams = request.getConfig().getFactory().create();
    storeParams.getNestedOrSetEmpty(type())
        .set("last_results", lastResults);
    builder.storeParams(storeParams);
}
 
開發者ID:treasure-data,項目名稱:digdag,代碼行數:25,代碼來源:AbstractJdbcJobOperator.java

示例7: collectAllResults

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
private List<Map<String, Object>> collectAllResults(JdbcResultSet jdbcResultSet)
{
    List<String> columnNames = jdbcResultSet.getColumnNames();
    ImmutableList.Builder<Map<String, Object>> lastResults = ImmutableList.builder();

    long rows = 0;
    while (true) {
        List<Object> values = jdbcResultSet.next();
        if (values == null) {
            break;
        }

        rows += 1;
        if (rows > maxStoreLastResultsRows) {
            throw new TaskExecutionException("The number of result rows exceeded the limit: " + rows + " > " + maxStoreLastResultsRows);
        }

        lastResults.add(buildResultsMap(columnNames, values));
    }

    return lastResults.build();
}
 
開發者ID:treasure-data,項目名稱:digdag,代碼行數:23,代碼來源:AbstractJdbcJobOperator.java

示例8: error

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
private RuntimeException error(Request req, boolean uriIsSecret, Response res)
{
    if (HttpStatus.isClientError(res.getStatus())) {
        switch (res.getStatus()) {
            case HttpStatus.REQUEST_TIMEOUT_408:
            case HttpStatus.TOO_MANY_REQUESTS_429:
                // Retry these.
                return new RuntimeException("Failed HTTP request: " + requestStatus(req, res, uriIsSecret));
            default:
                // 4xx: The request is invalid for this resource. Fail hard without retrying.
                return new TaskExecutionException("HTTP 4XX Client Error: " + requestStatus(req, res, uriIsSecret));
        }
    }
    else if (res.getStatus() >= 500 && res.getStatus() < 600) {
        // 5xx: Server Error. This is hopefully ephemeral.
        return ephemeralError("HTTP 5XX Server Error: " + requestStatus(req, res, uriIsSecret));
    }
    else {
        // Unknown status code. Treat as an ephemeral error.
        return ephemeralError("Unexpected HTTP status: " + requestStatus(req, res, uriIsSecret));
    }
}
 
開發者ID:treasure-data,項目名稱:digdag,代碼行數:23,代碼來源:HttpOperatorFactory.java

示例9: client

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
private HttpClient client()
{
    boolean insecure = params.get("insecure", boolean.class, false);

    HttpClient httpClient = new HttpClient(new SslContextFactory(insecure));

    configureProxy(httpClient);

    boolean followRedirects = params.get("follow_redirects", boolean.class, true);

    httpClient.setFollowRedirects(followRedirects);
    httpClient.setMaxRedirects(maxRedirects);

    httpClient.setUserAgentField(new HttpField(
            USER_AGENT, userAgent + ' ' + httpClient.getUserAgentField().getValue()));

    try {
        httpClient.start();
    }
    catch (Exception e) {
        throw new TaskExecutionException(e);
    }
    return httpClient;
}
 
開發者ID:treasure-data,項目名稱:digdag,代碼行數:25,代碼來源:HttpOperatorFactory.java

示例10: fetchRows

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
private List<Config> fetchRows(TDJobOperator job)
{
    return PollingRetryExecutor.pollingRetryExecutor(state, RESULT)
            .retryUnless(TDOperator::isDeterministicClientException)
            .withErrorMessage("Failed to download result of job '%s'", job.getJobId())
            .run(s -> {
                List<String> columnNames = job.getResultColumnNames();
                List<Config> result = job.getResult(ite -> {
                    List<Config> rows = new ArrayList<>();
                    while (ite.hasNext()) {
                        rows.add(row(columnNames, ite.next().asArrayValue()));
                        if (rows.size() > Limits.maxWorkflowTasks()) {
                            TaskLimitExceededException cause = new TaskLimitExceededException("Too many tasks. Limit: " + Limits.maxWorkflowTasks());
                            throw new TaskExecutionException(cause);
                        }
                    }
                    return rows;
                });
                return result;
            });
}
 
開發者ID:treasure-data,項目名稱:digdag,代碼行數:22,代碼來源:TdForEachOperatorFactory.java

示例11: fetchJobResult

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
private boolean fetchJobResult(TDJobOperator job)
{
    Optional<ArrayValue> firstRow = pollingRetryExecutor(state, RESULT)
            .retryUnless(TDOperator::isDeterministicClientException)
            .withErrorMessage("Failed to download result of job '%s'", job.getJobId())
            .run(s -> job.getResult(
                    ite -> ite.hasNext()
                            ? Optional.of(ite.next())
                            : Optional.absent()));

    // There must be at least one row in the result for the wait condition to be fulfilled.
    if (!firstRow.isPresent()) {
        return false;
    }

    ArrayValue row = firstRow.get();
    if (row.size() < 1) {
        throw new TaskExecutionException("Got empty row in result of query");
    }

    Value firstCol = row.get(0);
    return isTruthy(firstCol);
}
 
開發者ID:treasure-data,項目名稱:digdag,代碼行數:24,代碼來源:TdWaitOperatorFactory.java

示例12: respondSlowlyThanTimeout

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
@Test
public void respondSlowlyThanTimeout() throws IOException {
	stubFor(get("/api/foobar")
			.willReturn(aResponse()
					.withStatus(200)
					.withFixedDelay(5000)));

	Operator op = factory.newOperator(newContext(
			tempPath,
			newTaskRequest().withConfig(config)));
	try {
		op.run();
		fail("should be thrown Exception.");
	} catch (TaskExecutionException ignore) {
	}
}
 
開發者ID:treasure-data,項目名稱:digdag,代碼行數:17,代碼來源:HttpOperatorFactoryTest.java

示例13: respondQuicklyThanTimeout

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
@Test
public void respondQuicklyThanTimeout() throws IOException {
	stubFor(get("/api/foobar")
			.willReturn(aResponse()
					.withStatus(200)
					.withFixedDelay(1000)));

	Operator op = factory.newOperator(newContext(
			tempPath,
			newTaskRequest().withConfig(config)));
	try {
		op.run();
	} catch (TaskExecutionException ignore) {
		fail("should be success.");
	}
}
 
開發者ID:treasure-data,項目名稱:digdag,代碼行數:17,代碼來源:HttpOperatorFactoryTest.java

示例14: testVersionId

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
@Test
public void testVersionId()
        throws Exception
{
    Config config = newConfig();
    config.set("_command", BUCKET + "/" + KEY);
    config.set("version_id", VERSION_ID);
    when(taskRequest.getConfig()).thenReturn(config);

    when(s3Secrets.getSecretOptional("region")).thenReturn(Optional.of(REGION));

    when(s3Client.getObjectMetadata(objectMetadataRequestCaptor.capture())).thenThrow(NOT_FOUND_EXCEPTION);

    Operator operator = factory.newOperator(newContext(projectPath, taskRequest));

    try {
        operator.run();
        fail();
    }
    catch (TaskExecutionException ignore) {
    }

    GetObjectMetadataRequest objectMetadataRequest = objectMetadataRequestCaptor.getValue();

    assertThat(objectMetadataRequest.getVersionId(), is(VERSION_ID));
}
 
開發者ID:treasure-data,項目名稱:digdag,代碼行數:27,代碼來源:S3WaitOperatorFactoryTest.java

示例15: testSSEC

import io.digdag.spi.TaskExecutionException; //導入依賴的package包/類
@Test
public void testSSEC()
        throws Exception
{
    Config config = newConfig();
    config.set("_command", BUCKET + "/" + KEY);
    when(taskRequest.getConfig()).thenReturn(config);

    when(s3Secrets.getSecretOptional("sse_c_key")).thenReturn(Optional.of(SSE_C_KEY));

    when(s3Client.getObjectMetadata(objectMetadataRequestCaptor.capture())).thenThrow(NOT_FOUND_EXCEPTION);

    Operator operator = factory.newOperator(newContext(projectPath, taskRequest));

    try {
        operator.run();
        fail();
    }
    catch (TaskExecutionException ignore) {
    }

    GetObjectMetadataRequest objectMetadataRequest = objectMetadataRequestCaptor.getValue();
    assertThat(objectMetadataRequest.getSSECustomerKey().getKey(), is(SSE_C_KEY));
    assertThat(objectMetadataRequest.getSSECustomerKey().getAlgorithm(), is("AES256"));
    assertThat(objectMetadataRequest.getSSECustomerKey().getMd5(), is(nullValue()));
}
 
開發者ID:treasure-data,項目名稱:digdag,代碼行數:27,代碼來源:S3WaitOperatorFactoryTest.java


注:本文中的io.digdag.spi.TaskExecutionException類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。