Skip to content

Commit

Permalink
Merge latest master into desc
Browse files Browse the repository at this point in the history
  • Loading branch information
benclifford committed Oct 26, 2023
2 parents 4c65f3f + cc52e97 commit 0d23d4e
Show file tree
Hide file tree
Showing 33 changed files with 827 additions and 295 deletions.
8 changes: 4 additions & 4 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ CCTOOLS_INSTALL := /tmp/cctools
MPICH=mpich
OPENMPI=openmpi
export PATH := $(CCTOOLS_INSTALL)/bin/:$(PATH)
export CCTOOLS_VERSION=7.7.0
export CCTOOLS_VERSION=7.7.1
export HYDRA_LAUNCHER=fork
export OMPI_MCA_rmaps_base_oversubscribe=yes
MPI=$(MPICH)
Expand Down Expand Up @@ -79,9 +79,9 @@ workqueue_mon_test: $(WORKQUEUE_INSTALL) ## run all tests with workqueue_ex con


.PHONY: config_local_test
config_local_test: # TODO: this doesn't check workqueue is installed -- because that's done in a different 'make' run, and there is nothing to cache that fact between runs in the current make impl (eg looking for a particular file to be there...)
pip3 install ".[monitoring,proxystore]"
PYTHONPATH=/tmp/cctools/lib/python3.8/site-packages pytest parsl/tests/ -k "not cleannet and not site" --config local --random-order
config_local_test:
pip3 install ".[monitoring,visualization,proxystore]"
PYTHONPATH=/tmp/cctools/lib/python3.8/site-packages pytest parsl/tests/ -k "not cleannet and not site" --config local --random-order --durations 10

.PHONY: site_test
site_test:
Expand Down
16 changes: 8 additions & 8 deletions docs/devguide/changelog.rst
Original file line number Diff line number Diff line change
Expand Up @@ -289,7 +289,7 @@ New Functionality
.. code-block:: python
@bash_app
def cat(inputs=[], outputs=[]):
def cat(inputs=(), outputs=()):
return 'cat {} > {}'.format(inputs[0], outputs[0])
concat = cat(inputs=['hello-0.txt'],
Expand All @@ -302,7 +302,7 @@ New Functionality
from parsl import File
@bash_app
def cat(inputs=[], outputs=[]):
def cat(inputs=(), outputs=()):
return 'cat {} > {}'.format(inputs[0].filepath, outputs[0].filepath)
concat = cat(inputs=[File('hello-0.txt')],
Expand All @@ -316,7 +316,7 @@ New Functionality
from parsl import File
@bash_app
def cat(inputs=[], outputs=[]):
def cat(inputs=(), outputs=()):
return 'cat {} > {}'.format(inputs[0].filepath, outputs[0].filepath)
Expand Down Expand Up @@ -397,16 +397,16 @@ New Functionality
# The following example worked until v0.8.0
@bash_app
def cat(inputs=[], outputs=[]):
def cat(inputs=(), outputs=()):
return 'cat {inputs[0]} > {outputs[0]}' # <-- Relies on Parsl auto formatting the string
# Following are two mechanisms that will work going forward from v0.9.0
@bash_app
def cat(inputs=[], outputs=[]):
def cat(inputs=(), outputs=()):
return 'cat {} > {}'.format(inputs[0], outputs[0]) # <-- Use str.format method
@bash_app
def cat(inputs=[], outputs=[]):
def cat(inputs=(), outputs=()):
return f'cat {inputs[0]} > {outputs[0]}' # <-- OR use f-strings introduced in Python3.6
Expand Down Expand Up @@ -510,12 +510,12 @@ New Functionality
# Old style: " ".join(inputs) is legal since inputs will behave like a list of strings
@bash_app
def concat(inputs=[], outputs=[], stdout="stdout.txt", stderr='stderr.txt'):
def concat(inputs=(), outputs=(), stdout="stdout.txt", stderr='stderr.txt'):
return "cat {0} > {1}".format(" ".join(inputs), outputs[0])
# New style:
@bash_app
def concat(inputs=[], outputs=[], stdout="stdout.txt", stderr='stderr.txt'):
def concat(inputs=(), outputs=(), stdout="stdout.txt", stderr='stderr.txt'):
return "cat {0} > {1}".format(" ".join(list(map(str,inputs))), outputs[0])
* Cleaner user app file log management.
Expand Down
2 changes: 1 addition & 1 deletion docs/faq.rst
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ How can I make an App dependent on multiple inputs?
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

You can pass any number of futures in to a single App either as positional arguments
or as a list of futures via the special keyword ``inputs=[]``.
or as a list of futures via the special keyword ``inputs=()``.
The App will wait for all inputs to be satisfied before execution.


Expand Down
3 changes: 3 additions & 0 deletions docs/teaching_scripts/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# Example Scripts

Scripts which illustrate example from the documentation that do not run well as part of the pytest
83 changes: 83 additions & 0 deletions docs/teaching_scripts/test_apps.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
"""Tests documentation related to building apps. Must reside outside the Parsl library to be effective"""
from typing import List, Union

import numpy as np

from parsl import python_app, HighThroughputExecutor, Config
import parsl

parsl.load(Config(executors=[HighThroughputExecutor(label='htex_spawn', max_workers=1, start_method='spawn', address='127.0.0.1')]))


# Part 1: Explain imports
# BAD: Assumes library has been imported
@python_app(executors=['htex_spawn'])
def bad_imports(x: Union[List[float], np.ndarray], m: float, b: float):
return np.multiply(x, m) + b


# GOOD: Imports libraries itself
@python_app(executors=['htex_spawn'])
def good_imports(x: Union[List[float], 'np.ndarray'], m: float, b: float):
import numpy as np
return np.multiply(x, m) + b


future = bad_imports([1.], 1, 0)

try:
future.result()
raise ValueError()
except NameError as e:
print('Failed, as expected. Error:', e)

future = good_imports([1.], 1, 0)
print(f'Passed, as expected: {future.result()}')

# Part 2: Test other types of globals
# BAD: Uses global variables
global_var = {'a': 0}


@python_app
def bad_global(string: str, character: str = 'a'):
global_var[character] += string.count(character) # `global_var` will not be accessible


# GOOD
@python_app
def good_global(string: str, character: str = 'a'):
return {character: string.count(character)}


try:
bad_global('parsl').result()
except NameError as e:
print(f'Failed, as expected: {e}')

for ch, co in good_global('parsl', 'a').result().items():
global_var[ch] += co


# Part 3: Mutable args

# BAD: Assumes changes to inputs will be communicated
@python_app
def append_to_list(input_list: list, new_val):
input_list.append(new_val)


mutable_arg = []
append_to_list(mutable_arg, 1).result()
assert mutable_arg == [], 'The list _was_changed'


# GOOD: Changes to inputs are returned
@python_app
def append_to_list(input_list: list, new_val) -> list:
input_list.append(new_val)
return input_list


mutable_arg = append_to_list(mutable_arg, 1).result()
assert mutable_arg == [1]
Loading

0 comments on commit 0d23d4e

Please sign in to comment.