]>
git.apps.os.sepia.ceph.com Git - ceph-ci.git/log 
Patrick Donnelly  [Sat, 11 Aug 2018 23:27:48 +0000  (16:27 -0700)] 
Merge PR #23480 into masterReviewed-by: Patrick Donnelly <pdonnell@redhat.com> 
Casey Bodley  [Sat, 11 Aug 2018 14:48:24 +0000  (10:48 -0400)] 
Merge pull request #22868 from iliul/modify-log-levelReviewed-by: Casey Bodley <cbodley@redhat.com> 
iliul  [Thu, 5 Jul 2018 08:20:27 +0000  (16:20 +0800)] 
rgw: Fix log level of gc_iterate_entriesFixes: http://tracker.ceph.com/issues/23801 Signed-off-by: iliul <liul.stone@gmail.com> 
Sage Weil  [Fri, 10 Aug 2018 21:32:34 +0000  (16:32 -0500)] 
Merge PR #22838 into masterReviewed-by: Sage Weil <sage@redhat.com> 
Sage Weil  [Fri, 10 Aug 2018 21:32:29 +0000  (16:32 -0500)] 
Merge PR #22970 into masterReviewed-by: Sage Weil <sage@redhat.com> 
Yuri Weinstein  [Fri, 10 Aug 2018 16:14:09 +0000  (09:14 -0700)] 
Merge pull request #22967 from linuxbox2/wip-slo-nosizeReviewed-by: Casey Bodley <cbodley@redhat.com> 
Yuri Weinstein  [Fri, 10 Aug 2018 16:13:40 +0000  (09:13 -0700)] 
Merge pull request #23056 from stiopaa1/fixRgwAdminUserReviewed-by: Orit Wasserman <owasserm@redhat.com> 
Yuri Weinstein  [Fri, 10 Aug 2018 16:13:18 +0000  (09:13 -0700)] 
Merge pull request #23282 from zhangsw/fix-rgw-server-headerReviewed-by: Casey Bodley <cbodley@redhat.com> 
Yuri Weinstein  [Fri, 10 Aug 2018 16:12:41 +0000  (09:12 -0700)] 
Merge pull request #23405 from joke-lee/WIP-RGW-BUCKET-NOTIFYReviewed-by: Casey Bodley <cbodley@redhat.com> 
Yuri Weinstein  [Fri, 10 Aug 2018 16:12:15 +0000  (09:12 -0700)] 
Merge pull request #23434 from joke-lee/wip-cors-rule-num-limitReviewed-by: Matt Benjamin <mbenjami@redhat.com> 
Alfredo Deza  [Fri, 10 Aug 2018 15:15:29 +0000  (11:15 -0400)] 
Merge pull request #23210 from alfredodeza/wip-bluestore-sizingReviewed-by: Ben England <bengland@redhat.com> Reviewed-by: Josh Durgin <jdurgin@redhat.com> Reviewed-by: Sage Weil <sage@redhat.com> 
Casey Bodley  [Fri, 10 Aug 2018 13:00:47 +0000  (09:00 -0400)] 
Merge pull request #23511 from excellentkf/WIP-testReviewed-by: Casey Bodley <cbodley@redhat.com> 
Kefu Chai  [Fri, 10 Aug 2018 04:45:29 +0000  (12:45 +0800)] 
Merge pull request #23496 from bstillwell/crush_doc_fixesReviewed-by: Kefu Chai <kchai@redhat.com> 
Kefu Chai  [Fri, 10 Aug 2018 02:54:13 +0000  (10:54 +0800)] 
Merge pull request #23477 from liewegas/wip-kv-merge-nameReviewed-by: Kefu Chai <kchai@redhat.com> 
Kefu Chai  [Fri, 10 Aug 2018 02:52:53 +0000  (10:52 +0800)] 
Merge pull request #23474 from tchaikov/wip-config-expand-metaReviewed-by: Igor Fedotov <ifedotov@suse.com> Reviewed-by: Sage Weil <sage@redhat.com> Reviewed-by: Casey Bodley <cbodley@redhat.com> 
yanjun  [Fri, 10 Aug 2018 02:51:52 +0000  (10:51 +0800)] 
Merge pull request #23481 from Yan-waller/wip-walle-180808-smooth-intervalsReviewed-by: John Spray <john.spray@redhat.com> 
yanjun  [Fri, 10 Aug 2018 02:49:19 +0000  (10:49 +0800)] 
Merge pull request #23482 from Yan-waller/wip-walle-180808-mgr-deadlockReviewed-by: John Spray <john.spray@redhat.com> Reviewed-by: xie xingguo <xie.xingguo@zte.com.cn> 
yanjun  [Fri, 10 Aug 2018 02:47:19 +0000  (10:47 +0800)] 
Merge pull request #23487 from xiexingguo/wip-hb-peers-v2Reviewed-by: Sage Weil <sage@redhat.com> Reviewed-by: Yan Jun <yan.jun8@zte.com.cn> 
Mark Nelson  [Thu, 9 Aug 2018 21:50:16 +0000  (16:50 -0500)] 
kv/RocksDBStore: Handle nullptr if clock cache is chosen.Signed-off-by: Mark Nelson <mnelson@redhat.com> 
Mark Nelson  [Tue, 3 Jul 2018 22:30:23 +0000  (17:30 -0500)] 
kv/rocksdb_cache/BinnedLRUCache: Don't promote data to the high pri pool.Signed-off-by: Mark Nelson <mnelson@redhat.com> 
Mark Nelson  [Tue, 3 Jul 2018 15:42:14 +0000  (10:42 -0500)] 
src/kv: Initial import of a custom RocksDB cache.Signed-off-by: Mark Nelson <mnelson@redhat.com> 
Alfredo Deza  [Thu, 9 Aug 2018 21:41:58 +0000  (17:41 -0400)] 
Merge pull request #23514 from bstillwell/operations_doc_fixesReviewed-by: Alfredo Deza <adeza@redhat.com> 
Bryan Stillwell  [Thu, 9 Aug 2018 20:51:25 +0000  (14:51 -0600)] 
doc: Multiple spelling fixesSigned-off-by: Bryan Stillwell <bstillwell@godaddy.com> 
Mark Nelson  [Wed, 20 Jun 2018 02:59:26 +0000  (21:59 -0500)] 
os/bluestore: limit OSD memory usage by tuning the cache size.Signed-off-by: Mark Nelson <mnelson@redhat.com> 
Sage Weil  [Thu, 9 Aug 2018 19:35:56 +0000  (14:35 -0500)] 
Merge PR #23471 into masterReviewed-by: Kefu Chai <kchai@redhat.com> Reviewed-by: João Eduardo Luís <joao@suse.de> 
Sage Weil  [Thu, 9 Aug 2018 19:35:50 +0000  (14:35 -0500)] 
Merge PR #23473 into masterReviewed-by: Sage Weil <sage@redhat.com> 
Bryan Stillwell  [Wed, 8 Aug 2018 21:24:53 +0000  (15:24 -0600)] 
doc: Fix a couple typos and improve diagram formattingSigned-off-by: Bryan Stillwell <bstillwell@godaddy.com> 
Kefu Chai  [Sat, 4 Aug 2018 12:52:29 +0000  (20:52 +0800)] 
tools/cephfs: fix mkdirs(exist_ok) callSigned-off-by: Kefu Chai <kchai@redhat.com> 
Kefu Chai  [Thu, 9 Aug 2018 11:36:13 +0000  (19:36 +0800)] 
tools/cephfs: cephfs-shell cleanupSigned-off-by: Kefu Chai <kchai@redhat.com> 
Kefu Chai  [Thu, 9 Aug 2018 11:28:48 +0000  (19:28 +0800)] 
tools/cephfs: run cephfs-shell thru autopep8Signed-off-by: Kefu Chai <kchai@redhat.com> 
Sage Weil  [Thu, 9 Aug 2018 13:06:25 +0000  (08:06 -0500)] 
Merge PR #23422 into masterReviewed-by: Kefu Chai <kchai@redhat.com> 
excellentkf  [Thu, 9 Aug 2018 12:39:10 +0000  (20:39 +0800)] 
common/options: correct the description of rgw_enable_lc_threads optionSigned-off-by: excellentkf <likefei@cmss.chinamobile.com> 
Kefu Chai  [Thu, 9 Aug 2018 12:35:17 +0000  (20:35 +0800)] 
Merge pull request #23466 from tspmelo/wip-update-packagesReviewed-by: Ernesto Puerta <epuertat@redhat.com> 
John Wilkins  [Thu, 9 Aug 2018 04:23:28 +0000  (21:23 -0700)] 
Merge pull request #23431 from falcon78921/wip-doc-rados-poolReviewed-by: John Wilkins <jowilkin@redhat.com> 
xie xingguo  [Mon, 30 Jul 2018 01:22:32 +0000  (09:22 +0800)] 
osd/OSD.cc: force updating heartbeat peers periodicallySigned-off-by: xie xingguo <xie.xingguo@zte.com.cn> 
xie xingguo  [Mon, 30 Jul 2018 00:40:59 +0000  (08:40 +0800)] 
crush/CrushWrapper: check against dead crush ruleSigned-off-by: xie xingguo <xie.xingguo@zte.com.cn> 
xie xingguo  [Wed, 8 Aug 2018 09:52:29 +0000  (17:52 +0800)] 
osd/OSD.cc: choose heartbeat peers by failure domainSigned-off-by: xie xingguo <xie.xingguo@zte.com.cn> 
Kefu Chai  [Wed, 8 Aug 2018 16:46:53 +0000  (00:46  +0800)] 
Merge pull request #23441 from tchaikov/wip-cmake-rocksdb-cleanupReviewed-by: Casey Bodley <cbodley@redhat.com> 
Patrick Donnelly  [Wed, 8 Aug 2018 16:40:21 +0000  (09:40 -0700)] 
Merge PR #23462 into masterReviewed-by: Patrick Donnelly <pdonnell@redhat.com> 
Sage Weil  [Tue, 7 Aug 2018 13:48:45 +0000  (08:48 -0500)] 
mon/PGMap: fix spacing around pretty-printed SI unitsSigned-off-by: Sage Weil <sage@redhat.com> 
Andrew Schoen  [Wed, 8 Aug 2018 15:43:49 +0000  (15:43 +0000)] 
Merge pull request #23489 from alfredodeza/wip-cv-mgrReviewed-by: Andrew Schoen <aschoen@redhat.com> 
Sage Weil  [Wed, 8 Aug 2018 13:31:31 +0000  (08:31 -0500)] 
Merge PR #23475 into masterReviewed-by: Kefu Chai <kchai@redhat.com> 
Sage Weil  [Wed, 8 Aug 2018 13:31:26 +0000  (08:31 -0500)] 
Merge PR #23478 into masterReviewed-by: Kefu Chai <kchai@redhat.com> 
Igor Fedotov  [Wed, 8 Aug 2018 13:20:16 +0000  (16:20 +0300)] 
Merge pull request #23267 from ifed01/wip-ifed-rm-fio-dirReviewed-by: Kefu Chai <kchai@redhat.com> 
Alfredo Deza  [Wed, 8 Aug 2018 12:29:03 +0000  (08:29 -0400)] 
ceph-volume tests/functional add mgrs daemons to lvm testsSigned-off-by: Alfredo Deza <adeza@redhat.com> 
xie xingguo  [Wed, 8 Aug 2018 08:46:16 +0000  (16:46 +0800)] 
crush/CrushWrapper: get_children_of_type - switch outcome to vectorSigned-off-by: xie xingguo <xie.xingguo@zte.com.cn> 
Yan Jun  [Wed, 8 Aug 2018 07:24:37 +0000  (15:24 +0800)] 
mgr: fix beacon interruption caused by deadlockSigned-off-by: Yan Jun <yan.jun8@zte.com.cn> 
Yan Jun  [Wed, 8 Aug 2018 06:35:38 +0000  (14:35 +0800)] 
mgr: fix to apply changed mon_stat_smooth_intervalsSigned-off-by: Yan Jun <yan.jun8@zte.com.cn> 
Sage Weil  [Wed, 8 Aug 2018 01:43:49 +0000  (20:43 -0500)] 
mgr/localpool: pg_num is an int arg to 'osd pool create'
In 
bd565bca3f42d7946c392b2833bb3d9982a8ac5d  we start returning EINVAL if
the pg_num argument is not valid, whereas before it was silently ignored.
Signed-off-by: Sage Weil <sage@redhat.com> 
Sage Weil  [Tue, 7 Aug 2018 22:02:56 +0000  (17:02 -0500)] 
kv/KeyValueDB: return const char* from MergeOperator::name()Fixes: http://tracker.ceph.com/issues/26875 Signed-off-by: Sage Weil <sage@redhat.com> 
Mark Nelson  [Tue, 3 Jul 2018 13:13:00 +0000  (08:13 -0500)] 
src/rocksdb: switch back to master branch.Signed-off-by: Mark Nelson <mnelson@redhat.com> 
Alfredo Deza  [Tue, 7 Aug 2018 17:12:36 +0000  (13:12 -0400)] 
Merge pull request #23472 from jcsp/wip-orchestrator-rook-docReviewed-by: Alfredo Deza <adeza@redhat.com> 
Sage Weil  [Tue, 7 Aug 2018 16:55:22 +0000  (11:55 -0500)] 
qa/standalone/crush/crush-choose-args: run mgrFixes: d2b41d4095074447df247907934626f4287cd91b Signed-off-by: Sage Weil <sage@redhat.com> 
Kefu Chai  [Tue, 7 Aug 2018 15:55:30 +0000  (23:55 +0800)] 
common: expand meta in parse_argv()
it fixes the issue where the conf->foo fails to expand if it is set
as "$bar" in a .conf file, and "bar" is another config var, and bar
is set using config_proxy.parse_argv().
because before 
773ef117 , apply_changes() calls update_legacy_vals(),
which expand meta vars for legacy config vals, but after 
773ef117 ,
we cannot change config_values in apply_changes() anymore. so
update_legacy_vals() calls is moved to apply_changes()'s callers
accordingly. but the apply_changes() is also called by global_init()
directly instead of by the routines in config.cc. so in 
773ef117 ,
i missed it.
in this change, it's put back into parse_argv() instead of into
global_init(), as update_legacy_vals() is a low level function, and
parse_argv() could change the config_values, it's better to call
update_legacy_vals() out there, just like set_mon_vals() and
parse_config_files().
Signed-off-by: Kefu Chai <kchai@redhat.com> 
Willem Jan Withagen  [Tue, 7 Aug 2018 14:57:00 +0000  (16:57 +0200)] 
OSD: translate the error resultSigned-off-by: Willem Jan Withagen <wjw@digiware.nl> 
Igor Fedotov  [Tue, 7 Aug 2018 14:19:15 +0000  (17:19 +0300)] 
test/fio: pass config params to object store in a different mannerSigned-off-by: Igor Fedotov <ifedotov@suse.com> 
John Spray  [Tue, 7 Aug 2018 13:54:19 +0000  (09:54 -0400)] 
doc: Rook/orchestrator doc fixesSigned-off-by: John Spray <john.spray@redhat.com> 
Sage Weil  [Tue, 7 Aug 2018 13:59:39 +0000  (08:59 -0500)] 
Merge PR #23432 into master
Sage Weil  [Tue, 7 Aug 2018 13:54:00 +0000  (08:54 -0500)] 
Merge PR #23243 into masterReviewed-by: xie xingguo <xie.xingguo@zte.com.cn> Reviewed-by: Patrick Donnelly <pdonnell@redhat.com> 
Sage Weil  [Tue, 7 Aug 2018 13:53:55 +0000  (08:53 -0500)] 
Merge PR #23338 into master
Sage Weil  [Tue, 7 Aug 2018 13:53:51 +0000  (08:53 -0500)] 
Merge PR #23412 into masterReviewed-by: Sage Weil <sage@redhat.com> 
Sage Weil  [Mon, 6 Aug 2018 18:31:53 +0000  (13:31 -0500)] 
include/types: render SI units adjacent to numberSigned-off-by: Sage Weil <sage@redhat.com> 
Kefu Chai  [Tue, 7 Aug 2018 10:18:01 +0000  (18:18 +0800)] 
Merge pull request #23430 from tchaikov/wip-silence-clang-warningsReviewed-by: John Spray <john.spray@redhat.com> 
Sebastian Wagner  [Tue, 7 Aug 2018 09:43:48 +0000  (11:43 +0200)] 
Merge pull request #23420 from tspmelo/fix-24902Reviewed-by: Volker Theile <vtheile@suse.com> Reviewed-by: Stephan Müller <smueller@suse.com> Reviewed-by: Laura Paduano <lpaduano@suse.com> 
Sebastian Wagner  [Tue, 7 Aug 2018 09:38:56 +0000  (11:38 +0200)] 
Merge pull request #23414 from tspmelo/wip-breadcrumbsReviewed-by: Ricardo Marques <rimarques@suse.com> Reviewed-by: Volker Theile <vtheile@suse.com> 
Yan, Zheng  [Tue, 7 Aug 2018 09:05:37 +0000  (17:05 +0800)] 
Merge pull request #23465 from ukernel/wip-revert-22850
Tiago Melo  [Mon, 6 Aug 2018 17:44:15 +0000  (18:44 +0100)] 
mgr/dashboard: Update prettier packageSigned-off-by: Tiago Melo <tmelo@suse.com> 
Yan, Zheng  [Tue, 7 Aug 2018 09:00:02 +0000  (17:00 +0800)] 
Revert "cephfs-journal-tool: enable purge_queue journal's event commands"
This reverts commit 
8ebfa93982a95d6ccc66faa2a828b9386af45238 . That
commit changes PurgeItem's encode/decode function, breaks backward
compatibility
Signed-off-by: "Yan, Zheng" <zyan@redhat.com> 
Tiago Melo  [Mon, 6 Aug 2018 17:37:39 +0000  (18:37 +0100)] 
mgr/dashboard: Update Codelyzer packageSigned-off-by: Tiago Melo <tmelo@suse.com> 
Tiago Melo  [Mon, 6 Aug 2018 16:48:13 +0000  (17:48 +0100)] 
mgr/dashboard: Update all @angular packagesSigned-off-by: Tiago Melo <tmelo@suse.com> 
Tiago Melo  [Mon, 6 Aug 2018 16:32:50 +0000  (17:32 +0100)] 
mgr/dashboard: Update frontend packagesSigned-off-by: Tiago Melo <tmelo@suse.com> 
Kefu Chai  [Tue, 7 Aug 2018 08:27:08 +0000  (16:27 +0800)] 
Merge pull request #22562 from wjwithagen/wjw-fix-dashboard-buildReviewed-by: Tiago Melo <tmelo@suse.com> 
Jos Collin  [Tue, 7 Aug 2018 04:16:40 +0000  (09:46 +0530)] 
doc: cleanup in cephfs/capabilitiesSigned-off-by: Jos Collin <jcollin@redhat.com> 
Xie Xingguo  [Tue, 7 Aug 2018 03:24:25 +0000  (11:24 +0800)] 
Merge pull request #23450 from neha-ojha/wip-fix-complete-toReviewed-by: xie xingguo <xie.xingguo@zte.com.cn> 
Willem Jan Withagen  [Thu, 14 Jun 2018 12:27:08 +0000  (14:27 +0200)] 
FreeBSD: update build script to current stateSigned-off-by: Willem Jan Withagen <wjw@digiware.nl> 
David Galloway  [Mon, 6 Aug 2018 21:02:00 +0000  (17:02 -0400)] 
Merge pull request #23456 from yuriw/wip-yuriw-crontab-master
Yuri Weinstein  [Mon, 6 Aug 2018 20:59:21 +0000  (13:59 -0700)] 
qa/tests: changed ceph qa email address to bypass dreamhost's spam filterSigned-off-by: Yuri Weinstein <yweinste@redhat.com> 
Andrew Schoen  [Mon, 6 Aug 2018 20:32:16 +0000  (20:32 +0000)] 
Merge pull request #23448 from alfredodeza/wip-rm26862Reviewed-by: Andrew Schoen <aschoen@redhat.com> 
Patrick Donnelly  [Mon, 6 Aug 2018 20:27:12 +0000  (13:27 -0700)] 
Merge PR #23433 into masterReviewed-by: Zheng Yan <zyan@redhat.com> 
Alfredo Deza  [Tue, 24 Jul 2018 18:39:59 +0000  (14:39 -0400)] 
doc/bluestore detail the different sizing strategies for block.db based on cluster workloadSigned-off-by: Alfredo Deza <adeza@redhat.com> 
Alfredo Deza  [Tue, 24 Jul 2018 16:51:56 +0000  (12:51 -0400)] 
doc/bluestore expand on configuration with fast and slow devicesSigned-off-by: Alfredo Deza <adeza@redhat.com> 
Patrick Donnelly  [Mon, 6 Aug 2018 18:43:44 +0000  (11:43 -0700)] 
Merge PR #22850 into masterReviewed-by: Patrick Donnelly <pdonnell@redhat.com> 
Patrick Donnelly  [Mon, 6 Aug 2018 18:43:35 +0000  (11:43 -0700)] 
Merge PR #22999 into masterReviewed-by: Patrick Donnelly <pdonnell@redhat.com> 
Patrick Donnelly  [Mon, 6 Aug 2018 18:43:24 +0000  (11:43 -0700)] 
Merge PR #23341 into masterReviewed-by: Patrick Donnelly <pdonnell@redhat.com> 
Patrick Donnelly  [Mon, 6 Aug 2018 18:43:09 +0000  (11:43 -0700)] 
Merge PR #23370 into masterReviewed-by: Patrick Donnelly <pdonnell@redhat.com> Reviewed-by: Zheng Yan <zyan@redhat.com> 
John Spray  [Mon, 6 Aug 2018 16:26:49 +0000  (17:26 +0100)] 
Merge pull request #23387 from jcsp/wip-mgr-rwReviewed-by: Sage Weil <sage@redhat.com> 
John Spray  [Mon, 6 Aug 2018 16:26:22 +0000  (17:26 +0100)] 
Merge pull request #23205 from jcsp/wip-devicehealth-cleanupReviewed-by: Sage Weil <sage@redhat.com> 
Neha Ojha  [Sat, 4 Aug 2018 00:38:22 +0000  (17:38 -0700)] 
osd/PGLog.cc: check if complete_to points to log.end()Signed-off-by: Neha Ojha <nojha@redhat.com> 
Andrew Schoen  [Mon, 6 Aug 2018 16:02:58 +0000  (16:02 +0000)] 
Merge pull request #23443 from alfredodeza/wip-rm24970Reviewed-by: Andrew Schoen <aschoen@redhat.com> 
Alfredo Deza  [Mon, 6 Aug 2018 15:59:05 +0000  (11:59 -0400)] 
ceph-volume lvm.batch move import statement to the topSigned-off-by: Alfredo Deza <adeza@redhat.com> 
Alfredo Deza  [Mon, 6 Aug 2018 15:58:31 +0000  (11:58 -0400)] 
ceph-volume lvm.batch allow extra flags for bluestoreSigned-off-by: Alfredo Deza <adeza@redhat.com> 
Ricardo Marques  [Mon, 6 Aug 2018 15:41:37 +0000  (16:41 +0100)] 
Merge pull request #23347 from votdev/bug_25190Reviewed-by: Ricardo Dias <rdias@suse.com> Reviewed-by: Tatjana Dehler <tdehler@suse.com> 
John Spray  [Mon, 6 Aug 2018 15:20:39 +0000  (16:20 +0100)] 
mgr: add Orchestrator.available method + CLISigned-off-by: John Spray <john.spray@redhat.com> 
John Spray  [Thu, 2 Aug 2018 14:32:38 +0000  (15:32 +0100)] 
doc: add general documentation on orchestratorSigned-off-by: John Spray <john.spray@redhat.com> 
John Spray  [Tue, 31 Jul 2018 15:18:33 +0000  (16:18 +0100)] 
doc: add page for Rook moduleSigned-off-by: John Spray <john.spray@redhat.com> 
John Spray  [Tue, 17 Jul 2018 11:35:11 +0000  (12:35 +0100)] 
doc: add development guide for Ceph+Rook in k8sSigned-off-by: John Spray <john.spray@redhat.com> 
John Spray  [Thu, 17 May 2018 13:09:44 +0000  (14:09 +0100)] 
script: add kubejacker scriptSigned-off-by: John Spray <john.spray@redhat.com> 
John Spray  [Wed, 2 May 2018 10:58:10 +0000  (11:58 +0100)] 
mgr/rook: Rook orchestrator moduleSigned-off-by: John Spray <john.spray@redhat.com> 
John Spray  [Wed, 2 May 2018 10:58:45 +0000  (11:58 +0100)] 
mgr/orchestrator_cli: module for calling into orchestatorsSigned-off-by: John Spray <john.spray@redhat.com> 
John Spray  [Wed, 21 Mar 2018 00:20:43 +0000  (08:20 +0800)] 
mgr: introduce `orchestrator` python interfaceSigned-off-by: John Spray <john.spray@redhat.com>