2017-05-30 02:06:41 +00:00
|
|
|
# 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.
|
|
|
|
|
|
|
|
# plugin test case
|
|
|
|
|
|
|
|
import logging
|
|
|
|
|
|
|
|
from diskimage_builder.block_device.plugin import NodeBase
|
|
|
|
from diskimage_builder.block_device.plugin import PluginBase
|
|
|
|
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class TestANode(NodeBase):
|
2017-06-02 00:57:06 +00:00
|
|
|
def __init__(self, config, state, test_rollback):
|
2017-05-30 02:06:41 +00:00
|
|
|
logger.debug("Create test 1")
|
2017-06-02 00:57:06 +00:00
|
|
|
super(TestANode, self).__init__(config['name'], state)
|
|
|
|
# might be a root node, so possibly no base
|
|
|
|
if 'base' in config:
|
|
|
|
self.base = config['base']
|
|
|
|
|
2017-06-01 04:31:49 +00:00
|
|
|
# put something in the state for test_b to check for
|
|
|
|
state['test_init_state'] = 'here'
|
2017-05-30 02:06:41 +00:00
|
|
|
|
2017-06-02 00:57:06 +00:00
|
|
|
# If we're doing rollback testing the config has some strings
|
|
|
|
# set for us
|
|
|
|
if test_rollback:
|
|
|
|
self.add_rollback(self.do_rollback, config['rollback_one_arg'])
|
|
|
|
self.add_rollback(self.do_rollback, config['rollback_two_arg'])
|
|
|
|
# see if we're the node who is going to fail
|
|
|
|
self.trigger_rollback = True if 'trigger_rollback' in config else False
|
|
|
|
|
2017-05-30 02:06:41 +00:00
|
|
|
def get_edges(self):
|
2017-06-02 00:57:06 +00:00
|
|
|
# may not have a base, if used as root node
|
|
|
|
to = [self.base] if hasattr(self, 'base') else []
|
|
|
|
return (to, [])
|
|
|
|
|
|
|
|
def do_rollback(self, string):
|
|
|
|
# We will check this after all rollbacks to make sure they ran
|
|
|
|
# in the right order
|
|
|
|
self.state['rollback_test'].append(string)
|
2017-05-30 02:06:41 +00:00
|
|
|
|
2017-06-02 00:57:06 +00:00
|
|
|
def create(self):
|
2017-05-30 02:06:41 +00:00
|
|
|
# put some fake entries into state
|
2017-06-01 04:31:49 +00:00
|
|
|
self.state['test_a'] = {}
|
|
|
|
self.state['test_a']['value'] = 'foo'
|
|
|
|
self.state['test_a']['value2'] = 'bar'
|
2017-06-02 00:57:06 +00:00
|
|
|
|
|
|
|
if self.trigger_rollback:
|
|
|
|
# The rollback test will append the strings to this as
|
|
|
|
# it unrolls, and we'll check it's value at the end
|
|
|
|
self.state['rollback_test'] = []
|
|
|
|
raise RuntimeError("Rollback triggered")
|
|
|
|
|
2017-05-30 02:06:41 +00:00
|
|
|
return
|
|
|
|
|
2017-06-01 04:57:34 +00:00
|
|
|
def umount(self):
|
Use picked nodes for later cmd_* calls
Currently the later cmd_* calls -- umount, cleanup, delete -- all
recreate the node graph by parsing the config file using
create_graph()
There is some need, however, to have a sense of global state when
building the node list. The problem is, this is a one time operation
-- we do not want to rebuild that state for these later calls (see the
"loaded" checks in proposed
Ic3b805f9258128d5233b21ff25579c03487c7fcc).
An insight here seems to be that these cmd_* calls do not actually
want to re-parse the configuration file and rebuild the node list;
they just want to walk the node list in reverse with the state as
provided after cmd_create().
So, rather than re-creating the node list, we might as well just
pickle it, save it to disk along side the state dictionary dump and
reload it for cmd_*.
After this, I think we can safely have PluginBase.__init__() be passed
the state. We will now know that this will only be called once,
during initial creation.
Change-Id: I68840594a34af28d41d9522addcfd830bd203b97
2017-05-31 05:09:37 +00:00
|
|
|
# Umount is run in reverse. This key should exist from test_b
|
2017-06-01 04:57:34 +00:00
|
|
|
self.state['umount'].append('test_a')
|
Use picked nodes for later cmd_* calls
Currently the later cmd_* calls -- umount, cleanup, delete -- all
recreate the node graph by parsing the config file using
create_graph()
There is some need, however, to have a sense of global state when
building the node list. The problem is, this is a one time operation
-- we do not want to rebuild that state for these later calls (see the
"loaded" checks in proposed
Ic3b805f9258128d5233b21ff25579c03487c7fcc).
An insight here seems to be that these cmd_* calls do not actually
want to re-parse the configuration file and rebuild the node list;
they just want to walk the node list in reverse with the state as
provided after cmd_create().
So, rather than re-creating the node list, we might as well just
pickle it, save it to disk along side the state dictionary dump and
reload it for cmd_*.
After this, I think we can safely have PluginBase.__init__() be passed
the state. We will now know that this will only be called once,
during initial creation.
Change-Id: I68840594a34af28d41d9522addcfd830bd203b97
2017-05-31 05:09:37 +00:00
|
|
|
|
2017-05-30 02:06:41 +00:00
|
|
|
|
|
|
|
class TestA(PluginBase):
|
|
|
|
|
2017-06-01 04:31:49 +00:00
|
|
|
def __init__(self, config, defaults, state):
|
2017-06-07 23:43:47 +00:00
|
|
|
super(TestA, self).__init__()
|
2017-06-02 00:57:06 +00:00
|
|
|
|
|
|
|
test_rollback = True if 'test_rollback' in defaults else False
|
|
|
|
self.node = TestANode(config, state, test_rollback)
|
2017-05-30 02:06:41 +00:00
|
|
|
|
|
|
|
def get_nodes(self):
|
|
|
|
return [self.node]
|