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)