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


Java AnalysisJob類代碼示例

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


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

示例1: testScenario

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
public void testScenario() throws Throwable {
    final CsvDatastore datastore =
            new CsvDatastore("my database", "../core/src/test/resources/example-name-lengths.csv");
    final ClasspathScanDescriptorProvider descriptorProvider =
            new ClasspathScanDescriptorProvider().scanPackage("org.datacleaner", true);
    final DataCleanerConfiguration configuration = new DataCleanerConfigurationImpl().withDatastores(datastore)
            .withEnvironment(new DataCleanerEnvironmentImpl().withDescriptorProvider(descriptorProvider));
    final AnalysisJob job = new JaxbJobReader(configuration)
            .read(new FileInputStream("src/test/resources/example-job-components-without-inputcolumns.xml"));

    final AnalysisRunner runner = new AnalysisRunnerImpl(configuration);
    final AnalysisResultFuture resultFuture = runner.run(job);

    if (!resultFuture.isSuccessful()) {
        throw resultFuture.getErrors().get(0);
    }

    final InputColumn<?>[] input = job.getAnalyzerJobs().iterator().next().getInput();
    assertEquals(4, input.length);

    final StringAnalyzerResult result = (StringAnalyzerResult) resultFuture.getResults().get(0);
    for (int i = 0; i < input.length; i++) {
        assertEquals(5, result.getRowCount(input[i]));
    }
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:26,代碼來源:ComponentsWithoutInputColumnsTest.java

示例2: getComponentByKey

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
private ComponentJob getComponentByKey(final AnalysisJob job, final String queriedKey) {
    final List<ComponentJob> componentJobs = CollectionUtils.concat(false, job.getTransformerJobs(),
            job.getTransformerJobs(), job.getAnalyzerJobs());
    for (final ComponentJob componentJob : componentJobs) {
        final String componentKey = getComponentKey(componentJob);
        if (queriedKey.equals(componentKey)) {
            return componentJob;
        }

        final OutputDataStreamJob[] outputDataStreamJobs = componentJob.getOutputDataStreamJobs();
        for (final OutputDataStreamJob outputDataStreamJob : outputDataStreamJobs) {
            final AnalysisJob childJob = outputDataStreamJob.getJob();
            if (childJob != null) {
                final ComponentJob result = getComponentByKey(childJob, queriedKey);
                if (result != null) {
                    return result;
                }
            }
        }
    }

    return null;
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:24,代碼來源:SparkJobContext.java

示例3: testSingleResultElement

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
@Test
public void testSingleResultElement() throws IOException {
    final Datastore datastore = TestHelper.createSampleDatabaseDatastore("orderdb");
    final SimpleDescriptorProvider descriptorProvider = new SimpleDescriptorProvider();
    descriptorProvider.addRendererBeanDescriptor(Descriptors.ofRenderer(ListResultHtmlRenderer.class));

    final DataCleanerEnvironment environment =
            new DataCleanerEnvironmentImpl().withDescriptorProvider(descriptorProvider);
    final DataCleanerConfigurationImpl configuration =
            new DataCleanerConfigurationImpl().withDatastores(datastore).withEnvironment(environment);
    final AnalysisJob job;
    try (AnalysisJobBuilder jobBuilder = new AnalysisJobBuilder(configuration)) {
        jobBuilder.setDatastore(datastore);
        jobBuilder.addSourceColumns("customers.customername");

        jobBuilder.addAnalyzer(MockAnalyzer.class).addInputColumns(jobBuilder.getSourceColumns());

        job = jobBuilder.toAnalysisJob();
    }

    final AnalysisResult analysisResult = new AnalysisRunnerImpl(configuration).run(job);

    writeAndCompareWithBenchmark(analysisResult, configuration);
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:25,代碼來源:HtmlAnalysisResultWriterTest.java

示例4: testResultPathNameNoVariableSpecified

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
@Test
public void testResultPathNameNoVariableSpecified() throws Exception {
    final SparkConf sparkConf = new SparkConf().setMaster("local").setAppName("DCTest - " + name.getMethodName());
    try (JavaSparkContext sparkContext = new JavaSparkContext(sparkConf)) {

        final SparkJobContext sparkJobContext = new SparkJobContext(URI.create("src/test/resources/conf_local.xml"),
                URI.create("src/test/resources/vanilla-job.analysis.xml"), null, sparkContext);
        final AnalysisJob job = sparkJobContext.getAnalysisJob();
        assertNotNull(job);
        assertNull(sparkJobContext.getResultPath());
        final String analysisJobName = sparkJobContext.getJobName();
        assertEquals("vanilla-job", analysisJobName);
        final Resource resultResource = ResultFilePathUtils.getResultResource(sparkContext, sparkJobContext);
        final int lastIndexOfDash = resultResource.getQualifiedPath().lastIndexOf("-");
        assertTrue(resultResource.getQualifiedPath().contains(analysisJobName));
        assertTrue(resultResource.getQualifiedPath().substring(0, lastIndexOfDash)
                .endsWith("datacleaner" + File.separator + "results" + File.separator + "vanilla-job"));
    }
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:20,代碼來源:JobResultPathTest.java

示例5: performResultAssertions

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
private void performResultAssertions(final AnalysisJob job, final AnalysisResult result) {
    assertEquals(1, result.getResults().size());

    Collection<ComponentJob> componentJobs = result.getResultMap().keySet();
    componentJobs = CollectionUtils2.sorted(componentJobs, ObjectComparator.getComparator());

    assertEquals("[ImmutableAnalyzerJob[name=date gap job,analyzer=Date gap analyzer]]", componentJobs.toString());

    // using the original component jobs not only asserts that these exist
    // in the result, but also that the their deserialized clones are equal
    // (otherwise the results cannot be retrieved from the result map).
    final AnalyzerJob analyzerJob = job.getAnalyzerJobs().iterator().next();

    final AnalyzerResult analyzerResult = result.getResult(analyzerJob);
    assertNotNull(analyzerResult);
    assertEquals("DateGapAnalyzerResult[gaps={121=[], 128=[], 141=[], 181=[], 363=[]}]", analyzerResult.toString());
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:18,代碼來源:AnalyzeDateGapsCompareSchemasAndSerializeResultsTest.java

示例6: getAnalysisJob

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
@Provides
public AnalysisJob getAnalysisJob(@Nullable final AnalysisJobBuilder builder) {
    if (builder == null) {
        return null;
    }
    return builder.toAnalysisJob(false);
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:8,代碼來源:DCModuleImpl.java

示例7: getInputColumnConversion

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
@Override
protected Map<InputColumn<?>, InputColumn<?>> getInputColumnConversion(final AnalysisJob wrappedAnalysisJob) {
    final Map<InputColumn<?>, InputColumn<?>> map = new HashMap<>();
    final Iterator<InputColumn<?>> sourceColumns = wrappedAnalysisJob.getSourceColumns().iterator();
    int i = 0;
    while (i < input.length && sourceColumns.hasNext()) {
        final InputColumn<?> next = sourceColumns.next();
        map.put(input[i], next);
        i++;
    }
    return map;
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:13,代碼來源:AbstractWrappedAnalysisJobTransformerTest.java

示例8: testWrappedExecution

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
public void testWrappedExecution() throws Throwable {
    final AnalysisJob job;
    try (AnalysisJobBuilder builder = new AnalysisJobBuilder(_configuration)) {
        builder.setDatastore("actual_input");
        builder.addSourceColumns("table.name");
        builder.addTransformer(MockWrappedAnalysisJobTransformer.class)
                .addInputColumn(builder.getSourceColumnByName("name"));
        builder.addAnalyzer(MockAnalyzer.class).addInputColumns(builder.getAvailableInputColumns(Object.class));

        job = builder.toAnalysisJob();
    }

    final AnalysisResultFuture resultFuture = new AnalysisRunnerImpl(_configuration).run(job);
    resultFuture.await();

    if (resultFuture.isErrornous()) {
        throw resultFuture.getErrors().get(0);
    }

    final List<AnalyzerResult> results = resultFuture.getResults();
    assertEquals(1, results.size());

    @SuppressWarnings("unchecked") final ListResult<InputRow> analyzerResult =
            (ListResult<InputRow>) results.get(0);

    final List<InputRow> values = analyzerResult.getValues();
    assertEquals(4, values.size());

    assertEquals("TransformedInputRow[values={"
            + "TransformedInputColumn[id=trans-0001-0002,name=mock output]=mocked: Tomasz},"
            + "delegate=MetaModelInputRow[Row[values=[Tomasz]]]]", values.get(0).toString());
    assertEquals("TransformedInputRow[values={"
            + "TransformedInputColumn[id=trans-0001-0002,name=mock output]=mocked: Kasper},"
            + "delegate=MetaModelInputRow[Row[values=[Kasper]]]]", values.get(1).toString());
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:36,代碼來源:AbstractWrappedAnalysisJobTransformerTest.java

示例9: testSingleRecordOutputScenario

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
public void testSingleRecordOutputScenario() throws Exception {
    final TransformerComponentBuilder<MockTransformer> tr1 = ajb.addTransformer(MockTransformer.class);
    tr1.addInputColumn(ajb.getSourceColumnByName("name"));

    final TransformerComponentBuilder<MockTransformer> tr2 = ajb.addTransformer(MockTransformer.class);
    tr2.addInputColumn(tr1.getOutputColumns().get(0));

    final AnalyzerComponentBuilder<MockAnalyzer> analyzer = ajb.addAnalyzer(MockAnalyzer.class);
    analyzer.addInputColumns(sourceColumns);

    final AnalysisJob job = ajb.toAnalysisJob(true);

    final Configuration configuration = new Configuration();
    configuration.includeAnalyzers = false;

    final ConsumeRowHandler handler = new ConsumeRowHandler(job, _configuration, configuration);

    final List<InputRow> result;

    final MockInputRow inputRow =
            new MockInputRow().put(nameColumn, "Kasper").put(ageColumn, null).put(countryColumn, null);
    result = handler.consumeRow(inputRow).getRows();

    assertEquals(1, result.size());
    final InputRow outputRow = result.get(0);
    assertEquals("TransformedInputRow[values={"
            + "TransformedInputColumn[id=trans-0001-0002,name=mock output]=mocked: Kasper, "
            + "TransformedInputColumn[id=trans-0003-0004,name=mock output]=mocked: mocked: Kasper}," + "delegate="
            + inputRow.toString() + "]", outputRow.toString());

    final List<InputColumn<?>> outputColumns = outputRow.getInputColumns();
    assertEquals(5, outputColumns.size());

    assertEquals("mocked: Kasper", outputRow.getValue(outputColumns.get(3)).toString());
    assertEquals("mocked: mocked: Kasper", outputRow.getValue(outputColumns.get(4)).toString());
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:37,代碼來源:ConsumeRowHandlerTest.java

示例10: runAnalysisJob

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
private AnalysisResultFuture runAnalysisJob(final String appName, final URI analysisJobXmlPath,
        final String expectedAnalysisJobName, final boolean useMinPartitions,
        final SparkJobLifeCycleListener sparkJobLifeCycleListener) throws Exception {
    final AnalysisResultFuture result;
    final SparkConf sparkConf = new SparkConf().setMaster("local").setAppName(appName);
    try (JavaSparkContext sparkContext = new JavaSparkContext(sparkConf)) {
        final SparkJobContext sparkJobContext =
                new SparkJobContext(URI.create("src/test/resources/conf_local.xml"), analysisJobXmlPath, null,
                        sparkContext);
        if (sparkJobLifeCycleListener != null) {
            sparkJobContext.addSparkJobLifeCycleListener(sparkJobLifeCycleListener);
        }
        final AnalysisJob job = sparkJobContext.getAnalysisJob();
        assertNotNull(job);
        assertEquals(expectedAnalysisJobName, sparkJobContext.getJobName());

        final SparkAnalysisRunner sparkAnalysisRunner = new SparkAnalysisRunner(sparkContext, sparkJobContext,
                useMinPartitions ? MIN_PARTITIONS_MULTIPLE : null);

        result = sparkAnalysisRunner.run(job);
    }

    if (result.isErrornous()) {
        throw (Exception) result.getErrors().get(0);
    }

    return result;
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:29,代碼來源:SparkAnalysisRunnerTest.java

示例11: onUnexpectedError

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
public void onUnexpectedError(final AnalysisJob job, Throwable throwable) {
    throwable = ErrorUtils.unwrapForPresentation(throwable);
    if (throwable instanceof AnalysisJobCancellation) {
        _progressInformationPanel.onCancelled();
        _cancelButton.setEnabled(false);
        return;
    } else if (throwable instanceof PreviousErrorsExistException) {
        // do nothing
        return;
    }
    _progressInformationPanel.addUserLog("An error occurred in the analysis job!", throwable, true);
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:13,代碼來源:ResultWindow.java

示例12: DistributedJobContextImpl

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
public DistributedJobContextImpl(final DataCleanerConfiguration masterConfiguration, final AnalysisJob masterJob,
        final int chunkIndex, final int chunkCount) {
    _masterConfiguration = masterConfiguration;
    _masterJob = masterJob;
    _chunkIndex = chunkIndex;
    _chunkCount = chunkCount;
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:8,代碼來源:DistributedJobContextImpl.java

示例13: buildSlaveJob

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
/**
 * Creates a slave job by copying the original job and adding a
 * {@link MaxRowsFilter} as a default requirement.
 *
 * @param job
 * @param firstRow
 * @param maxRows
 * @return
 */
private AnalysisJob buildSlaveJob(final AnalysisJob job, final int slaveJobIndex, final int firstRow,
        final int maxRows) {
    logger.info("Building slave job {} with firstRow={} and maxRow={}", slaveJobIndex + 1, firstRow, maxRows);

    try (AnalysisJobBuilder jobBuilder = new AnalysisJobBuilder(_configuration, job)) {

        final FilterComponentBuilder<MaxRowsFilter, Category> maxRowsFilter =
                jobBuilder.addFilter(MaxRowsFilter.class);
        maxRowsFilter.getComponentInstance().setFirstRow(firstRow);
        maxRowsFilter.getComponentInstance().setMaxRows(maxRows);

        final boolean naturalRecordOrderConsistent =
                jobBuilder.getDatastore().getPerformanceCharacteristics().isNaturalRecordOrderConsistent();
        if (!naturalRecordOrderConsistent) {
            final InputColumn<?> orderColumn = findOrderByColumn(jobBuilder);
            maxRowsFilter.getComponentInstance().setOrderColumn(orderColumn);
        }

        jobBuilder.setDefaultRequirement(maxRowsFilter, MaxRowsFilter.Category.VALID);

        // in assertion/test mode do an early validation
        assert jobBuilder.isConfigured(true);

        return jobBuilder.toAnalysisJob();
    }
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:36,代碼來源:DistributedAnalysisRunner.java

示例14: jobSuccess

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
@Override
public void jobSuccess(final AnalysisJob job, final AnalysisJobMetrics metrics) {
    for (final AnalysisListener delegate : _delegates) {
        try {
            delegate.jobSuccess(job, metrics);
        } catch (final Exception e) {
            logger.warn("Listener {} failed", delegate.getClass().getName(), e);
        }
    }
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:11,代碼來源:CompositeAnalysisListener.java

示例15: createWrappedAnalysisJob

import org.datacleaner.job.AnalysisJob; //導入依賴的package包/類
@Override
protected AnalysisJob createWrappedAnalysisJob() {
    try (AnalysisJobBuilder builder = new AnalysisJobBuilder(_configuration)) {
        builder.setDatastore("orig_input");
        builder.addSourceColumns("table.foo");
        builder.addTransformer(MockTransformer.class).addInputColumns(builder.getSourceColumns());
        builder.addAnalyzer(MockAnalyzer.class).addInputColumns(builder.getAvailableInputColumns(Object.class));
        return builder.toAnalysisJob();
    }
}
 
開發者ID:datacleaner,項目名稱:DataCleaner,代碼行數:11,代碼來源:AbstractWrappedAnalysisJobTransformerTest.java


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