[ 
https://issues.apache.org/jira/browse/BEAM-10636?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

David Rubinstein updated BEAM-10636:
------------------------------------
    Description: 
PyCrypto [uses|[https://github.com/pycrypto/pycrypto/issues/308]] 
`time.clock()` which was 
[deprecated|[https://docs.python.org/3/whatsnew/3.8.html#api-and-feature-removals]]
 in Python3.8

Upon further look this has to do with google-apitools depending on oauth2client 
(which is archived) which depends on pycrypto (which is not maintained 
anymore). Not really sure what to do to fix the dependencies, but deployments 
in Python3.8 with FnAPI on Dataflow are broken for me until then.
 
 Relevant stacktrace.
{noformat}
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/pipeline.py", line 534, in 
run
[2020-08-04T18:03:22.978Z]     return self.runner.run_pipeline(self, 
self._options)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/dataflow_runner.py",
 line 558, in run_pipeline
[2020-08-04T18:03:22.978Z]     self.job = apiclient.Job(options, 
self.proto_pipeline)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/apiclient.py",
 line 495, in __init__
[2020-08-04T18:03:22.978Z]     self.proto.replaceJobId = 
self.job_id_for_name(self.proto.name)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/apiclient.py",
 line 518, in job_id_for_name
[2020-08-04T18:03:22.978Z]     return DataflowApplicationClient(
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/apiclient.py",
 line 924, in job_id_for_name
[2020-08-04T18:03:22.978Z]     response = 
self._client.projects_locations_jobs.List(request)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/clients/dataflow/dataflow_v1b3_client.py",
 line 763, in List
[2020-08-04T18:03:22.978Z]     return self._RunMethod(
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apitools/base/py/base_api.py", line 
728, in _RunMethod
[2020-08-04T18:03:22.978Z]     http_response = http_wrapper.MakeRequest(
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", line 
359, in MakeRequest
[2020-08-04T18:03:22.978Z]     retry_func(ExceptionRetryArgs(http, 
http_request, e, retry,
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", line 
304, in HandleExceptionsAndRebuildHttpConnections
[2020-08-04T18:03:22.978Z]     raise retry_args.exc
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", line 
348, in MakeRequest
[2020-08-04T18:03:22.978Z]     return _MakeRequestNoRetry(
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", line 
397, in _MakeRequestNoRetry
[2020-08-04T18:03:22.978Z]     info, content = http.request(
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/transport.py", line 153, 
in new_request
[2020-08-04T18:03:22.978Z]     credentials._refresh(orig_request_method)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/client.py", line 765, in 
_refresh
[2020-08-04T18:03:22.978Z]     self._do_refresh_request(http_request)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/client.py", line 792, in 
_do_refresh_request
[2020-08-04T18:03:22.978Z]     body = self._generate_refresh_request_body()
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/client.py", line 1501, in 
_generate_refresh_request_body
[2020-08-04T18:03:22.978Z]     assertion = self._generate_assertion()
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/service_account.py", line 
385, in _generate_assertion
[2020-08-04T18:03:22.978Z]     return crypt.make_signed_jwt(self._signer, 
payload,
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/crypt.py", line 97, in 
make_signed_jwt
[2020-08-04T18:03:22.978Z]     signature = signer.sign(signing_input)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/_pycrypto_crypt.py", line 
99, in sign
[2020-08-04T18:03:22.978Z]     return 
PKCS1_v1_5.new(self._key).sign(SHA256.new(message))
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Signature/PKCS1_v1_5.py", line 
112, in sign
[2020-08-04T18:03:22.978Z]     m = self._key.decrypt(em)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/PublicKey/RSA.py", line 174, in 
decrypt
[2020-08-04T18:03:22.978Z]     return pubkey.pubkey.decrypt(self, ciphertext)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/PublicKey/pubkey.py", line 93, 
in decrypt
[2020-08-04T18:03:22.978Z]     plaintext=self._decrypt(ciphertext)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/PublicKey/RSA.py", line 235, in 
_decrypt
[2020-08-04T18:03:22.978Z]     r = getRandomRange(1, self.key.n-1, 
randfunc=self._randfunc)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Util/number.py", line 123, in 
getRandomRange
[2020-08-04T18:03:22.978Z]     value = getRandomInteger(bits, randfunc)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Util/number.py", line 104, in 
getRandomInteger
[2020-08-04T18:03:22.978Z]     S = randfunc(N>>3)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
line 202, in read
[2020-08-04T18:03:22.978Z]     return self._singleton.read(bytes)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
line 178, in read
[2020-08-04T18:03:22.978Z]     return _UserFriendlyRNG.read(self, bytes)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
line 129, in read
[2020-08-04T18:03:22.978Z]     self._ec.collect()
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
line 77, in collect
[2020-08-04T18:03:22.978Z]     t = time.clock()
[2020-08-04T18:03:22.978Z] AttributeError: module 'time' has no attribute 
'clock'
{noformat}



  was:
PyCrypto [uses|[https://github.com/pycrypto/pycrypto/issues/308]] 
`time.clock()` which was 
[deprecated|[https://docs.python.org/3/whatsnew/3.8.html#api-and-feature-removals]]
 in Python3.8

Upon further look this has to do with google-apitools depending on oauth2client 
(which is archived) which depends on pycrypto (which is not maintained 
anymore). Not really sure what to do to fix the dependencies, but deployments 
in Python3.8 with FnAPI on Dataflow are broken for me until then.
 
 Relevant stacktrace.
{noformat}
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/pipeline.py", line 534, in 
run
[2020-08-04T18:03:22.978Z]     return self.runner.run_pipeline(self, 
self._options)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/dataflow_runner.py",
 line 558, in run_pipeline
[2020-08-04T18:03:22.978Z]     self.job = apiclient.Job(options, 
self.proto_pipeline)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/apiclient.py",
 line 495, in __init__
[2020-08-04T18:03:22.978Z]     self.proto.replaceJobId = 
self.job_id_for_name(self.proto.name)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/apiclient.py",
 line 518, in job_id_for_name
[2020-08-04T18:03:22.978Z]     return DataflowApplicationClient(
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/apiclient.py",
 line 924, in job_id_for_name
[2020-08-04T18:03:22.978Z]     response = 
self._client.projects_locations_jobs.List(request)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/clients/dataflow/dataflow_v1b3_client.py",
 line 763, in List
[2020-08-04T18:03:22.978Z]     return self._RunMethod(
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apitools/base/py/base_api.py", line 
728, in _RunMethod
[2020-08-04T18:03:22.978Z]     http_response = http_wrapper.MakeRequest(
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", line 
359, in MakeRequest
[2020-08-04T18:03:22.978Z]     retry_func(ExceptionRetryArgs(http, 
http_request, e, retry,
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", line 
304, in HandleExceptionsAndRebuildHttpConnections
[2020-08-04T18:03:22.978Z]     raise retry_args.exc
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", line 
348, in MakeRequest
[2020-08-04T18:03:22.978Z]     return _MakeRequestNoRetry(
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", line 
397, in _MakeRequestNoRetry
[2020-08-04T18:03:22.978Z]     info, content = http.request(
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/transport.py", line 153, 
in new_request
[2020-08-04T18:03:22.978Z]     credentials._refresh(orig_request_method)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/client.py", line 765, in 
_refresh
[2020-08-04T18:03:22.978Z]     self._do_refresh_request(http_request)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/client.py", line 792, in 
_do_refresh_request
[2020-08-04T18:03:22.978Z]     body = self._generate_refresh_request_body()
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/client.py", line 1501, in 
_generate_refresh_request_body
[2020-08-04T18:03:22.978Z]     assertion = self._generate_assertion()
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/service_account.py", line 
385, in _generate_assertion
[2020-08-04T18:03:22.978Z]     return crypt.make_signed_jwt(self._signer, 
payload,
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/crypt.py", line 97, in 
make_signed_jwt
[2020-08-04T18:03:22.978Z]     signature = signer.sign(signing_input)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/oauth2client/_pycrypto_crypt.py", line 
99, in sign
[2020-08-04T18:03:22.978Z]     return 
PKCS1_v1_5.new(self._key).sign(SHA256.new(message))
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Signature/PKCS1_v1_5.py", line 
112, in sign
[2020-08-04T18:03:22.978Z]     m = self._key.decrypt(em)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/PublicKey/RSA.py", line 174, in 
decrypt
[2020-08-04T18:03:22.978Z]     return pubkey.pubkey.decrypt(self, ciphertext)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/PublicKey/pubkey.py", line 93, 
in decrypt
[2020-08-04T18:03:22.978Z]     plaintext=self._decrypt(ciphertext)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/PublicKey/RSA.py", line 235, in 
_decrypt
[2020-08-04T18:03:22.978Z]     r = getRandomRange(1, self.key.n-1, 
randfunc=self._randfunc)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Util/number.py", line 123, in 
getRandomRange
[2020-08-04T18:03:22.978Z]     value = getRandomInteger(bits, randfunc)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Util/number.py", line 104, in 
getRandomInteger
[2020-08-04T18:03:22.978Z]     S = randfunc(N>>3)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
line 202, in read
[2020-08-04T18:03:22.978Z]     return self._singleton.read(bytes)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
line 178, in read
[2020-08-04T18:03:22.978Z]     return _UserFriendlyRNG.read(self, bytes)
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
line 129, in read
[2020-08-04T18:03:22.978Z]     self._ec.collect()
[2020-08-04T18:03:22.978Z]   File 
"/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
line 77, in collect
[2020-08-04T18:03:22.978Z]     t = time.clock()
[2020-08-04T18:03:22.978Z] AttributeError: module 'time' has no attribute 
'clock'
{noformat




> Dataflow deployments with FnAPI runner fail on python3.8 due to pycrypto 
> -------------------------------------------------------------------------
>
>                 Key: BEAM-10636
>                 URL: https://issues.apache.org/jira/browse/BEAM-10636
>             Project: Beam
>          Issue Type: Bug
>          Components: runner-dataflow
>    Affects Versions: 2.23.0
>            Reporter: David Rubinstein
>            Priority: P2
>
> PyCrypto [uses|[https://github.com/pycrypto/pycrypto/issues/308]] 
> `time.clock()` which was 
> [deprecated|[https://docs.python.org/3/whatsnew/3.8.html#api-and-feature-removals]]
>  in Python3.8
> Upon further look this has to do with google-apitools depending on 
> oauth2client (which is archived) which depends on pycrypto (which is not 
> maintained anymore). Not really sure what to do to fix the dependencies, but 
> deployments in Python3.8 with FnAPI on Dataflow are broken for me until then.
>  
>  Relevant stacktrace.
> {noformat}
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/apache_beam/pipeline.py", line 534, 
> in run
> [2020-08-04T18:03:22.978Z]     return self.runner.run_pipeline(self, 
> self._options)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/dataflow_runner.py",
>  line 558, in run_pipeline
> [2020-08-04T18:03:22.978Z]     self.job = apiclient.Job(options, 
> self.proto_pipeline)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/apiclient.py",
>  line 495, in __init__
> [2020-08-04T18:03:22.978Z]     self.proto.replaceJobId = 
> self.job_id_for_name(self.proto.name)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/apiclient.py",
>  line 518, in job_id_for_name
> [2020-08-04T18:03:22.978Z]     return DataflowApplicationClient(
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/apiclient.py",
>  line 924, in job_id_for_name
> [2020-08-04T18:03:22.978Z]     response = 
> self._client.projects_locations_jobs.List(request)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/apache_beam/runners/dataflow/internal/clients/dataflow/dataflow_v1b3_client.py",
>  line 763, in List
> [2020-08-04T18:03:22.978Z]     return self._RunMethod(
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/apitools/base/py/base_api.py", line 
> 728, in _RunMethod
> [2020-08-04T18:03:22.978Z]     http_response = http_wrapper.MakeRequest(
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", 
> line 359, in MakeRequest
> [2020-08-04T18:03:22.978Z]     retry_func(ExceptionRetryArgs(http, 
> http_request, e, retry,
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", 
> line 304, in HandleExceptionsAndRebuildHttpConnections
> [2020-08-04T18:03:22.978Z]     raise retry_args.exc
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", 
> line 348, in MakeRequest
> [2020-08-04T18:03:22.978Z]     return _MakeRequestNoRetry(
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/apitools/base/py/http_wrapper.py", 
> line 397, in _MakeRequestNoRetry
> [2020-08-04T18:03:22.978Z]     info, content = http.request(
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/oauth2client/transport.py", line 153, 
> in new_request
> [2020-08-04T18:03:22.978Z]     credentials._refresh(orig_request_method)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/oauth2client/client.py", line 765, in 
> _refresh
> [2020-08-04T18:03:22.978Z]     self._do_refresh_request(http_request)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/oauth2client/client.py", line 792, in 
> _do_refresh_request
> [2020-08-04T18:03:22.978Z]     body = self._generate_refresh_request_body()
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/oauth2client/client.py", line 1501, 
> in _generate_refresh_request_body
> [2020-08-04T18:03:22.978Z]     assertion = self._generate_assertion()
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/oauth2client/service_account.py", 
> line 385, in _generate_assertion
> [2020-08-04T18:03:22.978Z]     return crypt.make_signed_jwt(self._signer, 
> payload,
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/oauth2client/crypt.py", line 97, in 
> make_signed_jwt
> [2020-08-04T18:03:22.978Z]     signature = signer.sign(signing_input)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/oauth2client/_pycrypto_crypt.py", 
> line 99, in sign
> [2020-08-04T18:03:22.978Z]     return 
> PKCS1_v1_5.new(self._key).sign(SHA256.new(message))
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/Crypto/Signature/PKCS1_v1_5.py", line 
> 112, in sign
> [2020-08-04T18:03:22.978Z]     m = self._key.decrypt(em)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/Crypto/PublicKey/RSA.py", line 174, 
> in decrypt
> [2020-08-04T18:03:22.978Z]     return pubkey.pubkey.decrypt(self, ciphertext)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/Crypto/PublicKey/pubkey.py", line 93, 
> in decrypt
> [2020-08-04T18:03:22.978Z]     plaintext=self._decrypt(ciphertext)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/Crypto/PublicKey/RSA.py", line 235, 
> in _decrypt
> [2020-08-04T18:03:22.978Z]     r = getRandomRange(1, self.key.n-1, 
> randfunc=self._randfunc)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/Crypto/Util/number.py", line 123, in 
> getRandomRange
> [2020-08-04T18:03:22.978Z]     value = getRandomInteger(bits, randfunc)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/Crypto/Util/number.py", line 104, in 
> getRandomInteger
> [2020-08-04T18:03:22.978Z]     S = randfunc(N>>3)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
> line 202, in read
> [2020-08-04T18:03:22.978Z]     return self._singleton.read(bytes)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
> line 178, in read
> [2020-08-04T18:03:22.978Z]     return _UserFriendlyRNG.read(self, bytes)
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
> line 129, in read
> [2020-08-04T18:03:22.978Z]     self._ec.collect()
> [2020-08-04T18:03:22.978Z]   File 
> "/usr/local/lib/python3.8/site-packages/Crypto/Random/_UserFriendlyRNG.py", 
> line 77, in collect
> [2020-08-04T18:03:22.978Z]     t = time.clock()
> [2020-08-04T18:03:22.978Z] AttributeError: module 'time' has no attribute 
> 'clock'
> {noformat}



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

Reply via email to