Merge "Handle test_runs without metadata in write_subunit"
This commit is contained in:
commit
3fa9a5403a
66
subunit2sql/tests/test_write_subunit.py
Normal file
66
subunit2sql/tests/test_write_subunit.py
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
# Copyright (c) 2015 Hewlett-Packard Development Company, L.P.
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
|
||||||
|
import datetime
|
||||||
|
|
||||||
|
import mock
|
||||||
|
|
||||||
|
from subunit2sql.tests import base
|
||||||
|
from subunit2sql import write_subunit
|
||||||
|
|
||||||
|
timestamp_a = datetime.datetime.utcnow()
|
||||||
|
timestamp_b = datetime.datetime.utcnow()
|
||||||
|
|
||||||
|
|
||||||
|
class TestWriteSubunit(base.TestCase):
|
||||||
|
|
||||||
|
@mock.patch('subunit2sql.db.api.get_tests_run_dicts_from_run_id',
|
||||||
|
return_value={'fake_test_id': {
|
||||||
|
'start_time': timestamp_a,
|
||||||
|
'stop_time': timestamp_b,
|
||||||
|
'status': 'success'}})
|
||||||
|
@mock.patch('subunit2sql.write_subunit.write_test')
|
||||||
|
@mock.patch('subunit2sql.db.api.get_session')
|
||||||
|
def test_test_runs_without_metdata(self, api_mock, write_mock,
|
||||||
|
sesion_mock):
|
||||||
|
out = mock.MagicMock()
|
||||||
|
write_subunit.sql2subunit('fake_id', out)
|
||||||
|
self.assertEqual(write_mock.call_count, 1)
|
||||||
|
args = write_mock.call_args_list[0][0]
|
||||||
|
self.assertEqual(timestamp_a, args[1])
|
||||||
|
self.assertEqual(timestamp_b, args[2])
|
||||||
|
self.assertEqual('success', args[3])
|
||||||
|
self.assertEqual('fake_test_id', args[4])
|
||||||
|
self.assertEqual(None, args[5])
|
||||||
|
|
||||||
|
@mock.patch('subunit2sql.db.api.get_tests_run_dicts_from_run_id',
|
||||||
|
return_value={'fake_test_id': {
|
||||||
|
'start_time': timestamp_a,
|
||||||
|
'stop_time': timestamp_b,
|
||||||
|
'status': 'success',
|
||||||
|
'metadata': {
|
||||||
|
'key': 'value'}}})
|
||||||
|
@mock.patch('subunit2sql.write_subunit.write_test')
|
||||||
|
@mock.patch('subunit2sql.db.api.get_session')
|
||||||
|
def test_test_runs_with_metdata(self, api_mock, write_mock, session_mock):
|
||||||
|
out = mock.MagicMock()
|
||||||
|
write_subunit.sql2subunit('fake_id', out)
|
||||||
|
self.assertEqual(write_mock.call_count, 1)
|
||||||
|
args = write_mock.call_args_list[0][0]
|
||||||
|
self.assertEqual(timestamp_a, args[1])
|
||||||
|
self.assertEqual(timestamp_b, args[2])
|
||||||
|
self.assertEqual('success', args[3])
|
||||||
|
self.assertEqual('fake_test_id', args[4])
|
||||||
|
self.assertEqual({'key': 'value'}, args[5])
|
@ -59,11 +59,12 @@ def convert_datetime(timestamp):
|
|||||||
def write_test(output, start_time, stop_time, status, test_id, metadatas):
|
def write_test(output, start_time, stop_time, status, test_id, metadatas):
|
||||||
write_status = output.status
|
write_status = output.status
|
||||||
kwargs = {}
|
kwargs = {}
|
||||||
if 'tags' in metadatas:
|
if metadatas:
|
||||||
tags = metadatas['tags']
|
if 'tags' in metadatas:
|
||||||
kwargs['test_tags'] = tags.split(',')
|
tags = metadatas['tags']
|
||||||
if 'attrs' in metadatas:
|
kwargs['test_tags'] = tags.split(',')
|
||||||
test_id = test_id + '[' + metadatas['attrs'] + ']'
|
if 'attrs' in metadatas:
|
||||||
|
test_id = test_id + '[' + metadatas['attrs'] + ']'
|
||||||
start_time = convert_datetime(start_time)
|
start_time = convert_datetime(start_time)
|
||||||
kwargs['timestamp'] = start_time
|
kwargs['timestamp'] = start_time
|
||||||
kwargs['test_id'] = test_id
|
kwargs['test_id'] = test_id
|
||||||
@ -82,8 +83,11 @@ def sql2subunit(run_id, output=sys.stdout):
|
|||||||
output.startTestRun()
|
output.startTestRun()
|
||||||
for test_id in test_runs:
|
for test_id in test_runs:
|
||||||
test = test_runs[test_id]
|
test = test_runs[test_id]
|
||||||
|
# NOTE(mtreinish): test_run_metadata is not guaranteed to be present
|
||||||
|
# for the test_run.
|
||||||
|
metadata = test.get('metadata', None)
|
||||||
write_test(output, test['start_time'], test['stop_time'],
|
write_test(output, test['start_time'], test['stop_time'],
|
||||||
test['status'], test_id, test['metadata'])
|
test['status'], test_id, metadata)
|
||||||
output.stopTestRun()
|
output.stopTestRun()
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user