225 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			225 lines
		
	
	
		
			7.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
from __future__ import unicode_literals
 | 
						|
 | 
						|
import boto3
 | 
						|
from botocore.exceptions import ClientError
 | 
						|
from datetime import datetime, timedelta
 | 
						|
import pytz
 | 
						|
import sure   # noqa
 | 
						|
 | 
						|
from moto import mock_cloudwatch
 | 
						|
 | 
						|
 | 
						|
@mock_cloudwatch
 | 
						|
def test_put_list_dashboard():
 | 
						|
    client = boto3.client('cloudwatch', region_name='eu-central-1')
 | 
						|
    widget = '{"widgets": [{"type": "text", "x": 0, "y": 7, "width": 3, "height": 3, "properties": {"markdown": "Hello world"}}]}'
 | 
						|
 | 
						|
    client.put_dashboard(DashboardName='test1', DashboardBody=widget)
 | 
						|
    resp = client.list_dashboards()
 | 
						|
 | 
						|
    len(resp['DashboardEntries']).should.equal(1)
 | 
						|
 | 
						|
 | 
						|
@mock_cloudwatch
 | 
						|
def test_put_list_prefix_nomatch_dashboard():
 | 
						|
    client = boto3.client('cloudwatch', region_name='eu-central-1')
 | 
						|
    widget = '{"widgets": [{"type": "text", "x": 0, "y": 7, "width": 3, "height": 3, "properties": {"markdown": "Hello world"}}]}'
 | 
						|
 | 
						|
    client.put_dashboard(DashboardName='test1', DashboardBody=widget)
 | 
						|
    resp = client.list_dashboards(DashboardNamePrefix='nomatch')
 | 
						|
 | 
						|
    len(resp['DashboardEntries']).should.equal(0)
 | 
						|
 | 
						|
 | 
						|
@mock_cloudwatch
 | 
						|
def test_delete_dashboard():
 | 
						|
    client = boto3.client('cloudwatch', region_name='eu-central-1')
 | 
						|
    widget = '{"widgets": [{"type": "text", "x": 0, "y": 7, "width": 3, "height": 3, "properties": {"markdown": "Hello world"}}]}'
 | 
						|
 | 
						|
    client.put_dashboard(DashboardName='test1', DashboardBody=widget)
 | 
						|
    client.put_dashboard(DashboardName='test2', DashboardBody=widget)
 | 
						|
    client.put_dashboard(DashboardName='test3', DashboardBody=widget)
 | 
						|
    client.delete_dashboards(DashboardNames=['test2', 'test1'])
 | 
						|
 | 
						|
    resp = client.list_dashboards(DashboardNamePrefix='test3')
 | 
						|
    len(resp['DashboardEntries']).should.equal(1)
 | 
						|
 | 
						|
 | 
						|
@mock_cloudwatch
 | 
						|
def test_delete_dashboard_fail():
 | 
						|
    client = boto3.client('cloudwatch', region_name='eu-central-1')
 | 
						|
    widget = '{"widgets": [{"type": "text", "x": 0, "y": 7, "width": 3, "height": 3, "properties": {"markdown": "Hello world"}}]}'
 | 
						|
 | 
						|
    client.put_dashboard(DashboardName='test1', DashboardBody=widget)
 | 
						|
    client.put_dashboard(DashboardName='test2', DashboardBody=widget)
 | 
						|
    client.put_dashboard(DashboardName='test3', DashboardBody=widget)
 | 
						|
    # Doesnt delete anything if all dashboards to be deleted do not exist
 | 
						|
    try:
 | 
						|
        client.delete_dashboards(DashboardNames=['test2', 'test1', 'test_no_match'])
 | 
						|
    except ClientError as err:
 | 
						|
        err.response['Error']['Code'].should.equal('ResourceNotFound')
 | 
						|
    else:
 | 
						|
        raise RuntimeError('Should of raised error')
 | 
						|
 | 
						|
    resp = client.list_dashboards()
 | 
						|
    len(resp['DashboardEntries']).should.equal(3)
 | 
						|
 | 
						|
 | 
						|
@mock_cloudwatch
 | 
						|
def test_get_dashboard():
 | 
						|
    client = boto3.client('cloudwatch', region_name='eu-central-1')
 | 
						|
    widget = '{"widgets": [{"type": "text", "x": 0, "y": 7, "width": 3, "height": 3, "properties": {"markdown": "Hello world"}}]}'
 | 
						|
    client.put_dashboard(DashboardName='test1', DashboardBody=widget)
 | 
						|
 | 
						|
    resp = client.get_dashboard(DashboardName='test1')
 | 
						|
    resp.should.contain('DashboardArn')
 | 
						|
    resp.should.contain('DashboardBody')
 | 
						|
    resp['DashboardName'].should.equal('test1')
 | 
						|
 | 
						|
 | 
						|
@mock_cloudwatch
 | 
						|
def test_get_dashboard_fail():
 | 
						|
    client = boto3.client('cloudwatch', region_name='eu-central-1')
 | 
						|
 | 
						|
    try:
 | 
						|
        client.get_dashboard(DashboardName='test1')
 | 
						|
    except ClientError as err:
 | 
						|
        err.response['Error']['Code'].should.equal('ResourceNotFound')
 | 
						|
    else:
 | 
						|
        raise RuntimeError('Should of raised error')
 | 
						|
 | 
						|
 | 
						|
@mock_cloudwatch
 | 
						|
def test_alarm_state():
 | 
						|
    client = boto3.client('cloudwatch', region_name='eu-central-1')
 | 
						|
 | 
						|
    client.put_metric_alarm(
 | 
						|
        AlarmName='testalarm1',
 | 
						|
        MetricName='cpu',
 | 
						|
        Namespace='blah',
 | 
						|
        Period=10,
 | 
						|
        EvaluationPeriods=5,
 | 
						|
        Statistic='Average',
 | 
						|
        Threshold=2,
 | 
						|
        ComparisonOperator='GreaterThanThreshold',
 | 
						|
    )
 | 
						|
    client.put_metric_alarm(
 | 
						|
        AlarmName='testalarm2',
 | 
						|
        MetricName='cpu',
 | 
						|
        Namespace='blah',
 | 
						|
        Period=10,
 | 
						|
        EvaluationPeriods=5,
 | 
						|
        Statistic='Average',
 | 
						|
        Threshold=2,
 | 
						|
        ComparisonOperator='GreaterThanThreshold',
 | 
						|
    )
 | 
						|
 | 
						|
    # This is tested implicitly as if it doesnt work the rest will die
 | 
						|
    client.set_alarm_state(
 | 
						|
        AlarmName='testalarm1',
 | 
						|
        StateValue='ALARM',
 | 
						|
        StateReason='testreason',
 | 
						|
        StateReasonData='{"some": "json_data"}'
 | 
						|
    )
 | 
						|
 | 
						|
    resp = client.describe_alarms(
 | 
						|
        StateValue='ALARM'
 | 
						|
    )
 | 
						|
    len(resp['MetricAlarms']).should.equal(1)
 | 
						|
    resp['MetricAlarms'][0]['AlarmName'].should.equal('testalarm1')
 | 
						|
    resp['MetricAlarms'][0]['StateValue'].should.equal('ALARM')
 | 
						|
 | 
						|
    resp = client.describe_alarms(
 | 
						|
        StateValue='OK'
 | 
						|
    )
 | 
						|
    len(resp['MetricAlarms']).should.equal(1)
 | 
						|
    resp['MetricAlarms'][0]['AlarmName'].should.equal('testalarm2')
 | 
						|
    resp['MetricAlarms'][0]['StateValue'].should.equal('OK')
 | 
						|
 | 
						|
    # Just for sanity
 | 
						|
    resp = client.describe_alarms()
 | 
						|
    len(resp['MetricAlarms']).should.equal(2)
 | 
						|
 | 
						|
 | 
						|
@mock_cloudwatch
 | 
						|
def test_put_metric_data_no_dimensions():
 | 
						|
    conn = boto3.client('cloudwatch', region_name='us-east-1')
 | 
						|
 | 
						|
    conn.put_metric_data(
 | 
						|
        Namespace='tester',
 | 
						|
        MetricData=[
 | 
						|
            dict(
 | 
						|
                MetricName='metric',
 | 
						|
                Value=1.5,
 | 
						|
            )
 | 
						|
        ]
 | 
						|
    )
 | 
						|
 | 
						|
    metrics = conn.list_metrics()['Metrics']
 | 
						|
    metrics.should.have.length_of(1)
 | 
						|
    metric = metrics[0]
 | 
						|
    metric['Namespace'].should.equal('tester')
 | 
						|
    metric['MetricName'].should.equal('metric')
 | 
						|
 | 
						|
 | 
						|
 | 
						|
@mock_cloudwatch
 | 
						|
def test_put_metric_data_with_statistics():
 | 
						|
    conn = boto3.client('cloudwatch', region_name='us-east-1')
 | 
						|
 | 
						|
    conn.put_metric_data(
 | 
						|
        Namespace='tester',
 | 
						|
        MetricData=[
 | 
						|
            dict(
 | 
						|
                MetricName='statmetric',
 | 
						|
                Timestamp=datetime(2015, 1, 1),
 | 
						|
                # no Value to test  https://github.com/spulec/moto/issues/1615
 | 
						|
                StatisticValues=dict(
 | 
						|
                    SampleCount=123.0,
 | 
						|
                    Sum=123.0,
 | 
						|
                    Minimum=123.0,
 | 
						|
                    Maximum=123.0
 | 
						|
                ),
 | 
						|
                Unit='Milliseconds',
 | 
						|
                StorageResolution=123
 | 
						|
            )
 | 
						|
        ]
 | 
						|
    )
 | 
						|
 | 
						|
    metrics = conn.list_metrics()['Metrics']
 | 
						|
    metrics.should.have.length_of(1)
 | 
						|
    metric = metrics[0]
 | 
						|
    metric['Namespace'].should.equal('tester')
 | 
						|
    metric['MetricName'].should.equal('statmetric')
 | 
						|
    # TODO: test statistics - https://github.com/spulec/moto/issues/1615
 | 
						|
 | 
						|
@mock_cloudwatch
 | 
						|
def test_get_metric_statistics():
 | 
						|
    conn = boto3.client('cloudwatch', region_name='us-east-1')
 | 
						|
    utc_now = datetime.now(tz=pytz.utc)
 | 
						|
 | 
						|
    conn.put_metric_data(
 | 
						|
        Namespace='tester',
 | 
						|
        MetricData=[
 | 
						|
            dict(
 | 
						|
                MetricName='metric',
 | 
						|
                Value=1.5,
 | 
						|
                Timestamp=utc_now
 | 
						|
            )
 | 
						|
        ]
 | 
						|
    )
 | 
						|
 | 
						|
    stats = conn.get_metric_statistics(
 | 
						|
        Namespace='tester',
 | 
						|
        MetricName='metric',
 | 
						|
        StartTime=utc_now - timedelta(seconds=60),
 | 
						|
        EndTime=utc_now + timedelta(seconds=60),
 | 
						|
        Period=60,
 | 
						|
        Statistics=['SampleCount', 'Sum']
 | 
						|
    )
 | 
						|
 | 
						|
    stats['Datapoints'].should.have.length_of(1)
 | 
						|
    datapoint = stats['Datapoints'][0]
 | 
						|
    datapoint['SampleCount'].should.equal(1.0)
 | 
						|
    datapoint['Sum'].should.equal(1.5)
 |