| #!/usr/bin/env python3 |
| # |
| # Copyright 2019, The Android Open Source Project |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| # |
| """Unit tests for the logcat_utils.py script.""" |
| |
| import asyncio |
| import datetime |
| import re |
| |
| import logcat_utils |
| from mock import MagicMock, patch |
| |
| def test_parse_logcat_datatime(): |
| # Act |
| result = logcat_utils.parse_logcat_datetime('2019-07-01 16:13:55.221') |
| |
| # Assert |
| assert result == datetime.datetime(2019, 7, 1, 16, 13, 55, 221000) |
| |
| class AsyncMock(MagicMock): |
| async def __call__(self, *args, **kwargs): |
| return super(AsyncMock, self).__call__(*args, **kwargs) |
| |
| def _async_return(): |
| f = asyncio.Future() |
| f.set_result( |
| b'2019-07-01 15:51:53.290 27365 27392 I ActivityTaskManager: ' |
| b'Displayed com.google.android.music/com.android.music.activitymanagement.' |
| b'TopLevelActivity: +1s7ms') |
| return f |
| |
| def test_parse_displayed_time_succeed(): |
| # Act |
| with patch('asyncio.create_subprocess_exec', |
| new_callable=AsyncMock) as asyncio_mock: |
| asyncio_mock.return_value.stdout.readline = _async_return |
| timestamp = datetime.datetime(datetime.datetime.now().year, 7, 1, 16, 13, |
| 55, 221000) |
| timeout_dt = timestamp + datetime.timedelta(0, 10) |
| pattern = re.compile('.*ActivityTaskManager: Displayed ' |
| 'com.google.android.music/com.android.music.*') |
| result = logcat_utils.blocking_wait_for_logcat_pattern(timestamp, |
| pattern, |
| timeout_dt) |
| |
| # Assert |
| assert result == '2019-07-01 15:51:53.290 27365 27392 I ' \ |
| 'ActivityTaskManager: ' \ |
| 'Displayed com.google.android.music/com.android.music.' \ |
| 'activitymanagement.TopLevelActivity: +1s7ms' |
| |
| def _async_timeout_return(): |
| f = asyncio.Future() |
| f.set_result( |
| b'2019-07-01 17:51:53.290 27365 27392 I ActivityTaskManager: ' |
| b'Displayed com.google.android.music/com.android.music.activitymanagement.' |
| b'TopLevelActivity: +1s7ms') |
| return f |
| |
| def test_parse_displayed_time_timeout(): |
| # Act |
| with patch('asyncio.create_subprocess_exec', |
| new_callable=AsyncMock) as asyncio_mock: |
| asyncio_mock.return_value.stdout.readline = _async_timeout_return |
| timestamp = datetime.datetime(datetime.datetime.now().year, |
| 7, 1, 16, 13, 55, 221000) |
| timeout_dt = timestamp + datetime.timedelta(0, 10) |
| pattern = re.compile('.*ActivityTaskManager: Displayed ' |
| 'com.google.android.music/com.android.music.*') |
| result = logcat_utils.blocking_wait_for_logcat_pattern(timestamp, |
| pattern, |
| timeout_dt) |
| |
| # Assert |
| assert result == None |