Add get_runs_counts_by_run_metadata()

This commit adds get_runs_counts_by_run_metadata() to validate a
key-value pair existence. This api is needed for openstack-health RSS
feed to avoid invalid 400 errors.

Change-Id: I792829aa703db29b2049d4895dd93e4efe352de4
Story: #2000614
This commit is contained in:
Masayuki Igawa 2016-05-31 17:49:36 +09:00
parent 6e79c4c569
commit cdd16df4b1
2 changed files with 53 additions and 0 deletions

View File

@ -1571,6 +1571,28 @@ def get_recent_failed_runs_by_run_metadata(key, value, num_runs=10,
models.Run.run_at.desc()).limit(num_runs).all()
def get_runs_counts_by_run_metadata(key, value, start_date=None, session=None):
"""Check runs for a given run metadata pair
:param str key: The run_metadata key to check runs
:param str value: The run_metadata value to check runs
:param datetime start_date: The optional starting dates to get runs from.
Nothing older than this date will be returned
:param session: Optional session object if one isn't provided a new session
will be acquired for the duration of this operation
:return count: A count for a given run metadata key-value pair
:rtype: int
"""
session = session or get_session()
query = db_utils.model_query(models.Run, session).join(
models.RunMetadata, models.Run.id == models.RunMetadata.run_id).filter(
models.RunMetadata.key == key,
models.RunMetadata.value == value)
query = _filter_runs_by_date(query, start_date)
return query.count()
def get_runs_by_status_grouped_by_run_metadata(key, start_date=None,
stop_date=None, session=None):
session = session or get_session()

View File

@ -862,6 +862,37 @@ class TestDatabaseAPI(base.TestCase):
self.assertEqual(1, len(results))
self.assertEqual(run_c.id, results[0].id)
def test_get_runs_counts_by_run_metadata_no_start_date(self):
run_a = api.create_run(fails=1)
api.create_run()
run_c = api.create_run(fails=2)
api.add_run_metadata({'fake_key': 'fake_value'}, run_a.id)
api.add_run_metadata({'zeon': 'zaku'}, run_c.id)
results = api.get_runs_counts_by_run_metadata('zeon', 'zaku')
self.assertEqual(1, results)
results = api.get_runs_counts_by_run_metadata('zeon', 'dom')
self.assertEqual(0, results)
def test_get_runs_counts_by_run_metadata_with_start_date(self):
run_a = api.create_run(fails=1)
api.create_run()
run_c = api.create_run(fails=2)
run_d = api.create_run(fails=3,
run_at=datetime.datetime(1914, 6, 28,
10, 45, 0))
api.add_run_metadata({'fake_key': 'fake_value'}, run_a.id)
api.add_run_metadata({'zeon': 'zaku'}, run_c.id)
api.add_run_metadata({'zeon': 'zaku'}, run_d.id)
results = api.get_runs_counts_by_run_metadata(
'zeon', 'zaku', start_date=datetime.date(1970, 1, 1))
self.assertEqual(1, results)
results = api.get_runs_counts_by_run_metadata(
'zeon', 'zaku', start_date=datetime.date(1914, 6, 27))
self.assertEqual(2, results)
results = api.get_runs_counts_by_run_metadata(
'zeon', 'dom', start_date=datetime.date(1914, 6, 27))
self.assertEqual(0, results)
def test_get_test_run_metadata(self):
run = api.create_run()
test = api.create_test('fake_test')