parsl 2024.4.1__tar.gz → 2024.4.8__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {parsl-2024.4.1/parsl.egg-info → parsl-2024.4.8}/PKG-INFO +2 -2
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/dataflow/dflow.py +13 -23
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/status_handling.py +1 -8
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/jobs/job_status_poller.py +19 -5
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/jobs/strategy.py +10 -6
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/remote.py +2 -1
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/version.py +1 -1
- {parsl-2024.4.1 → parsl-2024.4.8/parsl.egg-info}/PKG-INFO +2 -2
- {parsl-2024.4.1 → parsl-2024.4.8}/LICENSE +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/MANIFEST.in +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/README.rst +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/addresses.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/app/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/app/app.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/app/bash.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/app/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/app/futures.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/app/python.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/benchmark/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/benchmark/perf.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/channels/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/channels/base.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/channels/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/channels/local/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/channels/local/local.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/channels/oauth_ssh/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/channels/oauth_ssh/oauth_ssh.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/channels/ssh/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/channels/ssh/ssh.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/channels/ssh_il/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/channels/ssh_il/ssh_il.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/concurrent/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/config.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/ASPIRE1.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/Azure.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/ad_hoc.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/bridges.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/cc_in2p3.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/ec2.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/expanse.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/frontera.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/htex_local.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/illinoiscluster.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/kubernetes.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/local_threads.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/midway.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/osg.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/polaris.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/stampede2.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/summit.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/toss3_llnl.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/vineex_local.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/configs/wqex_local.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/curvezmq.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/data_provider/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/data_provider/data_manager.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/data_provider/file_noop.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/data_provider/files.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/data_provider/ftp.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/data_provider/globus.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/data_provider/http.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/data_provider/rsync.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/data_provider/staging.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/dataflow/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/dataflow/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/dataflow/futures.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/dataflow/memoization.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/dataflow/rundirs.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/dataflow/states.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/dataflow/taskrecord.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/base.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/flux/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/flux/execute_parsl_task.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/flux/executor.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/flux/flux_instance_manager.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/executor.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/interchange.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/manager_record.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/monitoring_info.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/mpi_prefix_composer.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/mpi_resource_management.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/probe.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/process_worker_pool.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/zmq_pipes.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/radical/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/radical/executor.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/radical/rpex_master.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/radical/rpex_resources.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/radical/rpex_worker.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/taskvine/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/taskvine/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/taskvine/exec_parsl_function.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/taskvine/executor.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/taskvine/factory.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/taskvine/factory_config.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/taskvine/manager.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/taskvine/manager_config.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/taskvine/utils.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/threads.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/workqueue/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/workqueue/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/workqueue/exec_parsl_function.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/workqueue/executor.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/workqueue/parsl_coprocess.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/workqueue/parsl_coprocess_stub.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/jobs/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/jobs/error_handlers.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/jobs/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/jobs/states.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/launchers/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/launchers/base.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/launchers/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/launchers/launchers.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/log_utils.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/db_manager.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/message_type.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/monitoring.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/queries/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/queries/pandas.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/radios.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/router.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/types.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/app.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/models.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/plots/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/plots/default/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/plots/default/task_plots.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/plots/default/workflow_plots.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/plots/default/workflow_resource_plots.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/static/parsl-logo-white.png +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/static/parsl-monitor.css +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/templates/app.html +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/templates/dag.html +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/templates/error.html +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/templates/layout.html +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/templates/resource_usage.html +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/templates/task.html +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/templates/workflow.html +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/templates/workflows_summary.html +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/utils.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/version.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/views.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/multiprocessing.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/process_loggers.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/ad_hoc/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/ad_hoc/ad_hoc.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/aws/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/aws/aws.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/aws/template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/azure/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/azure/azure.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/azure/template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/base.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/cluster_provider.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/cobalt/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/cobalt/cobalt.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/cobalt/template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/condor/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/condor/condor.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/condor/template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/googlecloud/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/googlecloud/googlecloud.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/grid_engine/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/grid_engine/grid_engine.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/grid_engine/template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/kubernetes/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/kubernetes/kube.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/kubernetes/template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/local/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/local/local.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/lsf/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/lsf/lsf.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/lsf/template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/pbspro/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/pbspro/pbspro.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/pbspro/template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/slurm/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/slurm/slurm.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/slurm/template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/torque/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/torque/template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/providers/torque/torque.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/py.typed +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/serialize/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/serialize/base.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/serialize/concretes.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/serialize/errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/serialize/facade.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/serialize/proxystore.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/callables_helper.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/ad_hoc_cluster_htex.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/azure_single_node.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/bluewaters.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/bridges.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/cc_in2p3.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/comet.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/cooley_htex.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/ec2_single_node.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/ec2_spot.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/frontera.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/htex_ad_hoc_cluster.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/htex_local.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/htex_local_alternate.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/htex_local_intask_staging.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/htex_local_rsync_staging.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_adhoc.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_radical.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_radical_mpi.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_threads.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_threads_checkpoint.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_threads_checkpoint_dfk_exit.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_threads_checkpoint_periodic.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_threads_checkpoint_task_exit.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_threads_ftp_in_task.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_threads_globus.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_threads_http_in_task.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_threads_monitoring.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/local_threads_no_cache.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/midway.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/nscc_singapore.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/osg_htex.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/petrelkube.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/summit.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/swan_htex.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/taskvine_ex.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/theta.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/user_opts.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/configs/workqueue_ex.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/conftest.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/latency.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_apps/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_channels/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_channels/test_channels.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_channels/test_local_channel.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_channels/test_scp_1.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_channels/test_ssh_1.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_channels/test_ssh_errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_channels/test_ssh_file_transport.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_channels/test_ssh_interactive.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_parsl_load_default_config.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_stress/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_stress/test_python_simple.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/integration/test_stress/test_python_threads.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/manual_tests/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/manual_tests/htex_local.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/manual_tests/test_ad_hoc_htex.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/manual_tests/test_basic.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/manual_tests/test_fan_in_out_htex_remote.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/manual_tests/test_log_filter.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/manual_tests/test_memory_limits.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/manual_tests/test_oauth_ssh.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/manual_tests/test_regression_220.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/manual_tests/test_udp_simple.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/manual_tests/test_worker_count.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/scaling_tests/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/scaling_tests/htex_local.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/scaling_tests/local_threads.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/scaling_tests/test_scale.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/scaling_tests/vineex_condor.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/scaling_tests/vineex_local.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/scaling_tests/wqex_condor.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/scaling_tests/wqex_local.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/site_tests/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/site_tests/site_config_selector.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/site_tests/test_provider.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/site_tests/test_site.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/sites/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/sites/test_affinity.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/sites/test_concurrent.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/sites/test_dynamic_executor.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/sites/test_ec2.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/sites/test_launchers.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/sites/test_local_adhoc.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/sites/test_mpi/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/sites/test_worker_info.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_aalst_patterns.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/test_apptimeout.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/test_basic.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/test_error_codes.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/test_keyword_overlaps.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/test_kwarg_storage.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/test_memoize.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/test_memoize_ignore_args.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/test_memoize_ignore_args_regr.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/test_multiline.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/test_pipeline.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_bash_apps/test_stdout.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_callables.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_channels/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_channels/test_large_output.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_checkpointing/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_checkpointing/test_periodic.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_checkpointing/test_python_checkpoint_1.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_checkpointing/test_python_checkpoint_2.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_checkpointing/test_python_checkpoint_3.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_checkpointing/test_regression_232.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_checkpointing/test_regression_233.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_checkpointing/test_regression_239.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_checkpointing/test_task_exit.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_curvezmq.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_docs/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_docs/test_from_slides.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_docs/test_kwargs.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_docs/test_tutorial_1.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_docs/test_workflow1.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_docs/test_workflow2.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_docs/test_workflow4.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_error_handling/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_error_handling/test_fail.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_error_handling/test_python_walltime.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_error_handling/test_rand_fail.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_error_handling/test_resource_spec.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_error_handling/test_retries.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_error_handling/test_retry_handler.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_error_handling/test_retry_handler_failure.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_error_handling/test_serialization_fail.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_error_handling/test_wrap_with_logs.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_flowcontrol/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_flux.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/test_basic.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/test_connected_blocks.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/test_cpu_affinity_explicit.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/test_disconnected_blocks.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/test_drain.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/test_htex.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/test_manager_failure.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/test_missing_worker.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/test_multiple_disconnected_blocks.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/test_worker_failure.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_htex/test_zmq_binding.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_monitoring/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_monitoring/test_app_names.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_monitoring/test_basic.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_monitoring/test_db_locks.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_monitoring/test_fuzz_zmq.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_monitoring/test_htex_init_blocks_vs_monitoring.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_monitoring/test_incomplete_futures.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_monitoring/test_memoization_representation.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_monitoring/test_viz_colouring.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_mpi_apps/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_mpi_apps/test_bad_mpi_config.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_mpi_apps/test_mpi_mode_disabled.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_mpi_apps/test_mpi_mode_enabled.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_mpi_apps/test_mpi_prefix.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_mpi_apps/test_mpi_scheduler.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_mpi_apps/test_resource_spec.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_providers/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_providers/test_cobalt_deprecation_warning.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_providers/test_local_provider.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_providers/test_pbspro_template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_providers/test_slurm_instantiate.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_providers/test_slurm_template.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_providers/test_submiterror_deprecation.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_arg_input_types.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_basic.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_context_manager.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_dep_standard_futures.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_dependencies.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_depfail_propagation.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_fail.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_fibonacci_iterative.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_fibonacci_recursive.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_futures.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_garbage_collect.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_import_fail.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_join.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_lifted.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_mapred.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_memoize_1.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_memoize_2.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_memoize_4.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_memoize_bad_id_for_memo.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_memoize_ignore_args.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_memoize_joinapp.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_outputs.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_overview.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_pipeline.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_simple.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_timeout.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_python_apps/test_type5.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_radical/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_radical/test_mpi_funcs.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_regression/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_regression/test_1480.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_regression/test_1606_wait_for_current_tasks.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_regression/test_1653.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_regression/test_221.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_regression/test_226.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_regression/test_2652.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_regression/test_69a.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_regression/test_854.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_regression/test_97_parallelism_0.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_regression/test_98.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_scaling/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_scaling/test_block_error_handler.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_scaling/test_regression_1621.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_scaling/test_scale_down.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_scaling/test_scale_down_htex_auto_scale.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_scaling/test_shutdown_scalein.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_serialization/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_serialization/test_2555_caching_deserializer.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_serialization/test_basic.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_serialization/test_htex_code_cache.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_serialization/test_pack_resource_spec.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_serialization/test_proxystore_configured.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_serialization/test_proxystore_impl.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_shutdown/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_shutdown/test_kill_monitoring.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/staging_provider.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_1316.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_docs_1.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_docs_2.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_elaborate_noop_file.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_file.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_file_apps.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_file_staging.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_output_chain_filenames.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_staging_ftp.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_staging_ftp_in_task.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_staging_globus.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_staging/test_staging_https.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_summary.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_thread_parallelism.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_threads/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_threads/test_configs.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_threads/test_lazy_errors.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_utils/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/test_utils/test_representation_mixin.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/tests/utils.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/usage_tracking/__init__.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/usage_tracking/usage.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl/utils.py +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl.egg-info/SOURCES.txt +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl.egg-info/dependency_links.txt +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl.egg-info/entry_points.txt +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl.egg-info/requires.txt +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/parsl.egg-info/top_level.txt +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/requirements.txt +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/setup.cfg +0 -0
- {parsl-2024.4.1 → parsl-2024.4.8}/setup.py +0 -0
@@ -1,9 +1,9 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: parsl
|
3
|
-
Version: 2024.4.
|
3
|
+
Version: 2024.4.8
|
4
4
|
Summary: Simple data dependent workflows in Python
|
5
5
|
Home-page: https://github.com/Parsl/parsl
|
6
|
-
Download-URL: https://github.com/Parsl/parsl/archive/2024.04.
|
6
|
+
Download-URL: https://github.com/Parsl/parsl/archive/2024.04.08.tar.gz
|
7
7
|
Author: The Parsl Team
|
8
8
|
Author-email: parsl@googlegroups.com
|
9
9
|
License: Apache 2.0
|
@@ -714,14 +714,18 @@ class DataFlowKernel:
|
|
714
714
|
|
715
715
|
if self.monitoring is not None and self.monitoring.resource_monitoring_enabled:
|
716
716
|
wrapper_logging_level = logging.DEBUG if self.monitoring.monitoring_debug else logging.INFO
|
717
|
-
(function, args, kwargs) = monitor_wrapper(function,
|
718
|
-
|
719
|
-
|
720
|
-
|
721
|
-
|
722
|
-
|
723
|
-
|
724
|
-
|
717
|
+
(function, args, kwargs) = monitor_wrapper(f=function,
|
718
|
+
args=args,
|
719
|
+
kwargs=kwargs,
|
720
|
+
x_try_id=try_id,
|
721
|
+
x_task_id=task_id,
|
722
|
+
monitoring_hub_url=self.monitoring.monitoring_hub_url,
|
723
|
+
run_id=self.run_id,
|
724
|
+
logging_level=wrapper_logging_level,
|
725
|
+
sleep_dur=self.monitoring.resource_monitoring_interval,
|
726
|
+
radio_mode=executor.radio_mode,
|
727
|
+
monitor_resources=executor.monitor_resources(),
|
728
|
+
run_dir=self.run_dir)
|
725
729
|
|
726
730
|
with self.submitter_lock:
|
727
731
|
exec_fu = executor.submit(function, task_record['resource_specification'], *args, **kwargs)
|
@@ -1214,21 +1218,7 @@ class DataFlowKernel:
|
|
1214
1218
|
self.job_status_poller.close()
|
1215
1219
|
logger.info("Terminated job status poller")
|
1216
1220
|
|
1217
|
-
logger.info("
|
1218
|
-
|
1219
|
-
for ef in self.job_status_poller._executor_facades:
|
1220
|
-
if not ef.executor.bad_state_is_set:
|
1221
|
-
logger.info(f"Scaling in executor {ef.executor.label}")
|
1222
|
-
|
1223
|
-
# this code needs to be at least as many blocks as need
|
1224
|
-
# cancelling, but it is safe to be more, as the scaling
|
1225
|
-
# code will cope with being asked to cancel more blocks
|
1226
|
-
# than exist.
|
1227
|
-
block_count = len(ef.status)
|
1228
|
-
ef.scale_in(block_count)
|
1229
|
-
|
1230
|
-
else: # and bad_state_is_set
|
1231
|
-
logger.warning(f"Not scaling in executor {ef.executor.label} because it is in bad state")
|
1221
|
+
logger.info("Shutting down executors")
|
1232
1222
|
|
1233
1223
|
for executor in self.executors.values():
|
1234
1224
|
logger.info(f"Shutting down executor {executor.label}")
|
@@ -102,12 +102,6 @@ class BlockProviderExecutor(ParslExecutor):
|
|
102
102
|
else:
|
103
103
|
return self._provider.status_polling_interval
|
104
104
|
|
105
|
-
def _fail_job_async(self, block_id: str, message: str):
|
106
|
-
"""Marks a job that has failed to start but would not otherwise be included in status()
|
107
|
-
as failed and report it in status()
|
108
|
-
"""
|
109
|
-
self._simulated_status[block_id] = JobStatus(JobState.FAILED, message)
|
110
|
-
|
111
105
|
@abstractproperty
|
112
106
|
def outstanding(self) -> int:
|
113
107
|
"""This should return the number of tasks that the executor has been given to run (waiting to run, and running now)"""
|
@@ -198,8 +192,7 @@ class BlockProviderExecutor(ParslExecutor):
|
|
198
192
|
self.job_ids_to_block[job_id] = block_id
|
199
193
|
block_ids.append(block_id)
|
200
194
|
except Exception as ex:
|
201
|
-
self.
|
202
|
-
"Failed to start block {}: {}".format(block_id, ex))
|
195
|
+
self._simulated_status[block_id] = JobStatus(JobState.FAILED, "Failed to start block {}: {}".format(block_id, ex))
|
203
196
|
return block_ids
|
204
197
|
|
205
198
|
@abstractmethod
|
@@ -19,18 +19,16 @@ logger = logging.getLogger(__name__)
|
|
19
19
|
class PolledExecutorFacade:
|
20
20
|
def __init__(self, executor: BlockProviderExecutor, dfk: Optional["parsl.dataflow.dflow.DataFlowKernel"] = None):
|
21
21
|
self._executor = executor
|
22
|
-
self._dfk = dfk
|
23
22
|
self._interval = executor.status_polling_interval
|
24
23
|
self._last_poll_time = 0.0
|
25
24
|
self._status = {} # type: Dict[str, JobStatus]
|
26
|
-
self.first = True
|
27
25
|
|
28
26
|
# Create a ZMQ channel to send poll status to monitoring
|
29
27
|
self.monitoring_enabled = False
|
30
|
-
if
|
28
|
+
if dfk and dfk.monitoring is not None:
|
31
29
|
self.monitoring_enabled = True
|
32
|
-
hub_address =
|
33
|
-
hub_port =
|
30
|
+
hub_address = dfk.hub_address
|
31
|
+
hub_port = dfk.hub_zmq_port
|
34
32
|
context = zmq.Context()
|
35
33
|
self.hub_channel = context.socket(zmq.DEALER)
|
36
34
|
self.hub_channel.set_hwm(0)
|
@@ -136,3 +134,19 @@ class JobStatusPoller(Timer):
|
|
136
134
|
logger.debug("Adding executor {}".format(executor.label))
|
137
135
|
self._executor_facades.append(PolledExecutorFacade(executor, self.dfk))
|
138
136
|
self._strategy.add_executors(executors)
|
137
|
+
|
138
|
+
def close(self):
|
139
|
+
super().close()
|
140
|
+
for ef in self._executor_facades:
|
141
|
+
if not ef.executor.bad_state_is_set:
|
142
|
+
logger.info(f"Scaling in executor {ef.executor.label}")
|
143
|
+
|
144
|
+
# this code needs to be at least as many blocks as need
|
145
|
+
# cancelling, but it is safe to be more, as the scaling
|
146
|
+
# code will cope with being asked to cancel more blocks
|
147
|
+
# than exist.
|
148
|
+
block_count = len(ef.status)
|
149
|
+
ef.scale_in(block_count)
|
150
|
+
|
151
|
+
else: # and bad_state_is_set
|
152
|
+
logger.warning(f"Not scaling in executor {ef.executor.label} because it is in bad state")
|
@@ -26,6 +26,10 @@ class ExecutorState(TypedDict):
|
|
26
26
|
If the executor is not idle, then None.
|
27
27
|
"""
|
28
28
|
|
29
|
+
first: bool
|
30
|
+
"""True if this executor has not yet had a strategy poll.
|
31
|
+
"""
|
32
|
+
|
29
33
|
|
30
34
|
class Strategy:
|
31
35
|
"""Scaling strategy.
|
@@ -144,17 +148,17 @@ class Strategy:
|
|
144
148
|
|
145
149
|
def add_executors(self, executors: Sequence[ParslExecutor]) -> None:
|
146
150
|
for executor in executors:
|
147
|
-
self.executors[executor.label] = {'idle_since': None}
|
151
|
+
self.executors[executor.label] = {'idle_since': None, 'first': True}
|
148
152
|
|
149
153
|
def _strategy_init_only(self, executor_facades: List[jsp.PolledExecutorFacade]) -> None:
|
150
154
|
"""Scale up to init_blocks at the start, then nothing more.
|
151
155
|
"""
|
152
156
|
for ef in executor_facades:
|
153
|
-
|
154
|
-
|
157
|
+
executor = ef.executor
|
158
|
+
if self.executors[executor.label]['first']:
|
155
159
|
logger.debug(f"strategy_init_only: scaling out {executor.provider.init_blocks} initial blocks for {executor.label}")
|
156
160
|
ef.scale_out(executor.provider.init_blocks)
|
157
|
-
|
161
|
+
self.executors[executor.label]['first'] = False
|
158
162
|
else:
|
159
163
|
logger.debug("strategy_init_only: doing nothing")
|
160
164
|
|
@@ -190,11 +194,11 @@ class Strategy:
|
|
190
194
|
continue
|
191
195
|
logger.debug(f"Strategizing for executor {label}")
|
192
196
|
|
193
|
-
if
|
197
|
+
if self.executors[label]['first']:
|
194
198
|
executor = ef.executor
|
195
199
|
logger.debug(f"Scaling out {executor.provider.init_blocks} initial blocks for {label}")
|
196
200
|
ef.scale_out(executor.provider.init_blocks)
|
197
|
-
|
201
|
+
self.executors[label]['first'] = False
|
198
202
|
|
199
203
|
# Tasks that are either pending completion
|
200
204
|
active_tasks = executor.outstanding
|
@@ -15,7 +15,8 @@ from typing import Any, Callable, Dict, List, Sequence, Tuple
|
|
15
15
|
logger = logging.getLogger(__name__)
|
16
16
|
|
17
17
|
|
18
|
-
def monitor_wrapper(
|
18
|
+
def monitor_wrapper(*,
|
19
|
+
f: Any, # per app
|
19
20
|
args: Sequence, # per invocation
|
20
21
|
kwargs: Dict, # per invocation
|
21
22
|
x_try_id: int, # per invocation
|
@@ -1,9 +1,9 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: parsl
|
3
|
-
Version: 2024.4.
|
3
|
+
Version: 2024.4.8
|
4
4
|
Summary: Simple data dependent workflows in Python
|
5
5
|
Home-page: https://github.com/Parsl/parsl
|
6
|
-
Download-URL: https://github.com/Parsl/parsl/archive/2024.04.
|
6
|
+
Download-URL: https://github.com/Parsl/parsl/archive/2024.04.08.tar.gz
|
7
7
|
Author: The Parsl Team
|
8
8
|
Author-email: parsl@googlegroups.com
|
9
9
|
License: Apache 2.0
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{parsl-2024.4.1 → parsl-2024.4.8}/parsl/executors/high_throughput/mpi_resource_management.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/plots/default/task_plots.py
RENAMED
File without changes
|
{parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/plots/default/workflow_plots.py
RENAMED
File without changes
|
File without changes
|
{parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/static/parsl-logo-white.png
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/templates/resource_usage.html
RENAMED
File without changes
|
File without changes
|
File without changes
|
{parsl-2024.4.1 → parsl-2024.4.8}/parsl/monitoring/visualization/templates/workflows_summary.html
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|