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


Java BoundedReader.advance方法代碼示例

本文整理匯總了Java中org.apache.beam.sdk.io.BoundedSource.BoundedReader.advance方法的典型用法代碼示例。如果您正苦於以下問題:Java BoundedReader.advance方法的具體用法?Java BoundedReader.advance怎麽用?Java BoundedReader.advance使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.beam.sdk.io.BoundedSource.BoundedReader的用法示例。


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

示例1: testUnsplittable

import org.apache.beam.sdk.io.BoundedSource.BoundedReader; //導入方法依賴的package包/類
@Test
public void testUnsplittable() throws IOException {
  String baseName = "test-input";
  File compressedFile = tmpFolder.newFile(baseName + ".gz");
  byte[] input = generateInput(10000);
  writeFile(compressedFile, input, CompressionMode.GZIP);

  CompressedSource<Byte> source =
      CompressedSource.from(new ByteSource(compressedFile.getPath(), 1));
  List<Byte> expected = Lists.newArrayList();
  for (byte i : input) {
    expected.add(i);
  }

  PipelineOptions options = PipelineOptionsFactory.create();
  BoundedReader<Byte> reader = source.createReader(options);

  List<Byte> actual = Lists.newArrayList();
  for (boolean hasNext = reader.start(); hasNext; hasNext = reader.advance()) {
    actual.add(reader.getCurrent());
    // checkpoint every 9 elements
    if (actual.size() % 9 == 0) {
      Double fractionConsumed = reader.getFractionConsumed();
      assertNotNull(fractionConsumed);
      assertNull(reader.splitAtFraction(fractionConsumed));
    }
  }
  assertEquals(expected.size(), actual.size());
  assertEquals(Sets.newHashSet(expected), Sets.newHashSet(actual));
}
 
開發者ID:apache,項目名稱:beam,代碼行數:31,代碼來源:CompressedSourceTest.java

示例2: testGetFractionConsumedForBadProgressValue

import org.apache.beam.sdk.io.BoundedSource.BoundedReader; //導入方法依賴的package包/類
/**
 * This test validates the method getFractionConsumed()- when a bad progress value is returned by
 * the inputformat.
 */
@Test
public void testGetFractionConsumedForBadProgressValue() throws Exception {
  InputFormat<Text, Employee> mockInputFormat = Mockito.mock(EmployeeInputFormat.class);
  EmployeeRecordReader mockReader = Mockito.mock(EmployeeRecordReader.class);
  Mockito.when(
      mockInputFormat.createRecordReader(Mockito.any(InputSplit.class),
          Mockito.any(TaskAttemptContext.class))).thenReturn(mockReader);
  Mockito.when(mockReader.nextKeyValue()).thenReturn(true);
  // Set to a bad value , not in range of 0 to 1
  Mockito.when(mockReader.getProgress()).thenReturn(2.0F);
  InputSplit mockInputSplit = Mockito.mock(NewObjectsEmployeeInputSplit.class);
  HadoopInputFormatBoundedSource<Text, Employee> boundedSource =
      new HadoopInputFormatBoundedSource<Text, Employee>(
          serConf,
          WritableCoder.of(Text.class),
          AvroCoder.of(Employee.class),
          null, // No key translation required.
          null, // No value translation required.
          new SerializableSplit(mockInputSplit));
  boundedSource.setInputFormatObj(mockInputFormat);
  BoundedReader<KV<Text, Employee>> reader = boundedSource.createReader(p.getOptions());
  assertEquals(Double.valueOf(0), reader.getFractionConsumed());
  boolean start = reader.start();
  assertEquals(true, start);
  if (start) {
    boolean advance = reader.advance();
    assertEquals(null, reader.getFractionConsumed());
    assertEquals(true, advance);
    if (advance) {
      advance = reader.advance();
      assertEquals(null, reader.getFractionConsumed());
    }
  }
  // Validate if getFractionConsumed() returns null after few number of reads as getProgress
  // returns invalid value '2' which is not in the range of 0 to 1.
  assertEquals(null, reader.getFractionConsumed());
  reader.close();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:43,代碼來源:HadoopInputFormatIOTest.java

示例3: testGetSplitPointsConsumed

import org.apache.beam.sdk.io.BoundedSource.BoundedReader; //導入方法依賴的package包/類
@Test
public void testGetSplitPointsConsumed() throws Exception {
  final String table = "TEST-TABLE";
  final int numRows = 100;
  int splitPointsConsumed = 0;

  makeTableData(table, numRows);

  BigtableSource source =
      new BigtableSource(serviceFactory, table, null, Arrays.asList(ByteKeyRange.ALL_KEYS), null);

  BoundedReader<Row> reader = source.createReader(TestPipeline.testingPipelineOptions());

  reader.start();
  // Started, 0 split points consumed
  assertEquals("splitPointsConsumed starting",
      splitPointsConsumed, reader.getSplitPointsConsumed());

  // Split points consumed increases for each row read
  while (reader.advance()) {
    assertEquals("splitPointsConsumed advancing",
        ++splitPointsConsumed, reader.getSplitPointsConsumed());
  }

  // Reader marked as done, 100 split points consumed
  assertEquals("splitPointsConsumed done", numRows, reader.getSplitPointsConsumed());

  reader.close();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:30,代碼來源:BigtableIOTest.java

示例4: testReadersGetFractionConsumed

import org.apache.beam.sdk.io.BoundedSource.BoundedReader; //導入方法依賴的package包/類
/**
 * This test validates the method getFractionConsumed()- which indicates the progress of the read
 * in range of 0 to 1.
 */
@Test
public void testReadersGetFractionConsumed() throws Exception {
  List<KV<Text, Employee>> referenceRecords = TestEmployeeDataSet.getEmployeeData();
  HadoopInputFormatBoundedSource<Text, Employee> hifSource = getTestHIFSource(
      EmployeeInputFormat.class,
      Text.class,
      Employee.class,
      WritableCoder.of(Text.class),
      AvroCoder.of(Employee.class));
  long estimatedSize = hifSource.getEstimatedSizeBytes(p.getOptions());
  // Validate if estimated size is equal to the size of records.
  assertEquals(referenceRecords.size(), estimatedSize);
  List<BoundedSource<KV<Text, Employee>>> boundedSourceList =
      hifSource.split(0, p.getOptions());
  // Validate if split() has split correctly.
  assertEquals(TestEmployeeDataSet.NUMBER_OF_SPLITS, boundedSourceList.size());
  List<KV<Text, Employee>> bundleRecords = new ArrayList<>();
  for (BoundedSource<KV<Text, Employee>> source : boundedSourceList) {
    List<KV<Text, Employee>> elements = new ArrayList<KV<Text, Employee>>();
    BoundedReader<KV<Text, Employee>> reader = source.createReader(p.getOptions());
    float recordsRead = 0;
    // When start is not called, getFractionConsumed() should return 0.
    assertEquals(Double.valueOf(0), reader.getFractionConsumed());
    boolean start = reader.start();
    assertEquals(true, start);
    if (start) {
      elements.add(reader.getCurrent());
      boolean advance = reader.advance();
      // Validate if getFractionConsumed() returns the correct fraction based on
      // the number of records read in the split.
      assertEquals(
          Double.valueOf(++recordsRead / TestEmployeeDataSet.NUMBER_OF_RECORDS_IN_EACH_SPLIT),
          reader.getFractionConsumed());
      assertEquals(true, advance);
      while (advance) {
        elements.add(reader.getCurrent());
        advance = reader.advance();
        assertEquals(
            Double.valueOf(++recordsRead / TestEmployeeDataSet.NUMBER_OF_RECORDS_IN_EACH_SPLIT),
            reader.getFractionConsumed());
      }
      bundleRecords.addAll(elements);
    }
    // Validate if getFractionConsumed() returns 1 after reading is complete.
    assertEquals(Double.valueOf(1), reader.getFractionConsumed());
    reader.close();
  }
  assertThat(bundleRecords, containsInAnyOrder(referenceRecords.toArray()));
}
 
開發者ID:apache,項目名稱:beam,代碼行數:54,代碼來源:HadoopInputFormatIOTest.java


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