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 TestBNode(NodeBase):
|
2017-06-01 04:31:49 +00:00
|
|
|
def __init__(self, name, state, base):
|
2017-05-30 02:06:41 +00:00
|
|
|
logger.debug("Create test 1")
|
2017-06-01 04:31:49 +00:00
|
|
|
super(TestBNode, self).__init__(name, state)
|
2017-05-30 02:06:41 +00:00
|
|
|
self.base = base
|
|
|
|
|
|
|
|
def get_edges(self):
|
2017-06-01 04:31:49 +00:00
|
|
|
# this should have been inserted by test_a before
|
|
|
|
# we are called
|
|
|
|
assert self.state['test_init_state'] == 'here'
|
2017-05-30 02:06:41 +00:00
|
|
|
return ([self.base], [])
|
|
|
|
|
2017-06-01 04:31:49 +00:00
|
|
|
def create(self, rollback):
|
|
|
|
self.state['test_b'] = {}
|
|
|
|
self.state['test_b']['value'] = 'baz'
|
2017-05-30 02:06:41 +00:00
|
|
|
return
|
|
|
|
|
2017-06-01 04:57:34 +00:00
|
|
|
def umount(self):
|
|
|
|
# these values should have persisteted from create()
|
|
|
|
assert self.state['test_b']['value'] == 'baz'
|
|
|
|
|
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 run in reverse. this should run before test_a
|
2017-06-01 04:57:34 +00:00
|
|
|
assert 'umount' not in self.state
|
|
|
|
self.state['umount'] = []
|
|
|
|
self.state['umount'].append('test_b')
|
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 TestB(PluginBase):
|
|
|
|
|
2017-06-01 04:31:49 +00:00
|
|
|
def __init__(self, config, defaults, state):
|
2017-06-07 23:43:47 +00:00
|
|
|
super(TestB, self).__init__()
|
2017-05-30 02:06:41 +00:00
|
|
|
self.node = TestBNode(config['name'],
|
2017-06-01 04:31:49 +00:00
|
|
|
state,
|
2017-05-30 02:06:41 +00:00
|
|
|
config['base'])
|
|
|
|
|
|
|
|
def get_nodes(self):
|
|
|
|
return [self.node]
|