mirror of
https://github.com/saltstack/salt.git
synced 2025-04-17 10:10:20 +00:00
Add regression tests for #41982
These test the scenarios where another network with a similar name already exists, verifying that absent doesn't attempt to remove a network which isn't specified, and present still attempts to create the specified network despite a similarly named network already being present.
This commit is contained in:
parent
d31f2913bd
commit
c7d364ec56
1 changed files with 39 additions and 1 deletions
|
@ -43,10 +43,18 @@ class DockerNetworkTestCase(TestCase, LoaderModuleMockMixin):
|
|||
docker_create_network = Mock(return_value='created')
|
||||
docker_connect_container_to_network = Mock(return_value='connected')
|
||||
docker_inspect_container = Mock(return_value={'Id': 'abcd'})
|
||||
# Get docker.networks to return a network with a name which is a superset of the name of
|
||||
# the network which is to be created, despite this network existing we should still expect
|
||||
# that the new network will be created.
|
||||
# Regression test for #41982.
|
||||
docker_networks = Mock(return_value=[{
|
||||
'Name': 'network_foobar',
|
||||
'Containers': {'container': {}}
|
||||
}])
|
||||
__salt__ = {'docker.create_network': docker_create_network,
|
||||
'docker.inspect_container': docker_inspect_container,
|
||||
'docker.connect_container_to_network': docker_connect_container_to_network,
|
||||
'docker.networks': Mock(return_value=[]),
|
||||
'docker.networks': docker_networks,
|
||||
}
|
||||
with patch.dict(docker_state.__dict__,
|
||||
{'__salt__': __salt__}):
|
||||
|
@ -89,3 +97,33 @@ class DockerNetworkTestCase(TestCase, LoaderModuleMockMixin):
|
|||
'changes': {'disconnected': 'disconnected',
|
||||
'removed': 'removed'},
|
||||
'result': True})
|
||||
|
||||
def test_absent_with_matching_network(self):
|
||||
'''
|
||||
Test docker_network.absent when the specified network does not exist,
|
||||
but another network with a name which is a superset of the specified
|
||||
name does exist. In this case we expect there to be no attempt to remove
|
||||
any network.
|
||||
Regression test for #41982.
|
||||
'''
|
||||
docker_remove_network = Mock(return_value='removed')
|
||||
docker_disconnect_container_from_network = Mock(return_value='disconnected')
|
||||
docker_networks = Mock(return_value=[{
|
||||
'Name': 'network_foobar',
|
||||
'Containers': {'container': {}}
|
||||
}])
|
||||
__salt__ = {
|
||||
'docker.remove_network': docker_remove_network,
|
||||
'docker.disconnect_container_from_network': docker_disconnect_container_from_network,
|
||||
'docker.networks': docker_networks,
|
||||
}
|
||||
with patch.dict(docker_state.__dict__,
|
||||
{'__salt__': __salt__}):
|
||||
ret = docker_state.absent('network_foo')
|
||||
docker_disconnect_container_from_network.assert_not_called()
|
||||
docker_remove_network.assert_not_called()
|
||||
self.assertEqual(ret, {'name': 'network_foo',
|
||||
'comment': 'Network \'network_foo\' already absent',
|
||||
'changes': {},
|
||||
'result': True})
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue