Merge pull request #1049 from aleerizw/feature/add_ssm_delete_parameters

Added support for SSM delete_parameters
This commit is contained in:
Jack Danger 2017-08-13 23:47:03 -07:00 committed by GitHub
commit d22671a756
3 changed files with 45 additions and 0 deletions

View File

@ -52,6 +52,16 @@ class SimpleSystemManagerBackend(BaseBackend):
except KeyError:
pass
def delete_parameters(self, names):
result = []
for name in names:
try:
del self._parameters[name]
result.append(name)
except KeyError:
pass
return result
def get_all_parameters(self):
result = []
for k, _ in self._parameters.items():

View File

@ -26,6 +26,22 @@ class SimpleSystemManagerResponse(BaseResponse):
self.ssm_backend.delete_parameter(name)
return json.dumps({})
def delete_parameters(self):
names = self._get_param('Names')
result = self.ssm_backend.delete_parameters(names)
response = {
'DeletedParameters': [],
'InvalidParameters': []
}
for name in names:
if name in result:
response['DeletedParameters'].append(name)
else:
response['InvalidParameters'].append(name)
return json.dumps(response)
def get_parameters(self):
names = self._get_param('Names')
with_decryption = self._get_param('WithDecryption')

View File

@ -24,6 +24,25 @@ def test_delete_parameter():
response = client.get_parameters(Names=['test'])
len(response['Parameters']).should.equal(0)
@mock_ssm
def test_delete_parameters():
client = boto3.client('ssm', region_name='us-east-1')
client.put_parameter(
Name='test',
Description='A test parameter',
Value='value',
Type='String')
response = client.get_parameters(Names=['test'])
len(response['Parameters']).should.equal(1)
result = client.delete_parameters(Names=['test', 'invalid'])
len(result['DeletedParameters']).should.equal(1)
len(result['InvalidParameters']).should.equal(1)
response = client.get_parameters(Names=['test'])
len(response['Parameters']).should.equal(0)
@mock_ssm
def test_put_parameter():