Feat: reactivate output in task
This commit is contained in:
parent
211cee2f4f
commit
4d76dc8992
@ -11,47 +11,54 @@ class Task:
|
||||
action: str
|
||||
args: dict
|
||||
deps: list
|
||||
output: str
|
||||
|
||||
|
||||
def generate(template: str, meta: dict):
|
||||
def generate(template: str, meta: dict, output: str):
|
||||
"""Create a task to generate a subject"""
|
||||
return Task(
|
||||
action="GENERATE",
|
||||
args=meta,
|
||||
deps=[template],
|
||||
output=output,
|
||||
)
|
||||
|
||||
|
||||
def activate_corr_on(src: str):
|
||||
def activate_corr_on(src: str, output: str):
|
||||
"""Create a task to activate correction for src"""
|
||||
return Task(
|
||||
action="ACTIVATE_CORR",
|
||||
args={},
|
||||
deps=[src],
|
||||
output=output,
|
||||
)
|
||||
|
||||
|
||||
def compile_pdf(src: str):
|
||||
def compile_pdf(src: str, output: str):
|
||||
"""Create a task to compile src"""
|
||||
return Task(
|
||||
action="COMPILE",
|
||||
args={},
|
||||
deps=[src],
|
||||
output=output,
|
||||
)
|
||||
|
||||
def join_pdfs(pdfs: list):
|
||||
""" Create task to join pdf together """
|
||||
|
||||
def join_pdfs(pdfs: list, output: str):
|
||||
"""Create task to join pdf together"""
|
||||
return Task(
|
||||
action="JOIN",
|
||||
args={},
|
||||
deps=pdfs,
|
||||
output=output,
|
||||
)
|
||||
|
||||
|
||||
def clean(files: list):
|
||||
""" Create task to clean files"""
|
||||
"""Create task to clean files"""
|
||||
return Task(
|
||||
action="CLEAN",
|
||||
args={},
|
||||
deps=files,
|
||||
output=None,
|
||||
)
|
||||
|
@ -20,7 +20,7 @@ class Scheduler:
|
||||
|
||||
def dispatch(self, task):
|
||||
"""Do a task"""
|
||||
ans = self.actions[task.action](task.deps, task.args)
|
||||
ans = self.actions[task.action](task.deps, task.args, task.output)
|
||||
return ans
|
||||
|
||||
def __iter__(self):
|
||||
@ -47,7 +47,7 @@ class Scheduler:
|
||||
|
||||
self.append(undoable)
|
||||
ans = self.dispatch(task)
|
||||
self._done.append(ans)
|
||||
self._done.append(task.output)
|
||||
return ans
|
||||
|
||||
def run(self):
|
||||
|
@ -3,7 +3,7 @@ from bopytex.planner import activate_corr_on, clean, compile_pdf, generate, join
|
||||
|
||||
def test_build_task_generate():
|
||||
template = "tpl_source.tex"
|
||||
task = generate(template, {"subject": "01"})
|
||||
task = generate(template, {"subject": "01"}, output="source.tex")
|
||||
assert task.action == "GENERATE"
|
||||
assert task.args == {"subject": "01"}
|
||||
assert task.deps == [template]
|
||||
@ -11,7 +11,7 @@ def test_build_task_generate():
|
||||
|
||||
def test_build_task_activate_corr_on():
|
||||
src = "source.tex"
|
||||
task = activate_corr_on(src)
|
||||
task = activate_corr_on(src, output="corr_source.tex")
|
||||
assert task.action == "ACTIVATE_CORR"
|
||||
assert task.args == {}
|
||||
assert task.deps == [src]
|
||||
@ -19,7 +19,7 @@ def test_build_task_activate_corr_on():
|
||||
|
||||
def test_build_task_compile():
|
||||
src = "source.tex"
|
||||
task = compile_pdf(src)
|
||||
task = compile_pdf(src, output="source.pdf")
|
||||
assert task.action == "COMPILE"
|
||||
assert task.args == {}
|
||||
assert task.deps == [src]
|
||||
@ -27,13 +27,13 @@ def test_build_task_compile():
|
||||
|
||||
def test_build_task_join():
|
||||
pdfs = [f"{i}_source.pdf" for i in range(3)]
|
||||
task = join_pdfs(pdfs)
|
||||
task = join_pdfs(pdfs, output="joined.pdf")
|
||||
assert task.action == "JOIN"
|
||||
assert task.args == {}
|
||||
assert task.deps == pdfs
|
||||
|
||||
|
||||
def test_build_task_compile():
|
||||
def test_build_task_clean():
|
||||
files = ["source.aux", "source.log"]
|
||||
task = clean(files)
|
||||
assert task.action == "CLEAN"
|
||||
|
@ -3,91 +3,91 @@ from bopytex.scheduler import Scheduler
|
||||
import pytest
|
||||
|
||||
|
||||
def action_done(deps, args, output):
|
||||
return f"{deps} - {args} - {output} - done"
|
||||
|
||||
|
||||
actions = {"DO": action_done}
|
||||
|
||||
|
||||
def test_schedule_append():
|
||||
actions = {"DO": lambda deps, args: "done"}
|
||||
scheduler = Scheduler(actions)
|
||||
tasks = [Task(action="DO", args={}, deps=[])]
|
||||
tasks = [Task(action="DO", args={}, deps=[], output="end")]
|
||||
scheduler.append(tasks)
|
||||
assert scheduler.tasks == tasks
|
||||
|
||||
|
||||
def test_schedule_dispatch():
|
||||
actions = {"DO": lambda deps, args: "done"}
|
||||
scheduler = Scheduler(actions)
|
||||
task = Task(action="DO", args={}, deps=[])
|
||||
task = Task(action="DO", args={}, deps=[], output="end")
|
||||
result = scheduler.dispatch(task)
|
||||
assert result == "done"
|
||||
assert result == "[] - {} - end - done"
|
||||
|
||||
|
||||
def test_schedule_one_task():
|
||||
actions = {"DO": lambda deps, args: "done"}
|
||||
scheduler = Scheduler(actions)
|
||||
scheduler.append([Task(action="DO", args={}, deps=[])])
|
||||
scheduler.append([Task(action="DO", args={}, deps=[], output="end")])
|
||||
result = scheduler.next()
|
||||
assert result == "done"
|
||||
assert result == "[] - {} - end - done"
|
||||
assert scheduler.tasks == []
|
||||
assert scheduler.done == ["done"]
|
||||
assert scheduler.done == ["end"]
|
||||
|
||||
|
||||
def test_schedule_one_task_with_args():
|
||||
actions = {"DO": lambda deps, args: f"{args['task']} done"}
|
||||
scheduler = Scheduler(actions)
|
||||
scheduler.append([Task(action="DO", args={"task": "one"}, deps=[])])
|
||||
scheduler.append([Task(action="DO", args={"task": "one"}, deps=[], output="one")])
|
||||
result = scheduler.next()
|
||||
assert result == "one done"
|
||||
assert result == "[] - {'task': 'one'} - one - done"
|
||||
assert scheduler.tasks == []
|
||||
assert scheduler.done == ["one done"]
|
||||
assert scheduler.done == ["one"]
|
||||
|
||||
|
||||
def test_schedule_multiple_tasks():
|
||||
actions = {"DO": lambda deps, args: f"{args['task']} done"}
|
||||
scheduler = Scheduler(actions)
|
||||
t1 = Task(action="DO", args={"task": "one"}, deps=[])
|
||||
t2 = Task(action="DO", args={"task": "two"}, deps=[])
|
||||
t3 = Task(action="DO", args={"task": "three"}, deps=[])
|
||||
t1 = Task(action="DO", args={"task": "one"}, deps=[], output="one")
|
||||
t2 = Task(action="DO", args={"task": "two"}, deps=[], output="two")
|
||||
t3 = Task(action="DO", args={"task": "three"}, deps=[], output="three")
|
||||
scheduler.append([t1, t2, t3])
|
||||
result = scheduler.next()
|
||||
assert result == "one done"
|
||||
assert result == "[] - {'task': 'one'} - one - done"
|
||||
assert scheduler.tasks == [t2, t3]
|
||||
assert scheduler.done == ["one done"]
|
||||
assert scheduler.done == ["one"]
|
||||
|
||||
result = scheduler.next()
|
||||
assert result == "two done"
|
||||
assert result == "[] - {'task': 'two'} - two - done"
|
||||
assert scheduler.tasks == [t3]
|
||||
assert scheduler.done == ["one done", "two done"]
|
||||
assert scheduler.done == ["one", "two"]
|
||||
|
||||
result = scheduler.next()
|
||||
assert result == "three done"
|
||||
assert result == "[] - {'task': 'three'} - three - done"
|
||||
assert scheduler.tasks == []
|
||||
assert scheduler.done == ["one done", "two done", "three done"]
|
||||
assert scheduler.done == ["one", "two", "three"]
|
||||
|
||||
|
||||
def test_schedule_multiple_tasks_with_dependencies():
|
||||
actions = {"DO": lambda deps, args: f"{args['task']} done"}
|
||||
scheduler = Scheduler(actions)
|
||||
t1 = Task(action="DO", args={"task": "one"}, deps=["three done"])
|
||||
t2 = Task(action="DO", args={"task": "two"}, deps=["one done"])
|
||||
t3 = Task(action="DO", args={"task": "three"}, deps=[])
|
||||
t1 = Task(action="DO", args={"task": "one"}, deps=["three"], output="one")
|
||||
t2 = Task(action="DO", args={"task": "two"}, deps=["one"], output="two")
|
||||
t3 = Task(action="DO", args={"task": "three"}, deps=[], output="three")
|
||||
scheduler.append([t1, t2, t3])
|
||||
|
||||
result = scheduler.next()
|
||||
assert result == "three done"
|
||||
assert result == "[] - {'task': 'three'} - three - done"
|
||||
assert scheduler.tasks == [t1, t2]
|
||||
assert scheduler.done == ["three done"]
|
||||
assert scheduler.done == ["three"]
|
||||
|
||||
result = scheduler.next()
|
||||
assert result == "one done"
|
||||
assert result == "['three'] - {'task': 'one'} - one - done"
|
||||
assert scheduler.tasks == [t2]
|
||||
assert scheduler.done == ["three done", "one done"]
|
||||
assert scheduler.done == ["three", "one"]
|
||||
|
||||
result = scheduler.next()
|
||||
assert result == "two done"
|
||||
assert result == "['one'] - {'task': 'two'} - two - done"
|
||||
assert scheduler.tasks == []
|
||||
assert scheduler.done == ["three done", "one done", "two done"]
|
||||
assert scheduler.done == ["three", "one", "two"]
|
||||
|
||||
|
||||
def test_schedule_empty_task():
|
||||
actions = {"DO": lambda deps, args: f"{args['task']} done"}
|
||||
scheduler = Scheduler(actions)
|
||||
scheduler.append([])
|
||||
with pytest.raises(StopIteration):
|
||||
@ -95,12 +95,10 @@ def test_schedule_empty_task():
|
||||
|
||||
|
||||
def test_schedule_multiple_tasks_with_undoable_dependencies():
|
||||
actions = {"DO": lambda deps, args: f"{args['task']} done"}
|
||||
scheduler = Scheduler(actions)
|
||||
t1 = Task(action="DO", args={"task": "one"}, deps=["three done"])
|
||||
t2 = Task(action="DO", args={"task": "two"}, deps=[])
|
||||
t1 = Task(action="DO", args={"task": "one"}, deps=["three"], output="one")
|
||||
t2 = Task(action="DO", args={"task": "two"}, deps=[], output="two")
|
||||
scheduler.append([t1, t2])
|
||||
scheduler.run()
|
||||
assert scheduler.tasks == [t1]
|
||||
assert scheduler.done == ["two done"]
|
||||
|
||||
assert scheduler.done == ["two"]
|
||||
|
Loading…
Reference in New Issue
Block a user