Skip to content

Commit

Permalink
Merge pull request #130 from giffels/add-yaml-constructors
Browse files Browse the repository at this point in the history
Add COBalD yaml constructors, apply plugin constraint decorator and release 0.3.0
  • Loading branch information
giffels authored Feb 26, 2020
2 parents 0f2d4b5 + 446a9ef commit 2a835e4
Show file tree
Hide file tree
Showing 21 changed files with 83 additions and 60 deletions.
6 changes: 3 additions & 3 deletions docs/source/changelog.rst
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
.. Created by changelog.py at 2020-02-24, command
.. Created by changelog.py at 2020-02-26, command
'/Users/giffler/.cache/pre-commit/repont7o94ca/py_env-default/bin/changelog docs/source/changes compile --output=docs/source/changelog.rst'
based on the format of 'https://keepachangelog.com/'
#########
CHANGELOG
#########

[Unreleased] - 2020-02-24
=========================
[0.3.0] - 2020-02-26
====================

Added
-----
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
category: fixed
summary: The `CleanupState` is now taking into account the status of the resource for state transitions
pull requests:
- 100
summary: "The `CleanupState` is now taking into account the status of the resource\
\ for state transitions"
description: |
The `CleanupState` is now taking into account the status of the resource and two missing state transitions have been
added to the transistion dictionary.
pull requests:
- 100
version: 0.3.0
11 changes: 6 additions & 5 deletions docs/source/changes/116.adding_drone_life_time.yaml
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
category: added
summary: An optional and per site configurable drone minimum lifetime has been added
pull requests:
- 116
issues:
- 114
summary: "An optional and per site configurable drone minimum lifetime has been added"
description: |
An optionally and per site configurable drone minimum life time to TARDIS. The minimum life time is defined as the
time the drone is being in `AvailableState`. At the end of life, the drone is set to `DrainState`.
issues:
- 114
pull requests:
- 116
version: 0.3.0
11 changes: 6 additions & 5 deletions docs/source/changes/119.add_legacy_object_initialisation.yaml
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
category: added
summary: Add support for COBalD legacy object initialisation
pull requests:
- 119
issues:
- 118
summary: "Add support for COBalD legacy object initialisation"
description: |
Support for the `COBalD` object initialisation syntax to construct python objects instead of using YAML tags has been
enabled.
issues:
- 118
pull requests:
- 119
version: 0.3.0
7 changes: 4 additions & 3 deletions docs/source/changes/120.add_python38_support.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
category: added
summary: Add support for Python 3.8
pull requests:
- 120
summary: "Add support for Python 3.8"
description: |
Support for Python3.8 added to setup.py classifiers and travis uniitests for Python3.8 have been enabled.
pull requests:
- 120
version: 0.3.0
Original file line number Diff line number Diff line change
@@ -1,9 +1,8 @@
category: fixed
summary: Fix state transitions for jobs retried by HTCondor
pull_requests:
- 122
summary: "Fix state transitions for jobs retried by HTCondor"
description: |
In case a job is in `DrainingState`, `ShuttingDownState` or `ShutDownState` a transition back to BootingState is
currently not covered by `TARDIS`. However, a currently running job can potentially be retried by HTCondor in case of
an internal error. Now, retried jobs previously in `DrainingState`, `ShuttingDownState` or `ShutDownState` are removed
entirely from the batch queue.
version: 0.3.0
5 changes: 3 additions & 2 deletions docs/source/changes/123.fix_draining_slots_w_startd_name.yaml
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
category: fixed
summary: "Fix draining of slots having a startd name"
pull requests:
- 123
description: |
`TARDIS` supports running more than one Drone on the same host. To differentiate the drones, the `TardisDroneUuid` has
been introduced and will be set as `STARTD_NAME` on the corresponding sites. `TARDIS` used to use only the `hostname`
when draining resources. This change will take into account the provided `STARTD_NAME` as well.
pull requests:
- 123
version: 0.3.0
7 changes: 4 additions & 3 deletions docs/source/changes/125.add_unified_configuration.yaml
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
category: added
summary: Add the possibility to use an unified `COBalD` and `TARDIS` configuration
pull requests:
- 125
summary: "Add the possibility to use an unified `COBalD` and `TARDIS` configuration"
description: |
The possibility to combine the `COBalD` and the `TARDIS` configuration in one single `yaml` has been added.
pull requests:
- 125
version: 0.3.0
10 changes: 5 additions & 5 deletions docs/source/changes/126.fix_config_translation.yaml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
category: fixed
summary: Fix the translation of cloud init scripts into base64 encoded strings
summary: "Fix the translation of cloud init scripts into base64 encoded strings"
description: "The translation of cloud init scripts into base64 encoded strings has\
\ been fixed. Reason was changing a data structure\nwhile interating over it. \n"
pull requests:
- 126
description: |
The translation of cloud init scripts into base64 encoded strings has been fixed. Reason was changing a data structure
while interating over it.
- 126
version: 0.3.0
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
category: fixed
summary: Use utilisation as weight in composite pools
pull requests:
- 127
summary: "Use utilisation as weight in composite pools"
description: |
The experience of using `WeightedComposite` pools in production shows that weighting the `demand` of resources by
their `supply` is not always the best choice. Weighting the `demand` of resources by `utilisation` is instead more
desired, since `COBalD` should increase the best utilised resource.
pull requests:
- 127
version: 0.3.0
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
category: fixed
summary: Fix state transitions and refactoring of the SLURM site adapter
pull requests:
- 128
summary: "Fix state transitions and refactoring of the SLURM site adapter"
description: |
The SLURM site adapter contains now state transition for all possible job states in the SLURM batch system. For some
states the transition to `TARDIS` `resources_states` has been corrected leading to an infinite execution of `scancel`
to jobs not in the queue anymore. In addtion, `squeue` (jobs in batch queue) instead of the `sacct`
(Accounting tool listing also history of jobs) is used in order to minize the number of jobs to keep track of.
pull requests:
- 128
version: 0.3.0
7 changes: 4 additions & 3 deletions docs/source/changes/76.allow_removal_of_booting_drones.yaml
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
category: fixed
summary: Allow removal of booting drones if demand drops to zero
pull requests:
- 76
summary: "Allow removal of booting drones if demand drops to zero"
description: |
So far draining of drones in `AvailableState` was supported by `TARDIS`, which works well for cloud providers. Since
the queueing time in batch systems can be long, the deletion of queued drones (idle batch jobs) has been enabled as
well.
pull requests:
- 76
version: 0.3.0
8 changes: 5 additions & 3 deletions docs/source/changes/77.telegraf_config_update.yaml
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
category: added
summary: The machine name has been added as a default tag in the telegraf monitoring plugin, can be overwritten.
pull requests:
- 77
summary: "The machine name has been added as a default tag in the telegraf monitoring\
\ plugin, can be overwritten."
description: |
The machine name has been added as a default tag in the telegraf monitoring plugin. Can be overwritten by adding
`tardis_machine_name` as default tag in the plugin configuration.
pull requests:
- 77
version: 0.3.0
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
category: fixed
summary: Improved logging of the `HTCondor` batch system adapter and the status changes of the drones
pull requests:
- 78
summary: "Improved logging of the `HTCondor` batch system adapter and the status changes\
\ of the drones"
description: |
Drone resource attributes to have been addedd to the debug logging of drone status changes. The `condor_status`
command has been added to the debug logging of the htcondor batch system adapter.
pull requests:
- 78
version: 0.3.0
11 changes: 6 additions & 5 deletions docs/source/changes/92.register_pool_factory_as_yaml_plugin.yaml
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
category: added
summary: Register pool factory as `COBalD` yaml plugin
pull requests:
- 92
issues:
- 91
summary: "Register pool factory as `COBalD` yaml plugin"
description: |
Register the composite pool factory function `create_composite_pool` as `COBalD` yaml plugin, so that it can be loaded
via yaml tags in the `COBalD` configuration.
issues:
- 91
pull requests:
- 92
version: 0.3.0
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
category: fixed
summary: Fix the handling of the termination of vanished resources
pull requests:
- 96
summary: "Fix the handling of the termination of vanished resources"
description: |
Fix a bug with resources that shut down itself while being idle for 20 minutes, which remained in `CleanUpState`
forever, since the `teminate_resource` call keept raising `TardisResourceStatusUpdateFailed`, which led to infinte
retries of the `terminate_resource` call.
pull requests:
- 96
version: 0.3.0
2 changes: 2 additions & 0 deletions docs/source/changes/versions.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
- semver: 0.3.0
date: '2020-02-26'
4 changes: 2 additions & 2 deletions docs/source/executors/executors.rst
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ Shell Executor

.. code-block:: yaml
!ShellExecutor
!TardisShellExecutor
.. rubric:: Example configuration (`COBalD` legacy object initialisation)

Expand All @@ -53,7 +53,7 @@ SSH Executor

.. code-block:: yaml
!SSHExecutor
!TardisSSHExecutor
host: login.dorie.somewherein.de
username: clown
client_keys:
Expand Down
8 changes: 6 additions & 2 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,11 @@
],
entry_points={
"cobald.config.yaml_constructors": [
"TardisPoolFactory = tardis.resources.poolfactory:create_composite_pool"
"TardisPoolFactory = tardis.resources.poolfactory:create_composite_pool",
"TardisPeriodicValue = tardis.utilities.simulators.periodicvalue:PeriodicValue", # noqa: B950
"TardisRandomGauss = tardis.utilities.simulators.randomgauss:RandomGauss",
"TardisSSHExecutor = tardis.utilities.executors.sshexecutor:SSHExecutor",
"TardisShellExecutor = tardis.utilities.executors.shellexecutor:ShellExecutor", # noqa: B950
],
"cobald.config.sections": [
"tardis = tardis.configuration.configuration:Configuration"
Expand All @@ -53,7 +57,7 @@
"CloudStackAIO",
"PyYAML",
"AsyncOpenStackClient",
"cobald",
"cobald>=0.12.0",
"asyncssh",
"aiotelegraf",
],
Expand Down
2 changes: 1 addition & 1 deletion tardis/__about__.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
__summary__ = "Transparent Adaptive Resource Dynamic Integration System"
__url__ = "https://github.com/matterminers/tardis"

__version__ = "0.2.0"
__version__ = "0.3.0"
__author__ = "Manuel Giffels, Matthias Schnepf"
__email__ = "[email protected]"
__copyright__ = "2019 %s" % __author__
Expand Down
2 changes: 2 additions & 0 deletions tardis/configuration/configuration.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
from ..utilities.simulators import * # noqa: F403, F401

from cobald.daemon.config.mapping import Translator
from cobald.daemon.plugins import constraints as plugin_constraints

from base64 import b64encode
import os
Expand All @@ -31,6 +32,7 @@ def translate_config(obj):
return obj


@plugin_constraints(before={"pipeline"})
class Configuration(Borg):
_shared_state = AttributeDict()

Expand Down

0 comments on commit 2a835e4

Please sign in to comment.