Skip to content

Commit

Permalink
update dependencies + minor touch to make it compatible with aiida-co…
Browse files Browse the repository at this point in the history
…re 2.6
  • Loading branch information
khsrali committed Aug 6, 2024
1 parent f3f6dac commit 65463a0
Show file tree
Hide file tree
Showing 4 changed files with 25 additions and 20 deletions.
8 changes: 4 additions & 4 deletions aiida_submission_controller/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@

from aiida import engine, orm
from aiida.common import NotExistent
from pydantic import BaseModel, validator
from pydantic import BaseModel, field_validator
from rich import print
from rich.console import Console
from rich.table import Table
Expand Down Expand Up @@ -56,12 +56,12 @@ class BaseSubmissionController(BaseModel):
unique_extra_keys: Optional[tuple] = None
"""Tuple of keys defined in the extras that uniquely define each process to be run."""

_validate_group_exists = validator("group_label", allow_reuse=True)(validate_group_exists)
_validate_group_exists = field_validator("group_label")(validate_group_exists)

@property
def group(self):
"""Return the AiiDA ORM Group instance that is managed by this class."""
return orm.Group.objects.get(label=self.group_label)
return orm.Group.collection.get(label=self.group_label)

def get_query(self, process_projections, only_active=False):
"""Return a QueryBuilder object to get all processes in the group associated to this.
Expand Down Expand Up @@ -236,7 +236,7 @@ def submit_new_batch(self, dry_run=False, sort=False, verbose=False):
else:
CMDLINE_LOGGER.report(f"Submitted work chain <{wc_node}> for extras <{workchain_extras}>.")

wc_node.set_extra_many(get_extras_dict(self.get_extra_unique_keys(), workchain_extras))
wc_node.base.extras.set_many(get_extras_dict(self.get_extra_unique_keys(), workchain_extras))
self.group.add_nodes([wc_node])
submitted[workchain_extras] = wc_node

Expand Down
6 changes: 3 additions & 3 deletions aiida_submission_controller/from_group.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
from typing import Optional

from aiida import orm
from pydantic import validator
from pydantic import field_validator

from .base import BaseSubmissionController, validate_group_exists

Expand All @@ -22,12 +22,12 @@ class FromGroupSubmissionController(BaseSubmissionController): # pylint: disabl
order_by: Optional[dict] = None
"""Ordering applied to the query of the nodes in the parent group."""

_validate_group_exists = validator("parent_group_label", allow_reuse=True)(validate_group_exists)
_validate_group_exists = field_validator("parent_group_label")(validate_group_exists)

@property
def parent_group(self):
"""Return the AiiDA ORM Group instance of the parent group."""
return orm.Group.objects.get(label=self.parent_group_label)
return orm.Group.collection.get(label=self.parent_group_label)

def get_parent_node_from_extras(self, extras_values):
"""Return the Node instance (in the parent group) from the (unique) extras identifying it."""
Expand Down
12 changes: 8 additions & 4 deletions examples/add_in_batches.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@
"""An example of a SubmissionController implementation to compute a 12x12 table of additions."""
import time

from aiida import orm
from aiida import load_profile, orm
from aiida.calculations.arithmetic.add import ArithmeticAddCalculation
from pydantic import validator
from pydantic import field_validator

from aiida_submission_controller import BaseSubmissionController

Expand All @@ -15,7 +15,7 @@ class AdditionTableSubmissionController(BaseSubmissionController):
code_label: str
"""Label of the `code.arithmetic.add` `Code`."""

@validator("code_label")
@field_validator("code_label")
def _check_code_plugin(cls, value):
plugin_type = orm.load_code(value).default_calc_job_plugin
if plugin_type == "core.arithmetic.add":
Expand Down Expand Up @@ -63,8 +63,9 @@ def main():
##
## verdi code setup -L add --on-computer --computer=localhost -P core.arithmetic.add --remote-abs-path=/bin/bash -n
# Create a controller
load_profile()

group, _ = orm.Group.objects.get_or_create(label="tests/addition_table")
group, _ = orm.Group.collection.get_or_create(label="tests/addition_table")

controller = AdditionTableSubmissionController(
code_label="add@localhost",
Expand Down Expand Up @@ -123,6 +124,9 @@ def main():

time.sleep(10)

if controller.num_to_run == 0:
break


if __name__ == "__main__":
main()
19 changes: 10 additions & 9 deletions pyproject.toml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
[build-system]
requires = ["flit_core>=3.4,<4"]
requires = ["flit_core>=3.9,<4"]
build-backend = "flit_core.buildapi"

[project]
Expand All @@ -20,15 +20,16 @@ classifiers = [
"Operating System :: POSIX :: Linux",
"Operating System :: MacOS :: MacOS X",
"Programming Language :: Python",
"Programming Language :: Python :: 3.6",
"Programming Language :: Python :: 3.7",
"Programming Language :: Python :: 3.8"
"Programming Language :: Python :: 3.8",
"Programming Language :: Python :: 3.9",
"Programming Language :: Python :: 3.10",
"Programming Language :: Python :: 3.11",
]
requires-python = ">=3.6"
requires-python = ">=3.8"

dependencies = [
"aiida-core>=1.0",
"pydantic~=1.10.4",
"aiida-core>=2.6",
"pydantic~=2.8.2",
"rich",
]

Expand All @@ -40,8 +41,8 @@ qe = [
"aiida-quantumespresso"
]
dev = [
"pre-commit~=2.17.0",
"pylint-pydantic~=0.1.8"
"pre-commit~=3.8.0",
"pylint-pydantic~=0.3.2"
]

[tool.black]
Expand Down

0 comments on commit 65463a0

Please sign in to comment.