You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@beam.apache.org by "Beam JIRA Bot (Jira)" <ji...@apache.org> on 2021/09/14 17:24:01 UTC

[jira] [Commented] (BEAM-12458) Using SubscriberOptions.setPartitions results in pipeline construction error

    [ https://issues.apache.org/jira/browse/BEAM-12458?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17415067#comment-17415067 ] 

Beam JIRA Bot commented on BEAM-12458:
--------------------------------------

This issue is P2 but has been unassigned without any comment for 60 days so it has been labeled "stale-P2". If this issue is still affecting you, we care! Please comment and remove the label. Otherwise, in 14 days the issue will be moved to P3.

Please see https://beam.apache.org/contribute/jira-priorities/ for a detailed explanation of what these priorities mean.


> Using SubscriberOptions.setPartitions results in pipeline construction error
> ----------------------------------------------------------------------------
>
>                 Key: BEAM-12458
>                 URL: https://issues.apache.org/jira/browse/BEAM-12458
>             Project: Beam
>          Issue Type: Bug
>          Components: io-java-gcp
>    Affects Versions: 2.30.0
>            Reporter: Boyuan Zhang
>            Priority: P2
>              Labels: stale-P2
>
> With pipeline like:
> ```
>     SubscriberOptions subscriberOpitons =
>         SubscriberOptions.newBuilder()
>             .setSubscriptionPath(SubscriptionPath.parse(""))
>             .setPartitions(ImmutableSet.of(Partition.of(0))).build();
>     pipeline
>         .apply("Create elements", PubsubLiteIO.read(subscriberOpitons))
> ```
> it will fail at pipeline construction time:
> ```
> java.lang.IllegalArgumentException: Unable to infer a coder and no Coder was specified. Please set a coder by invoking Create.withCoder() explicitly  or a schema by invoking Create.withSchema().
> 	at org.apache.beam.sdk.transforms.Create$Values.expand(Create.java:363)
> 	at org.apache.beam.sdk.transforms.Create$Values.expand(Create.java:277)
> 	at org.apache.beam.sdk.Pipeline.applyInternal(Pipeline.java:548)
> 	at org.apache.beam.sdk.Pipeline.applyTransform(Pipeline.java:482)
> 	at org.apache.beam.sdk.values.PBegin.apply(PBegin.java:44)
> 	at org.apache.beam.sdk.io.gcp.pubsublite.SubscribeTransform.expand(SubscribeTransform.java:126)
> 	at org.apache.beam.sdk.io.gcp.pubsublite.SubscribeTransform.expand(SubscribeTransform.java:46)
> 	at org.apache.beam.sdk.Pipeline.applyInternal(Pipeline.java:548)
> 	at org.apache.beam.sdk.Pipeline.applyTransform(Pipeline.java:499)
> 	at org.apache.beam.sdk.values.PBegin.apply(PBegin.java:56)
> 	at org.apache.beam.sdk.Pipeline.apply(Pipeline.java:192)
> 	at org.apache.beam.sdk.io.gcp.pubsub.PubsubReadIT.testReadPubsubMessageId(PubsubReadIT.java:72)
> 	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> 	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
> 	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
> 	at java.lang.reflect.Method.invoke(Method.java:498)
> 	at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:59)
> 	at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
> 	at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:56)
> 	at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
> 	at org.apache.beam.sdk.testing.TestPipeline$1.evaluate(TestPipeline.java:322)
> 	at org.apache.beam.sdk.io.gcp.pubsub.TestPubsubSignal$1.evaluate(TestPubsubSignal.java:130)
> 	at org.junit.runners.ParentRunner$3.evaluate(ParentRunner.java:306)
> 	at org.junit.runners.BlockJUnit4ClassRunner$1.evaluate(BlockJUnit4ClassRunner.java:100)
> 	at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:366)
> 	at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:103)
> 	at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:63)
> 	at org.junit.runners.ParentRunner$4.run(ParentRunner.java:331)
> 	at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:79)
> 	at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:329)
> 	at org.junit.runners.ParentRunner.access$100(ParentRunner.java:66)
> 	at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:293)
> 	at org.junit.runners.ParentRunner$3.evaluate(ParentRunner.java:306)
> 	at org.junit.runners.ParentRunner.run(ParentRunner.java:413)
> 	at org.gradle.api.internal.tasks.testing.junit.JUnitTestClassExecutor.runTestClass(JUnitTestClassExecutor.java:110)
> 	at org.gradle.api.internal.tasks.testing.junit.JUnitTestClassExecutor.execute(JUnitTestClassExecutor.java:58)
> 	at org.gradle.api.internal.tasks.testing.junit.JUnitTestClassExecutor.execute(JUnitTestClassExecutor.java:38)
> 	at org.gradle.api.internal.tasks.testing.junit.AbstractJUnitTestClassProcessor.processTestClass(AbstractJUnitTestClassProcessor.java:62)
> 	at org.gradle.api.internal.tasks.testing.SuiteTestClassProcessor.processTestClass(SuiteTestClassProcessor.java:51)
> 	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> 	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
> 	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
> 	at java.lang.reflect.Method.invoke(Method.java:498)
> 	at org.gradle.internal.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:36)
> 	at org.gradle.internal.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:24)
> 	at org.gradle.internal.dispatch.ContextClassLoaderDispatch.dispatch(ContextClassLoaderDispatch.java:33)
> 	at org.gradle.internal.dispatch.ProxyDispatchAdapter$DispatchingInvocationHandler.invoke(ProxyDispatchAdapter.java:94)
> 	at com.sun.proxy.$Proxy2.processTestClass(Unknown Source)
> 	at org.gradle.api.internal.tasks.testing.worker.TestWorker.processTestClass(TestWorker.java:119)
> 	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> 	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
> 	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
> 	at java.lang.reflect.Method.invoke(Method.java:498)
> 	at org.gradle.internal.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:36)
> 	at org.gradle.internal.dispatch.ReflectionDispatch.dispatch(ReflectionDispatch.java:24)
> 	at org.gradle.internal.remote.internal.hub.MessageHubBackedObjectConnection$DispatchWrapper.dispatch(MessageHubBackedObjectConnection.java:182)
> 	at org.gradle.internal.remote.internal.hub.MessageHubBackedObjectConnection$DispatchWrapper.dispatch(MessageHubBackedObjectConnection.java:164)
> 	at org.gradle.internal.remote.internal.hub.MessageHub$Handler.run(MessageHub.java:414)
> 	at org.gradle.internal.concurrent.ExecutorPolicy$CatchAndRecordFailures.onExecute(ExecutorPolicy.java:64)
> 	at org.gradle.internal.concurrent.ManagedExecutorImpl$1.run(ManagedExecutorImpl.java:48)
> 	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
> 	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
> 	at org.gradle.internal.concurrent.ThreadFactoryImpl$ManagedThreadRunnable.run(ThreadFactoryImpl.java:56)
> 	at java.lang.Thread.run(Thread.java:748)
> Caused by: org.apache.beam.sdk.coders.CannotProvideCoderException: Unable to provide a Coder for org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition.
>   Building a Coder using a registered CoderProvider failed.
>   See suppressed exceptions for detailed failures.
> 	at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:693)
> 	at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromTypeDescriptor(CoderRegistry.java:622)
> 	at org.apache.beam.sdk.coders.CoderRegistry.getCoder(CoderRegistry.java:254)
> 	at org.apache.beam.sdk.coders.CoderRegistry.getCoder(CoderRegistry.java:245)
> 	at org.apache.beam.sdk.transforms.Create.inferCoderFromObject(Create.java:814)
> 	at org.apache.beam.sdk.transforms.Create.inferCoderFromObjects(Create.java:744)
> 	at org.apache.beam.sdk.transforms.Create.getDefaultCreateCoder(Create.java:732)
> 	at org.apache.beam.sdk.transforms.Create.access$300(Create.java:110)
> 	at org.apache.beam.sdk.transforms.Create$Values.expand(Create.java:359)
> 	... 63 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition is not one of the common types.
> 		at org.apache.beam.sdk.coders.CoderRegistry$CommonTypes.coderFor(CoderRegistry.java:154)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: Class org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition does not have a @DefaultCoder annotation.
> 		at org.apache.beam.sdk.coders.DefaultCoder$DefaultCoderProviderRegistrar$DefaultCoderProvider.coderFor(DefaultCoder.java:92)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: Unable to provide coder for org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition, this factory can only provide coders for org.apache.beam.sdk.coders.CoderRegistryTest$MyValueA
> 		at org.apache.beam.sdk.coders.CoderProviders$CoderProviderForCoder.coderFor(CoderProviders.java:183)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: Unable to provide coder for org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition, this factory can only provide coders for org.apache.beam.sdk.coders.CoderRegistryTest$MyValueB
> 		at org.apache.beam.sdk.coders.CoderProviders$CoderProviderForCoder.coderFor(CoderProviders.java:183)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: Unable to provide coder for org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition, this factory can only provide coders for org.apache.beam.sdk.coders.CoderRegistryTest$AutoRegistrationClass
> 		at org.apache.beam.sdk.coders.CoderProviders$CoderProviderForCoder.coderFor(CoderProviders.java:183)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: Unable to provide coder for org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition, this factory can only provide coders for com.google.protobuf.ByteString
> 		at org.apache.beam.sdk.coders.CoderProviders$CoderProviderForCoder.coderFor(CoderProviders.java:183)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: Cannot provide ProtoCoder because org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition is not a subclass of com.google.protobuf.Message
> 		at org.apache.beam.sdk.extensions.protobuf.ProtoCoder$ProtoCoderProvider.coderFor(ProtoCoder.java:334)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: Unable to provide coder for org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition, this factory can only provide coders for com.google.api.services.bigquery.model.TableRow
> 		at org.apache.beam.sdk.coders.CoderProviders$CoderProviderForCoder.coderFor(CoderProviders.java:183)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: Unable to provide coder for org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition, this factory can only provide coders for org.apache.beam.sdk.io.gcp.pubsub.PubsubMessage
> 		at org.apache.beam.sdk.coders.CoderProviders$CoderProviderForCoder.coderFor(CoderProviders.java:183)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: Unable to provide coder for org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition, this factory can only provide coders for org.apache.beam.sdk.io.gcp.pubsub.PubsubMessage
> 		at org.apache.beam.sdk.coders.CoderProviders$CoderProviderForCoder.coderFor(CoderProviders.java:183)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: Unable to provide coder for org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition, this factory can only provide coders for org.apache.beam.sdk.io.gcp.pubsub.PubsubMessage
> 		at org.apache.beam.sdk.coders.CoderProviders$CoderProviderForCoder.coderFor(CoderProviders.java:183)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> 	Suppressed: org.apache.beam.sdk.coders.CannotProvideCoderException: Cannot provide SerializableCoder because org.apache.beam.sdk.io.gcp.pubsublite.AutoValue_SubscriptionPartition does not implement Serializable
> 		at org.apache.beam.sdk.coders.SerializableCoder$SerializableCoderProvider.coderFor(SerializableCoder.java:160)
> 		at org.apache.beam.sdk.coders.CoderRegistry.getCoderFromFactories(CoderRegistry.java:677)
> 		... 71 more
> ```



--
This message was sent by Atlassian Jira
(v8.3.4#803005)