public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
From: "André Erdmann" <dywi@mailerd.de>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] proj/R_overlay:master commit in: roverlay/overlay/
Date: Sat,  9 Feb 2013 20:45:29 +0000 (UTC)	[thread overview]
Message-ID: <1360440494.0e093591866ba15abd66b692ec190602ee9d9673.dywi@gentoo> (raw)

commit:     0e093591866ba15abd66b692ec190602ee9d9673
Author:     André Erdmann <dywi <AT> mailerd <DOT> de>
AuthorDate: Sat Feb  9 19:16:45 2013 +0000
Commit:     André Erdmann <dywi <AT> mailerd <DOT> de>
CommitDate: Sat Feb  9 20:08:14 2013 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/R_overlay.git;a=commit;h=0e093591

overlay/creator: timestats

added (vague) time measurement for get_stats().

---
 roverlay/overlay/creator.py |  102 ++++++++++++++++++++++++++++++++----------
 1 files changed, 77 insertions(+), 25 deletions(-)

diff --git a/roverlay/overlay/creator.py b/roverlay/overlay/creator.py
index 6674e24..6aa5af9 100644
--- a/roverlay/overlay/creator.py
+++ b/roverlay/overlay/creator.py
@@ -12,13 +12,12 @@ main script).
 """
 __all__ = [ 'OverlayCreator', ]
 
+import collections
 import time
 import logging
 import threading
 import sys
 
-from collections import deque
-
 try:
 	import queue
 except ImportError:
@@ -137,8 +136,22 @@ class OverlayCreator ( object ):
 		# counts packages that passed adding to overlay
 		self.overlay_added  = PseudoAtomicCounter()
 
+		self._timestats     = collections.OrderedDict()
+
+		for k in (
+			'sync_packages',
+			'add_packages',
+			'ebuild_creation',
+			'overlay_write',
+		):
+			self._timestats [k] = -1
+
 	# --- end of __init__ (...) ---
 
+	def set_timestats ( self, name, seconds ):
+		self._timestats [name] = seconds
+	# --- end of set_timestats (...) ---
+
 	def get_stats ( self ):
 		pkg_added   = self.package_added.get_nowait()
 		pkg_created = self.create_success.get_nowait()
@@ -164,33 +177,68 @@ class OverlayCreator ( object ):
 			# the length of the highest number in stats (^=digit count)
 			# max_number_len := { 1,...,5 }
 			max_number_len = min ( 5, len ( str ( max ( stats ) ) ) )
-			num_fmt = '%(num)-' + str ( max_number_len ) + 's '
-
-			for i, s in enumerate ((
-				'packages added to the ebuild creation queue',
-				'packages passed ebuild creation',
-				'packages failed ebuild creation',
-				'ebuilds could be added to the overlay',
-				'ebuilds couldn\'t be added to the overlay',
-				'packages processed in total',
-				'packages failed in total',
-			)):
-				yield num_fmt % { 'num' : stats [i] } + s
+
+			for stats_tuple in zip (
+				stats,
+				(
+					'packages added to the ebuild creation queue',
+					'packages passed ebuild creation',
+					'packages failed ebuild creation',
+					'ebuilds could be added to the overlay',
+					'ebuilds couldn\'t be added to the overlay',
+					'packages processed in total',
+					'packages failed in total',
+				),
+			):
+				yield "{num:<{l}} {s}".format (
+					num = stats_tuple [0],
+					s   = stats_tuple [1],
+					l   = max_number_len,
+				)
+
+			yield ""
+
+			k_len = min (
+				39,
+				max ( len ( k ) for k in self._timestats.keys() )
+			)
+
+			for k, v in self._timestats.items():
+				if v < 0:
+					yield "time for {:<{l}} : <unknown>".format ( k, l=k_len, )
+
+				elif v < 1:
+					yield "time for {:<{l}} : {} ms".format (
+						k,
+						round ( v * 1000, 2 ),
+						l = k_len,
+					)
+
+				elif v > 300:
+					yield "time for {:<{l}} : {} minutes".format (
+						k,
+						round ( v / 60., 2 ),
+						l = k_len,
+					)
+
+				else:
+					yield "time for {}: {} seconds".format ( k, round ( v, 2 ) )
 		# --- end of stats_gen (...) ---
 
 		if enclose:
-			stats_str = deque ( stats_gen() )
+			stats = list ( stats_gen() )
+
 			# maxlen := { 2,...,80 }
 			maxlen = 2 + min ( 78,
-				len ( max ( stats_str, key=lambda s : len( s ) ) )
+				len ( max ( stats, key=lambda s : len( s ) ) )
 			)
 
-			stats_str.appendleft (
-				" Overlay creation stats ".center ( maxlen, '-' )
+			return (
+				"{0:-^{1}}\n".format ( " Overlay creation stats ", maxlen )
+				+ '\n'.join ( stats )
+				#+ '\n{0:-^{1}}'.format ( '', maxlen )
+				+ '\n' + ( maxlen * '-' )
 			)
-			stats_str.append ( '-' * maxlen )
-
-			return '\n'.join ( stats_str )
 
 		else:
 			return '\n'.join ( stats_gen() )
@@ -210,7 +258,7 @@ class OverlayCreator ( object ):
 		self.logger.debug (
 			"timestamp: {} (after {} seconds)".format ( description, delta )
 		)
-		return _stop
+		return delta
 	# --- end of _timestamp (...) ---
 
 	def add_package ( self, package_info ):
@@ -232,7 +280,9 @@ class OverlayCreator ( object ):
 		if self.overlay.writeable():
 			start = time.time()
 			self.overlay.write()
-			self._timestamp ( "overlay written", start )
+			self._timestats ['overlay_write'] = (
+				self._timestamp ( "overlay written", start )
+			)
 		else:
 			self.logger.warning ( "Not allowed to write overlay!" )
 	# --- end of write_overlay (...) ---
@@ -245,12 +295,14 @@ class OverlayCreator ( object ):
 	def run ( self, close_when_done=False ):
 		"""Starts ebuild creation and waits until done."""
 		self._runlock.acquire()
-		#self._time_start_run.append ( time.time() )
+		t_start = time.time()
 		try:
 			self.start()
 			self.join()
 		finally:
-			#self._time_stop_run.append ( time.time() )
+			self._timestats ['ebuild_creation'] = (
+				self._timestamp ( "run() done", t_start )
+			)
 			self._runlock.release()
 			if close_when_done:
 				self.close()


             reply	other threads:[~2013-02-09 20:45 UTC|newest]

Thread overview: 41+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-02-09 20:45 André Erdmann [this message]
  -- strict thread matches above, loose matches on Subject: below --
2014-08-23 19:03 [gentoo-commits] proj/R_overlay:master commit in: roverlay/overlay/ André Erdmann
2014-07-29 18:29 ` André Erdmann
2014-07-18 16:20 André Erdmann
2014-07-18  2:28 [gentoo-commits] proj/R_overlay:wip/addition_control " André Erdmann
2014-07-18 16:20 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2014-07-18  2:28 [gentoo-commits] proj/R_overlay:wip/addition_control " André Erdmann
2014-07-18 16:20 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2014-04-01 16:38 André Erdmann
2013-09-18 14:00 André Erdmann
2013-09-17 13:49 André Erdmann
2013-09-03 15:51 André Erdmann
2013-09-03 13:15 André Erdmann
2013-09-03  8:35 André Erdmann
2013-09-02 16:21 André Erdmann
2013-09-02 16:21 André Erdmann
2013-08-29 12:36 André Erdmann
2013-08-20 21:46 André Erdmann
2013-08-20 21:46 André Erdmann
2013-07-29 14:56 André Erdmann
2013-07-10 15:10 [gentoo-commits] proj/R_overlay:gsoc13/next " André Erdmann
2013-07-10 16:16 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2013-06-22 15:24 André Erdmann
2013-06-18 14:12 André Erdmann
2013-06-13 16:34 André Erdmann
2013-04-25 16:44 André Erdmann
2013-04-25 16:44 André Erdmann
2013-02-09 21:28 André Erdmann
2013-02-09 20:45 André Erdmann
2013-01-30 20:16 André Erdmann
2012-08-17 17:26 André Erdmann
2012-08-03 13:38 André Erdmann
2012-08-01 21:10 André Erdmann
2012-07-30 15:53 André Erdmann
2012-07-30  8:52 André Erdmann
2012-07-30  8:52 André Erdmann
2012-07-24 16:59 [gentoo-commits] proj/R_overlay:overlay_wip " André Erdmann
2012-07-30  8:52 ` [gentoo-commits] proj/R_overlay:master " André Erdmann
2012-07-05 16:00 André Erdmann
2012-07-04 18:21 André Erdmann
2012-07-03 17:48 André Erdmann
2012-06-27 14:46 André Erdmann
2012-06-26 15:42 André Erdmann
2012-06-22 18:13 André Erdmann
2012-06-21 16:55 André Erdmann

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1360440494.0e093591866ba15abd66b692ec190602ee9d9673.dywi@gentoo \
    --to=dywi@mailerd.de \
    --cc=gentoo-commits@lists.gentoo.org \
    --cc=gentoo-dev@lists.gentoo.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox