151 lines
4.4 KiB
Python
151 lines
4.4 KiB
Python
import time
|
|
from datetime import timedelta, datetime
|
|
|
|
import boto3
|
|
import pytest
|
|
from botocore.exceptions import ClientError
|
|
|
|
from moto import mock_logs
|
|
from moto.core.utils import unix_time, unix_time_millis
|
|
|
|
|
|
@mock_logs
|
|
def test_start_query__unknown_log_group():
|
|
client = boto3.client("logs", "us-east-1")
|
|
|
|
log_group_name = "/aws/codebuild/lowercase-dev"
|
|
client.create_log_group(logGroupName=log_group_name)
|
|
|
|
response = client.start_query(
|
|
logGroupName=log_group_name,
|
|
startTime=int(time.time()),
|
|
endTime=int(time.time()) + 300,
|
|
queryString="test",
|
|
)
|
|
|
|
assert "queryId" in response
|
|
|
|
with pytest.raises(ClientError) as exc:
|
|
client.start_query(
|
|
logGroupName="/aws/codebuild/lowercase-dev-invalid",
|
|
startTime=int(time.time()),
|
|
endTime=int(time.time()) + 300,
|
|
queryString="test",
|
|
)
|
|
|
|
# then
|
|
exc_value = exc.value
|
|
assert "ResourceNotFoundException" in exc_value.response["Error"]["Code"]
|
|
assert (
|
|
exc_value.response["Error"]["Message"]
|
|
== "The specified log group does not exist"
|
|
)
|
|
|
|
|
|
@mock_logs
|
|
def test_get_query_results():
|
|
client = boto3.client("logs", "us-east-1")
|
|
log_group_name = "test"
|
|
log_stream_name = "stream"
|
|
client.create_log_group(logGroupName=log_group_name)
|
|
client.create_log_stream(logGroupName=log_group_name, logStreamName=log_stream_name)
|
|
|
|
data = [
|
|
(
|
|
int(unix_time_millis(datetime.utcnow() - timedelta(minutes=x))),
|
|
f"event nr {x}",
|
|
)
|
|
for x in range(5)
|
|
]
|
|
events = [{"timestamp": x, "message": y} for x, y in reversed(data)]
|
|
|
|
client.put_log_events(
|
|
logGroupName=log_group_name, logStreamName=log_stream_name, logEvents=events
|
|
)
|
|
|
|
query_id = client.start_query(
|
|
logGroupName="test",
|
|
startTime=int(unix_time(datetime.utcnow() - timedelta(minutes=10))),
|
|
endTime=int(unix_time(datetime.utcnow() + timedelta(minutes=10))),
|
|
queryString="fields @message",
|
|
)["queryId"]
|
|
|
|
resp = client.get_query_results(queryId=query_id)
|
|
assert resp["status"] == "Complete"
|
|
assert len(resp["results"]) == 5
|
|
|
|
fields = set([row["field"] for field in resp["results"] for row in field])
|
|
assert fields == {"@ptr", "@message"}
|
|
|
|
messages = [
|
|
row["value"]
|
|
for field in resp["results"]
|
|
for row in field
|
|
if row["field"] == "@message"
|
|
]
|
|
assert messages == [
|
|
"event nr 4",
|
|
"event nr 3",
|
|
"event nr 2",
|
|
"event nr 1",
|
|
"event nr 0",
|
|
]
|
|
|
|
# Only find events from last 2 minutes
|
|
query_id = client.start_query(
|
|
logGroupName="test",
|
|
startTime=int(unix_time(datetime.utcnow() - timedelta(minutes=2, seconds=1))),
|
|
endTime=int(unix_time(datetime.utcnow() - timedelta(seconds=1))),
|
|
queryString="fields @message",
|
|
)["queryId"]
|
|
|
|
resp = client.get_query_results(queryId=query_id)
|
|
assert len(resp["results"]) == 2
|
|
|
|
messages = [
|
|
row["value"]
|
|
for field in resp["results"]
|
|
for row in field
|
|
if row["field"] == "@message"
|
|
]
|
|
assert messages == ["event nr 2", "event nr 1"]
|
|
|
|
|
|
@mock_logs
|
|
def test_describe_completed_query():
|
|
client = boto3.client("logs", "us-east-1")
|
|
|
|
client.create_log_group(logGroupName="test")
|
|
|
|
query_id = client.start_query(
|
|
logGroupName="test",
|
|
startTime=int(unix_time(datetime.utcnow() + timedelta(minutes=10))),
|
|
endTime=int(unix_time(datetime.utcnow() + timedelta(minutes=10))),
|
|
queryString="fields @message",
|
|
)["queryId"]
|
|
|
|
queries = client.describe_queries(logGroupName="test")["queries"]
|
|
|
|
assert len(queries) == 1
|
|
assert queries[0]["queryId"] == query_id
|
|
assert queries[0]["queryString"] == "fields @message"
|
|
assert queries[0]["status"] == "Complete"
|
|
assert queries[0]["createTime"]
|
|
assert queries[0]["logGroupName"] == "test"
|
|
|
|
queries = client.describe_queries(logGroupName="test", status="Complete")["queries"]
|
|
assert len(queries) == 1
|
|
|
|
queries = client.describe_queries(logGroupName="test", status="Scheduled")[
|
|
"queries"
|
|
]
|
|
assert len(queries) == 0
|
|
|
|
|
|
@mock_logs
|
|
def test_describe_queries_on_log_group_without_any():
|
|
client = boto3.client("logs", "us-east-1")
|
|
|
|
client.create_log_group(logGroupName="test1")
|
|
assert client.describe_queries(logGroupName="test1")["queries"] == []
|