fix merge conflicts
This commit is contained in:
commit
c20d365021
8 changed files with 393 additions and 5 deletions
|
|
@ -470,6 +470,92 @@ def test_invoke_lambda_error():
|
|||
assert 'FunctionError' in result
|
||||
assert result['FunctionError'] == 'Handled'
|
||||
|
||||
@mock_lambda
|
||||
@mock_s3
|
||||
def test_tags():
|
||||
"""
|
||||
test list_tags -> tag_resource -> list_tags -> tag_resource -> list_tags -> untag_resource -> list_tags integration
|
||||
"""
|
||||
s3_conn = boto3.client('s3', 'us-west-2')
|
||||
s3_conn.create_bucket(Bucket='test-bucket')
|
||||
|
||||
zip_content = get_test_zip_file2()
|
||||
s3_conn.put_object(Bucket='test-bucket', Key='test.zip', Body=zip_content)
|
||||
conn = boto3.client('lambda', 'us-west-2')
|
||||
|
||||
function = conn.create_function(
|
||||
FunctionName='testFunction',
|
||||
Runtime='python2.7',
|
||||
Role='test-iam-role',
|
||||
Handler='lambda_function.handler',
|
||||
Code={
|
||||
'S3Bucket': 'test-bucket',
|
||||
'S3Key': 'test.zip',
|
||||
},
|
||||
Description='test lambda function',
|
||||
Timeout=3,
|
||||
MemorySize=128,
|
||||
Publish=True,
|
||||
)
|
||||
|
||||
# List tags when there are none
|
||||
conn.list_tags(
|
||||
Resource=function['FunctionArn']
|
||||
)['Tags'].should.equal(dict())
|
||||
|
||||
# List tags when there is one
|
||||
conn.tag_resource(
|
||||
Resource=function['FunctionArn'],
|
||||
Tags=dict(spam='eggs')
|
||||
)['ResponseMetadata']['HTTPStatusCode'].should.equal(200)
|
||||
conn.list_tags(
|
||||
Resource=function['FunctionArn']
|
||||
)['Tags'].should.equal(dict(spam='eggs'))
|
||||
|
||||
# List tags when another has been added
|
||||
conn.tag_resource(
|
||||
Resource=function['FunctionArn'],
|
||||
Tags=dict(foo='bar')
|
||||
)['ResponseMetadata']['HTTPStatusCode'].should.equal(200)
|
||||
conn.list_tags(
|
||||
Resource=function['FunctionArn']
|
||||
)['Tags'].should.equal(dict(spam='eggs', foo='bar'))
|
||||
|
||||
# Untag resource
|
||||
conn.untag_resource(
|
||||
Resource=function['FunctionArn'],
|
||||
TagKeys=['spam', 'trolls']
|
||||
)['ResponseMetadata']['HTTPStatusCode'].should.equal(204)
|
||||
conn.list_tags(
|
||||
Resource=function['FunctionArn']
|
||||
)['Tags'].should.equal(dict(foo='bar'))
|
||||
|
||||
# Untag a tag that does not exist (no error and no change)
|
||||
conn.untag_resource(
|
||||
Resource=function['FunctionArn'],
|
||||
TagKeys=['spam']
|
||||
)['ResponseMetadata']['HTTPStatusCode'].should.equal(204)
|
||||
|
||||
@mock_lambda
|
||||
def test_tags_not_found():
|
||||
"""
|
||||
Test list_tags and tag_resource when the lambda with the given arn does not exist
|
||||
"""
|
||||
conn = boto3.client('lambda', 'us-west-2')
|
||||
conn.list_tags.when.called_with(
|
||||
Resource='arn:aws:lambda:123456789012:function:not-found'
|
||||
).should.throw(botocore.client.ClientError)
|
||||
|
||||
conn.tag_resource.when.called_with(
|
||||
Resource='arn:aws:lambda:123456789012:function:not-found',
|
||||
Tags=dict(spam='eggs')
|
||||
).should.throw(botocore.client.ClientError)
|
||||
|
||||
conn.untag_resource.when.called_with(
|
||||
Resource='arn:aws:lambda:123456789012:function:not-found',
|
||||
TagKeys=['spam']
|
||||
).should.throw(botocore.client.ClientError)
|
||||
|
||||
@mock_lambda
|
||||
def test_invoke_async_function():
|
||||
conn = boto3.client('lambda', 'us-west-2')
|
||||
|
|
@ -492,5 +578,4 @@ def test_invoke_async_function():
|
|||
InvokeArgs=json.dumps({ 'test': 'event' })
|
||||
)
|
||||
|
||||
print(success_result)
|
||||
success_result['Status'].should.equal(202)
|
||||
|
|
|
|||
|
|
@ -5,6 +5,7 @@ from decimal import Decimal
|
|||
import boto
|
||||
import boto3
|
||||
from boto3.dynamodb.conditions import Key
|
||||
from botocore.exceptions import ClientError
|
||||
import sure # noqa
|
||||
from freezegun import freeze_time
|
||||
from moto import mock_dynamodb2, mock_dynamodb2_deprecated
|
||||
|
|
@ -1190,6 +1191,14 @@ def _create_table_with_range_key():
|
|||
'AttributeName': 'subject',
|
||||
'AttributeType': 'S'
|
||||
},
|
||||
{
|
||||
'AttributeName': 'username',
|
||||
'AttributeType': 'S'
|
||||
},
|
||||
{
|
||||
'AttributeName': 'created',
|
||||
'AttributeType': 'N'
|
||||
}
|
||||
],
|
||||
ProvisionedThroughput={
|
||||
'ReadCapacityUnits': 5,
|
||||
|
|
@ -1392,6 +1401,155 @@ def test_update_item_with_expression():
|
|||
'subject': '123',
|
||||
})
|
||||
|
||||
@mock_dynamodb2
|
||||
def test_update_item_add_with_expression():
|
||||
table = _create_table_with_range_key()
|
||||
|
||||
item_key = {'forum_name': 'the-key', 'subject': '123'}
|
||||
current_item = {
|
||||
'forum_name': 'the-key',
|
||||
'subject': '123',
|
||||
'str_set': {'item1', 'item2', 'item3'},
|
||||
'num_set': {1, 2, 3},
|
||||
'num_val': 6
|
||||
}
|
||||
|
||||
# Put an entry in the DB to play with
|
||||
table.put_item(Item=current_item)
|
||||
|
||||
# Update item to add a string value to a string set
|
||||
table.update_item(
|
||||
Key=item_key,
|
||||
UpdateExpression='ADD str_set :v',
|
||||
ExpressionAttributeValues={
|
||||
':v': {'item4'}
|
||||
}
|
||||
)
|
||||
current_item['str_set'] = current_item['str_set'].union({'item4'})
|
||||
dict(table.get_item(Key=item_key)['Item']).should.equal(current_item)
|
||||
|
||||
# Update item to add a num value to a num set
|
||||
table.update_item(
|
||||
Key=item_key,
|
||||
UpdateExpression='ADD num_set :v',
|
||||
ExpressionAttributeValues={
|
||||
':v': {6}
|
||||
}
|
||||
)
|
||||
current_item['num_set'] = current_item['num_set'].union({6})
|
||||
dict(table.get_item(Key=item_key)['Item']).should.equal(current_item)
|
||||
|
||||
# Update item to add a value to a number value
|
||||
table.update_item(
|
||||
Key=item_key,
|
||||
UpdateExpression='ADD num_val :v',
|
||||
ExpressionAttributeValues={
|
||||
':v': 20
|
||||
}
|
||||
)
|
||||
current_item['num_val'] = current_item['num_val'] + 20
|
||||
dict(table.get_item(Key=item_key)['Item']).should.equal(current_item)
|
||||
|
||||
# Attempt to add a number value to a string set, should raise Client Error
|
||||
table.update_item.when.called_with(
|
||||
Key=item_key,
|
||||
UpdateExpression='ADD str_set :v',
|
||||
ExpressionAttributeValues={
|
||||
':v': 20
|
||||
}
|
||||
).should.have.raised(ClientError)
|
||||
dict(table.get_item(Key=item_key)['Item']).should.equal(current_item)
|
||||
|
||||
# Attempt to add a number set to the string set, should raise a ClientError
|
||||
table.update_item.when.called_with(
|
||||
Key=item_key,
|
||||
UpdateExpression='ADD str_set :v',
|
||||
ExpressionAttributeValues={
|
||||
':v': { 20 }
|
||||
}
|
||||
).should.have.raised(ClientError)
|
||||
dict(table.get_item(Key=item_key)['Item']).should.equal(current_item)
|
||||
|
||||
# Attempt to update with a bad expression
|
||||
table.update_item.when.called_with(
|
||||
Key=item_key,
|
||||
UpdateExpression='ADD str_set bad_value'
|
||||
).should.have.raised(ClientError)
|
||||
|
||||
# Attempt to add a string value instead of a string set
|
||||
table.update_item.when.called_with(
|
||||
Key=item_key,
|
||||
UpdateExpression='ADD str_set :v',
|
||||
ExpressionAttributeValues={
|
||||
':v': 'new_string'
|
||||
}
|
||||
).should.have.raised(ClientError)
|
||||
|
||||
|
||||
@mock_dynamodb2
|
||||
def test_update_item_delete_with_expression():
|
||||
table = _create_table_with_range_key()
|
||||
|
||||
item_key = {'forum_name': 'the-key', 'subject': '123'}
|
||||
current_item = {
|
||||
'forum_name': 'the-key',
|
||||
'subject': '123',
|
||||
'str_set': {'item1', 'item2', 'item3'},
|
||||
'num_set': {1, 2, 3},
|
||||
'num_val': 6
|
||||
}
|
||||
|
||||
# Put an entry in the DB to play with
|
||||
table.put_item(Item=current_item)
|
||||
|
||||
# Update item to delete a string value from a string set
|
||||
table.update_item(
|
||||
Key=item_key,
|
||||
UpdateExpression='DELETE str_set :v',
|
||||
ExpressionAttributeValues={
|
||||
':v': {'item2'}
|
||||
}
|
||||
)
|
||||
current_item['str_set'] = current_item['str_set'].difference({'item2'})
|
||||
dict(table.get_item(Key=item_key)['Item']).should.equal(current_item)
|
||||
|
||||
# Update item to delete a num value from a num set
|
||||
table.update_item(
|
||||
Key=item_key,
|
||||
UpdateExpression='DELETE num_set :v',
|
||||
ExpressionAttributeValues={
|
||||
':v': {2}
|
||||
}
|
||||
)
|
||||
current_item['num_set'] = current_item['num_set'].difference({2})
|
||||
dict(table.get_item(Key=item_key)['Item']).should.equal(current_item)
|
||||
|
||||
# Try to delete on a number, this should fail
|
||||
table.update_item.when.called_with(
|
||||
Key=item_key,
|
||||
UpdateExpression='DELETE num_val :v',
|
||||
ExpressionAttributeValues={
|
||||
':v': 20
|
||||
}
|
||||
).should.have.raised(ClientError)
|
||||
dict(table.get_item(Key=item_key)['Item']).should.equal(current_item)
|
||||
|
||||
# Try to delete a string set from a number set
|
||||
table.update_item.when.called_with(
|
||||
Key=item_key,
|
||||
UpdateExpression='DELETE num_set :v',
|
||||
ExpressionAttributeValues={
|
||||
':v': {'del_str'}
|
||||
}
|
||||
).should.have.raised(ClientError)
|
||||
dict(table.get_item(Key=item_key)['Item']).should.equal(current_item)
|
||||
|
||||
# Attempt to update with a bad expression
|
||||
table.update_item.when.called_with(
|
||||
Key=item_key,
|
||||
UpdateExpression='DELETE num_val badvalue'
|
||||
).should.have.raised(ClientError)
|
||||
|
||||
|
||||
@mock_dynamodb2
|
||||
def test_boto3_query_gsi_range_comparison():
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue