Add --csv-rows option

Add an option to include only --csv-rows <rows> number of rows in the
CSV output.

Change-Id: Ib6d8bf20561b42afef119533b571d7f1f32739a9
This commit is contained in:
Russell Bryant 2013-12-04 18:25:13 -05:00
parent 3fa41ac470
commit 617b8f5ea2
2 changed files with 43 additions and 1 deletions

View File

@ -111,11 +111,13 @@ def write_csv(reviewer_data, file_obj, options, reviewers, projects,
if ENABLE_RECEIVED: if ENABLE_RECEIVED:
row.append('Received') row.append('Received')
writer.writerow(row) writer.writerow(row)
for (name, r_data, d_data, s_data) in reviewer_data: for i, (name, r_data, d_data, s_data) in enumerate(reviewer_data, start=1):
row = [name, r_data, d_data] row = [name, r_data, d_data]
if ENABLE_RECEIVED: if ENABLE_RECEIVED:
row.append(s_data) row.append(s_data)
writer.writerow(row) writer.writerow(row)
if options.csv_rows and i == options.csv_rows:
break
def write_pretty(reviewer_data, file_obj, options, reviewers, projects, def write_pretty(reviewer_data, file_obj, options, reviewers, projects,
@ -241,6 +243,9 @@ def main(argv=None):
'-u', '--user', default=getpass.getuser(), help='gerrit user') '-u', '--user', default=getpass.getuser(), help='gerrit user')
optparser.add_option( optparser.add_option(
'-k', '--key', default=None, help='ssh key for gerrit') '-k', '--key', default=None, help='ssh key for gerrit')
optparser.add_option(
'-r', '--csv-rows', default=0, help='Max rows for CSV output',
type='int', dest='csv_rows')
options, args = optparser.parse_args() options, args = optparser.parse_args()

37
tests/test_reviewers.py Normal file
View File

@ -0,0 +1,37 @@
# Copyright (C) 2013 - Red Hat, Inc.
#
# 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 unittest
import six
import reviewstats.cmd.reviewers
class ReviewersCSVTestCase(unittest.TestCase):
def test_csv_rows(self):
class Options(object):
pass
options = Options()
options.csv_rows = 10
reviewer_data = [('', '', '', '')] * 100
sio = six.StringIO()
reviewstats.cmd.reviewers.write_csv(reviewer_data, sio, options, {},
{}, {}, {})
# NOTE(russellb) With csv_rows set to 10, the output should have 11
# lines: a heading line plus 10 rows
self.assertEqual(sio.getvalue().count('\n'), 11)