
Refactor orchestrator to break large monolithic functions into small functions per action. - Update orchestrator to match new statemgmt API - Pull most code out of __init__.py files - Create action classes for Orchestrator actions - Create action classes for Driver actions - Orchestrator consumes tasks from database queue - Additional encapsulation of task functionality into Task class - Create shared integration test fixtures - Fix Sphinx entrypoint so package install works - Disable bootdata API until BootAction implementation - Bring codebase into PEP8 compliance - Update documentation reflect code changes - Mark SQL #nosec for bandit Change-Id: Id9a7bdedcdd5bbf07aeabbdb52db0f0b71f1e4a4
76 lines
2.6 KiB
Python
76 lines
2.6 KiB
Python
# Copyright 2017 AT&T Intellectual Property. All other rights reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
"""Generic testing for the orchestrator."""
|
|
import threading
|
|
import time
|
|
|
|
import drydock_provisioner.orchestrator.orchestrator as orch
|
|
import drydock_provisioner.objects.fields as hd_fields
|
|
|
|
from drydock_provisioner.ingester.ingester import Ingester
|
|
|
|
|
|
class TestClass(object):
|
|
def test_task_complete(self, setup, blank_state):
|
|
ingester = Ingester()
|
|
ingester.enable_plugin(
|
|
'drydock_provisioner.ingester.plugins.yaml.YamlIngester')
|
|
|
|
orchestrator = orch.Orchestrator(
|
|
state_manager=blank_state, ingester=ingester)
|
|
orch_task = orchestrator.create_task(
|
|
action=hd_fields.OrchestratorAction.Noop)
|
|
orch_task.set_status(hd_fields.TaskStatus.Queued)
|
|
orch_task.save()
|
|
|
|
orch_thread = threading.Thread(target=orchestrator.watch_for_tasks)
|
|
orch_thread.start()
|
|
|
|
try:
|
|
time.sleep(10)
|
|
|
|
orch_task = blank_state.get_task(orch_task.get_id())
|
|
|
|
assert orch_task.get_status() == hd_fields.TaskStatus.Complete
|
|
finally:
|
|
orchestrator.stop_orchestrator()
|
|
orch_thread.join(10)
|
|
|
|
def test_task_termination(self, setup, blank_state):
|
|
ingester = Ingester()
|
|
ingester.enable_plugin(
|
|
'drydock_provisioner.ingester.plugins.yaml.YamlIngester')
|
|
|
|
orchestrator = orch.Orchestrator(
|
|
state_manager=blank_state, ingester=ingester)
|
|
orch_task = orchestrator.create_task(
|
|
action=hd_fields.OrchestratorAction.Noop)
|
|
|
|
orch_task.set_status(hd_fields.TaskStatus.Queued)
|
|
orch_task.save()
|
|
|
|
orch_thread = threading.Thread(target=orchestrator.watch_for_tasks)
|
|
orch_thread.start()
|
|
|
|
try:
|
|
time.sleep(2)
|
|
orchestrator.terminate_task(orch_task)
|
|
|
|
time.sleep(10)
|
|
orch_task = blank_state.get_task(orch_task.get_id())
|
|
assert orch_task.get_status() == hd_fields.TaskStatus.Terminated
|
|
finally:
|
|
orchestrator.stop_orchestrator()
|
|
orch_thread.join(10)
|