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


Java TestStream類代碼示例

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


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

示例1: testConvertsBids

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
@Test
public void testConvertsBids() throws Exception {
  PCollection<Event> bids = testPipeline.apply(
      TestStream.create(Event.CODER)
          .addElements(new Event(BID))
          .advanceWatermarkToInfinity());

  BeamRecord expectedBidRecord =
      new BeamRecord(
          ModelAdaptersMapping.ADAPTERS.get(Bid.class).getRecordType(),
          ModelAdaptersMapping.ADAPTERS.get(Bid.class).getFieldsValues(BID));

  PAssert
      .that(bids.apply(ToBeamRecord.parDo()))
      .containsInAnyOrder(expectedBidRecord);

  testPipeline.run();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:19,代碼來源:ToBeamRecordTest.java

示例2: testConvertsPeople

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
@Test
public void testConvertsPeople() throws Exception {
  PCollection<Event> people = testPipeline.apply(
      TestStream.create(Event.CODER)
          .addElements(new Event(PERSON))
          .advanceWatermarkToInfinity());

  BeamRecord expectedPersonRecord =
      new BeamRecord(
          ModelAdaptersMapping.ADAPTERS.get(Person.class).getRecordType(),
          ModelAdaptersMapping.ADAPTERS.get(Person.class).getFieldsValues(PERSON));

  PAssert
      .that(people.apply(ToBeamRecord.parDo()))
      .containsInAnyOrder(expectedPersonRecord);

  testPipeline.run();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:19,代碼來源:ToBeamRecordTest.java

示例3: testConvertsAuctions

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
@Test
public void testConvertsAuctions() throws Exception {
  PCollection<Event> auctions = testPipeline.apply(
      TestStream.create(Event.CODER)
          .addElements(new Event(AUCTION))
          .advanceWatermarkToInfinity());

  BeamRecord expectedAuctionRecord =
      new BeamRecord(
          ModelAdaptersMapping.ADAPTERS.get(Auction.class).getRecordType(),
          ModelAdaptersMapping.ADAPTERS.get(Auction.class).getFieldsValues(AUCTION));

  PAssert
      .that(auctions.apply(ToBeamRecord.parDo()))
      .containsInAnyOrder(expectedAuctionRecord);

  testPipeline.run();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:19,代碼來源:ToBeamRecordTest.java

示例4: testReshuffleWithTimestampsStreaming

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
@Test
@Category({ValidatesRunner.class, UsesTestStream.class})
public void testReshuffleWithTimestampsStreaming() {
  TestStream<Long> stream =
      TestStream.create(VarLongCoder.of())
          .advanceWatermarkTo(new Instant(0L).plus(Duration.standardDays(48L)))
          .addElements(
              TimestampedValue.of(0L, new Instant(0L)),
              TimestampedValue.of(1L, new Instant(0L).plus(Duration.standardDays(48L))),
              TimestampedValue.of(
                  2L, BoundedWindow.TIMESTAMP_MAX_VALUE.minus(Duration.standardDays(48L))))
          .advanceWatermarkToInfinity();
  PCollection<KV<String, Long>> input =
      pipeline
          .apply(stream).apply(WithKeys.<String, Long>of(""))
          .apply(
              Window.<KV<String, Long>>into(FixedWindows.of(Duration.standardMinutes(10L))));

  PCollection<KV<String, Long>> reshuffled = input.apply(Reshuffle.<String, Long>of());
  PAssert.that(reshuffled.apply(Values.<Long>create())).containsInAnyOrder(0L, 1L, 2L);

  pipeline.run();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:24,代碼來源:ReshuffleTest.java

示例5: globalWindowNoKeys

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
@Test
@Category(NeedsRunner.class)
public void globalWindowNoKeys() {
  PCollection<ValueInSingleWindow<String>> result =
      pipeline
          .apply(
              TestStream.create(StringUtf8Coder.of())
                  .addElements(TimestampedValue.of("dei", new Instant(123L)))
                  .advanceWatermarkToInfinity())
          .apply(Reify.<String>windows());
  PAssert.that(result)
      .containsInAnyOrder(
          ValueInSingleWindow.of(
              "dei", new Instant(123L), GlobalWindow.INSTANCE, PaneInfo.NO_FIRING));
  pipeline.run();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:17,代碼來源:ReifyTest.java

示例6: RawTestStream

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
public RawTestStream(
    RunnerApi.TestStreamPayload payload, RehydratedComponents rehydratedComponents) {
  this.payload = payload;
  this.spec =
      RunnerApi.FunctionSpec.newBuilder()
          .setUrn(TEST_STREAM_TRANSFORM_URN)
          .setPayload(payload.toByteString())
          .build();
  this.rehydratedComponents = rehydratedComponents;

  // Eagerly extract the coder to throw a good exception here
  try {
    this.valueCoder = (Coder<T>) rehydratedComponents.getCoder(payload.getCoderId());
  } catch (IOException exc) {
    throw new IllegalArgumentException(
        String.format(
            "Failure extracting coder with id '%s' for %s",
            payload.getCoderId(), TestStream.class.getSimpleName()),
        exc);
  }
}
 
開發者ID:apache,項目名稱:beam,代碼行數:22,代碼來源:TestStreamTranslation.java

示例7: getTestStream

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
/**
 * Converts an {@link AppliedPTransform}, which may be a rehydrated transform or an original
 * {@link TestStream}, to a {@link TestStream}.
 */
public static <T> TestStream<T> getTestStream(
    AppliedPTransform<PBegin, PCollection<T>, PTransform<PBegin, PCollection<T>>> application)
    throws IOException {
  // For robustness, we don't take this shortcut:
  // if (application.getTransform() instanceof TestStream) {
  //   return application.getTransform()
  // }

  SdkComponents sdkComponents = SdkComponents.create();
  RunnerApi.PTransform transformProto = PTransformTranslation.toProto(application, sdkComponents);
  checkArgument(
      TEST_STREAM_TRANSFORM_URN.equals(transformProto.getSpec().getUrn()),
      "Attempt to get %s from a transform with wrong URN %s",
      TestStream.class.getSimpleName(),
      transformProto.getSpec().getUrn());
  RunnerApi.TestStreamPayload testStreamPayload =
      RunnerApi.TestStreamPayload.parseFrom(transformProto.getSpec().getPayload());

  return (TestStream<T>)
      testStreamFromProtoPayload(
          testStreamPayload, RehydratedComponents.forComponents(sdkComponents.toComponents()));
}
 
開發者ID:apache,項目名稱:beam,代碼行數:27,代碼來源:TestStreamTranslation.java

示例8: payloadForTestStream

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
@VisibleForTesting
static <T> RunnerApi.TestStreamPayload payloadForTestStream(
    final TestStream<T> testStream, SdkComponents components) throws IOException {
  return payloadForTestStreamLike(
      new TestStreamLike() {
        @Override
        public Coder<T> getValueCoder() {
          return testStream.getValueCoder();
        }

        @Override
        public List<RunnerApi.TestStreamPayload.Event> getEvents() {
          try {
            List<RunnerApi.TestStreamPayload.Event> protoEvents = new ArrayList<>();
            for (TestStream.Event<T> event : testStream.getEvents()) {
              protoEvents.add(eventToProto(event, testStream.getValueCoder()));
            }
            return protoEvents;
          } catch (IOException e) {
            throw new RuntimeException(e);
          }
        }
      },
      components);
}
 
開發者ID:apache,項目名稱:beam,代碼行數:26,代碼來源:TestStreamTranslation.java

示例9: testRegistrarEncodedProto

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
@Test
public void testRegistrarEncodedProto() throws Exception {
  PCollection<String> output = p.apply(testStream);

  AppliedPTransform<PBegin, PCollection<String>, TestStream<String>> appliedTestStream =
      AppliedPTransform.<PBegin, PCollection<String>, TestStream<String>>of(
          "fakeName", PBegin.in(p).expand(), output.expand(), testStream, p);

  SdkComponents components = SdkComponents.create();
  RunnerApi.FunctionSpec spec =
      PTransformTranslation.toProto(appliedTestStream, components).getSpec();

  assertThat(spec.getUrn(), equalTo(TEST_STREAM_TRANSFORM_URN));

  RunnerApi.TestStreamPayload payload = TestStreamPayload.parseFrom(spec.getPayload());

  verifyTestStreamEncoding(
      testStream, payload, RehydratedComponents.forComponents(components.toComponents()));
}
 
開發者ID:apache,項目名稱:beam,代碼行數:20,代碼來源:TestStreamTranslationTest.java

示例10: verifyTestStreamEncoding

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
private static <T> void verifyTestStreamEncoding(
    TestStream<T> testStream,
    RunnerApi.TestStreamPayload payload,
    RehydratedComponents protoComponents)
    throws Exception {

  // This reverse direction is only valid for Java-based coders
  assertThat(
      protoComponents.getCoder(payload.getCoderId()),
      Matchers.<Coder<?>>equalTo(testStream.getValueCoder()));

  assertThat(payload.getEventsList().size(), equalTo(testStream.getEvents().size()));

  for (int i = 0; i < payload.getEventsList().size(); ++i) {
    assertThat(
        TestStreamTranslation.eventFromProto(payload.getEvents(i), testStream.getValueCoder()),
        equalTo(testStream.getEvents().get(i)));
  }
}
 
開發者ID:apache,項目名稱:beam,代碼行數:20,代碼來源:TestStreamTranslationTest.java

示例11: testTeamScoresOnTime

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
/**
 * A test of the {@link CalculateTeamScores} {@link PTransform} when all of the elements arrive
 * on time (ahead of the watermark).
 */
@Test
public void testTeamScoresOnTime() {

  TestStream<GameActionInfo> createEvents = TestStream.create(AvroCoder.of(GameActionInfo.class))
      // Start at the epoch
      .advanceWatermarkTo(baseTime)
      // add some elements ahead of the watermark
      .addElements(event(TestUser.BLUE_ONE, 3, Duration.standardSeconds(3)),
          event(TestUser.BLUE_ONE, 2, Duration.standardMinutes(1)),
          event(TestUser.RED_TWO, 3, Duration.standardSeconds(22)),
          event(TestUser.BLUE_TWO, 5, Duration.standardMinutes(3)))
      // The watermark advances slightly, but not past the end of the window
      .advanceWatermarkTo(baseTime.plus(Duration.standardMinutes(3)))
      // Add some more on time elements
      .addElements(event(TestUser.RED_ONE, 1, Duration.standardMinutes(4)),
          event(TestUser.BLUE_ONE, 2, Duration.standardSeconds(270)))
      // The window should close and emit an ON_TIME pane
      .advanceWatermarkToInfinity();

  PCollection<KV<String, Integer>> teamScores = p.apply(createEvents)
      .apply(new CalculateTeamScores(TEAM_WINDOW_DURATION, ALLOWED_LATENESS));

  String blueTeam = TestUser.BLUE_ONE.getTeam();
  String redTeam = TestUser.RED_ONE.getTeam();
  PAssert.that(teamScores)
      .inOnTimePane(new IntervalWindow(baseTime, TEAM_WINDOW_DURATION))
      .containsInAnyOrder(KV.of(blueTeam, 12), KV.of(redTeam, 4));

  p.run().waitUntilFinish();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:35,代碼來源:LeaderBoardTest.java

示例12: testTeamScoresUnobservablyLate

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
/**
 * A test where elements arrive behind the watermark (late data), but before the end of the
 * window. These elements are emitted on time.
 */
@Test
public void testTeamScoresUnobservablyLate() {

  BoundedWindow window = new IntervalWindow(baseTime, TEAM_WINDOW_DURATION);
  TestStream<GameActionInfo> createEvents = TestStream.create(AvroCoder.of(GameActionInfo.class))
      .advanceWatermarkTo(baseTime)
      .addElements(event(TestUser.BLUE_ONE, 3, Duration.standardSeconds(3)),
          event(TestUser.BLUE_TWO, 5, Duration.standardMinutes(8)),
          event(TestUser.RED_ONE, 4, Duration.standardMinutes(2)),
          event(TestUser.BLUE_ONE, 3, Duration.standardMinutes(5)))
      .advanceWatermarkTo(baseTime.plus(TEAM_WINDOW_DURATION).minus(Duration.standardMinutes(1)))
      // These events are late, but the window hasn't closed yet, so the elements are in the
      // on-time pane
      .addElements(event(TestUser.RED_TWO, 2, Duration.ZERO),
          event(TestUser.RED_TWO, 5, Duration.standardMinutes(1)),
          event(TestUser.BLUE_TWO, 2, Duration.standardSeconds(90)),
          event(TestUser.RED_TWO, 3, Duration.standardMinutes(3)))
      .advanceWatermarkTo(baseTime.plus(TEAM_WINDOW_DURATION).plus(Duration.standardMinutes(1)))
      .advanceWatermarkToInfinity();
  PCollection<KV<String, Integer>> teamScores = p.apply(createEvents)
      .apply(new CalculateTeamScores(TEAM_WINDOW_DURATION, ALLOWED_LATENESS));

  String blueTeam = TestUser.BLUE_ONE.getTeam();
  String redTeam = TestUser.RED_ONE.getTeam();
  // The On Time pane contains the late elements that arrived before the end of the window
  PAssert.that(teamScores)
      .inOnTimePane(window)
      .containsInAnyOrder(KV.of(redTeam, 14), KV.of(blueTeam, 13));

  p.run().waitUntilFinish();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:36,代碼來源:LeaderBoardTest.java

示例13: testTeamScoresDroppablyLate

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
/**
 * A test where elements arrive beyond the maximum allowed lateness. These elements are dropped
 * within {@link CalculateTeamScores} and do not impact the final result.
 */
@Test
public void testTeamScoresDroppablyLate() {

  BoundedWindow window = new IntervalWindow(baseTime, TEAM_WINDOW_DURATION);
  TestStream<GameActionInfo> infos = TestStream.create(AvroCoder.of(GameActionInfo.class))
      .addElements(event(TestUser.BLUE_ONE, 12, Duration.ZERO),
          event(TestUser.RED_ONE, 3, Duration.ZERO))
      .advanceWatermarkTo(window.maxTimestamp())
      .addElements(event(TestUser.RED_ONE, 4, Duration.standardMinutes(2)),
          event(TestUser.BLUE_TWO, 3, Duration.ZERO),
          event(TestUser.BLUE_ONE, 3, Duration.standardMinutes(3)))
      // Move the watermark to the end of the window to output on time
      .advanceWatermarkTo(baseTime.plus(TEAM_WINDOW_DURATION))
      // Move the watermark past the end of the allowed lateness plus the end of the window
      .advanceWatermarkTo(baseTime.plus(ALLOWED_LATENESS)
          .plus(TEAM_WINDOW_DURATION).plus(Duration.standardMinutes(1)))
      // These elements within the expired window are droppably late, and will not appear in the
      // output
      .addElements(
          event(TestUser.BLUE_TWO, 3, TEAM_WINDOW_DURATION.minus(Duration.standardSeconds(5))),
          event(TestUser.RED_ONE, 7, Duration.standardMinutes(4)))
      .advanceWatermarkToInfinity();
  PCollection<KV<String, Integer>> teamScores = p.apply(infos)
      .apply(new CalculateTeamScores(TEAM_WINDOW_DURATION, ALLOWED_LATENESS));

  String blueTeam = TestUser.BLUE_ONE.getTeam();
  String redTeam = TestUser.RED_ONE.getTeam();
  // Only one on-time pane and no late panes should be emitted
  PAssert.that(teamScores)
      .inWindow(window)
      .containsInAnyOrder(KV.of(redTeam, 7), KV.of(blueTeam, 18));
  // No elements are added before the watermark passes the end of the window plus the allowed
  // lateness, so no refinement should be emitted
  PAssert.that(teamScores).inFinalPane(window).empty();

  p.run().waitUntilFinish();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:42,代碼來源:LeaderBoardTest.java

示例14: testConvertsPriceToEur

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
@Test
public void testConvertsPriceToEur() throws Exception {
  PCollection<Event> bids = testPipeline.apply(
      TestStream.create(Event.CODER)
          .addElements(new Event(BID1_USD))
          .addElements(new Event(BID2_USD))
          .advanceWatermarkToInfinity());

  PAssert
      .that(bids.apply(new SqlQuery1()))
      .containsInAnyOrder(BID1_EUR_RECORD, BID2_EUR_RECORD);

  testPipeline.run();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:15,代碼來源:SqlQuery1Test.java

示例15: testPassesBidsThrough

import org.apache.beam.sdk.testing.TestStream; //導入依賴的package包/類
@Test
public void testPassesBidsThrough() throws Exception {
  PCollection<Event> bids = testPipeline.apply(
      TestStream.create(Event.CODER)
          .addElements(new Event(BID1))
          .addElements(new Event(BID2))
          .advanceWatermarkToInfinity());

  PAssert
      .that(bids.apply(new SqlQuery0()))
      .containsInAnyOrder(BID1_RECORD, BID2_RECORD);

  testPipeline.run();
}
 
開發者ID:apache,項目名稱:beam,代碼行數:15,代碼來源:SqlQuery0Test.java


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