You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@beam.apache.org by "Kyle Weaver (Jira)" <ji...@apache.org> on 2020/09/29 01:39:00 UTC
[jira] [Commented] (BEAM-9026) ValueProviderTests test failures
[ https://issues.apache.org/jira/browse/BEAM-9026?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17203582#comment-17203582 ]
Kyle Weaver commented on BEAM-9026:
-----------------------------------
I ran into a similar issue, where it looks like one of the test value provider arguments is leaking into an unrelated test: https://ci-beam.apache.org/job/beam_PreCommit_Python_Commit/15431/testReport/junit/apache_beam.runners.portability.flink_uber_jar_job_server_test/FlinkUberJarJobServerTest/test_retain_unknown_options/
> ValueProviderTests test failures
> --------------------------------
>
> Key: BEAM-9026
> URL: https://issues.apache.org/jira/browse/BEAM-9026
> Project: Beam
> Issue Type: Bug
> Components: sdk-py-core, test-failures
> Reporter: Udi Meiri
> Assignee: Udi Meiri
> Priority: P2
> Fix For: Not applicable
>
> Time Spent: 1h 10m
> Remaining Estimate: 0h
>
> It seems that there's an ordering issue with these tests, where they expect RuntimeValueProvider.runtime_options to be None, but it has already been initialized by another test.
> {code}
> 13:49:31 ______ ValueProviderTests.test_runtime_value_provider_positional_argument ______
> 13:49:31 [gw1] linux -- Python 3.6.8 /home/jenkins/jenkins-slave/workspace/beam_PreCommit_Python_Commit/src/sdks/python/test-suites/tox/py36/build/srcs/sdks/python/target/.tox-py36-gcp-pytest/py36-gcp-pytest/bin/python
> 13:49:31
> 13:49:31 self = <apache_beam.options.value_provider_test.ValueProviderTests testMethod=test_runtime_value_provider_positional_argument>
> 13:49:31
> 13:49:31 def test_runtime_value_provider_positional_argument(self):
> 13:49:31 class UserDefinedOptions(PipelineOptions):
> 13:49:31 @classmethod
> 13:49:31 def _add_argparse_args(cls, parser):
> 13:49:31 parser.add_value_provider_argument(
> 13:49:31 'vpt_vp_arg4',
> 13:49:31 help='This positional argument is a value provider')
> 13:49:31 options = UserDefinedOptions([])
> 13:49:31 self.assertTrue(isinstance(options.vpt_vp_arg4, RuntimeValueProvider))
> 13:49:31 > self.assertFalse(options.vpt_vp_arg4.is_accessible())
> 13:49:31 E AssertionError: True is not false
> 13:49:31
> 13:49:31 apache_beam/options/value_provider_test.py:85: AssertionError
> 13:49:31 __________________ ValueProviderTests.test_set_runtime_option __________________
> 13:49:31 [gw1] linux -- Python 3.6.8 /home/jenkins/jenkins-slave/workspace/beam_PreCommit_Python_Commit/src/sdks/python/test-suites/tox/py36/build/srcs/sdks/python/target/.tox-py36-gcp-pytest/py36-gcp-pytest/bin/python
> 13:49:31
> 13:49:31 self = <apache_beam.options.value_provider_test.ValueProviderTests testMethod=test_set_runtime_option>
> 13:49:31
> 13:49:31 def test_set_runtime_option(self):
> 13:49:31 # define ValueProvider options, with and without default values
> 13:49:31 class UserDefinedOptions1(PipelineOptions):
> 13:49:31 @classmethod
> 13:49:31 def _add_argparse_args(cls, parser):
> 13:49:31 parser.add_value_provider_argument(
> 13:49:31 '--vpt_vp_arg6',
> 13:49:31 help='This keyword argument is a value provider') # set at runtime
> 13:49:31
> 13:49:31 parser.add_value_provider_argument( # not set, had default int
> 13:49:31 '-v', '--vpt_vp_arg7', # with short form
> 13:49:31 default=123,
> 13:49:31 type=int)
> 13:49:31
> 13:49:31 parser.add_value_provider_argument( # not set, had default str
> 13:49:31 '--vpt_vp-arg8', # with dash in name
> 13:49:31 default='123',
> 13:49:31 type=str)
> 13:49:31
> 13:49:31 parser.add_value_provider_argument( # not set and no default
> 13:49:31 '--vpt_vp_arg9',
> 13:49:31 type=float)
> 13:49:31
> 13:49:31 parser.add_value_provider_argument( # positional argument set
> 13:49:31 'vpt_vp_arg10', # default & runtime ignored
> 13:49:31 help='This positional argument is a value provider',
> 13:49:31 type=float,
> 13:49:31 default=5.4)
> 13:49:31
> 13:49:31 # provide values at graph-construction time
> 13:49:31 # (options not provided here become of the type RuntimeValueProvider)
> 13:49:31 options = UserDefinedOptions1(['1.2'])
> 13:49:31 > self.assertFalse(options.vpt_vp_arg6.is_accessible())
> 13:49:31 E AssertionError: True is not false
> 13:49:31
> 13:49:31 apache_beam/options/value_provider_test.py:135: AssertionError
> {code}
> https://builds.apache.org/job/beam_PreCommit_Python_Commit/10566/timestamps/?time=HH:mm:ss&timeZone=GMT-8&appendLog&locale=en_US
--
This message was sent by Atlassian Jira
(v8.3.4#803005)