[Libreoffice-commits] buildbot.git: 4 commits - .gitignore tb3/dist-packages tb3/replay-branch tb3/tb3 tb3/tb3-local-client tb3/tests

Bjoern Michaelsen bjoern.michaelsen at canonical.com
Wed Jul 31 11:22:45 PDT 2013


 .gitignore                         |    1 +
 tb3/dist-packages/tb3/__init__.py  |    2 +-
 tb3/dist-packages/tb3/repostate.py |    6 +++---
 tb3/dist-packages/tb3/scheduler.py |    8 ++++----
 tb3/replay-branch                  |    2 +-
 tb3/tb3                            |   20 ++++++++++----------
 tb3/tb3-local-client               |   12 ++++++------
 tb3/tests/helpers.py               |    2 +-
 tb3/tests/tb3-cli.py               |    2 +-
 tb3/tests/tb3-local-client.py      |    2 +-
 tb3/tests/tb3/repostate.py         |    6 +++---
 tb3/tests/tb3/scheduler.py         |    6 +++---
 12 files changed, 35 insertions(+), 34 deletions(-)

New commits:
commit c88440b1e1c6113f957fd063f0361b6986163698
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Jul 31 03:23:06 2013 +0200

    add python bytecode to gitignore

diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..04a41a2
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1 @@
+**.pyc
commit d5c46e6da56bf3c68d3e7650beff522b8996ad25
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Jul 31 03:21:48 2013 +0200

    python2 -> python3 transition

diff --git a/tb3/dist-packages/tb3/__init__.py b/tb3/dist-packages/tb3/__init__.py
index c7a73e3..56b7d5a 100644
--- a/tb3/dist-packages/tb3/__init__.py
+++ b/tb3/dist-packages/tb3/__init__.py
@@ -1,4 +1,4 @@
-#!/usr/bin/env python
+#!/usr/bin/env python3
 #
 # This file is part of the LibreOffice project.
 #
diff --git a/tb3/dist-packages/tb3/repostate.py b/tb3/dist-packages/tb3/repostate.py
index 6963da5..fc5a1fe 100644
--- a/tb3/dist-packages/tb3/repostate.py
+++ b/tb3/dist-packages/tb3/repostate.py
@@ -1,4 +1,4 @@
-#! /usr/bin/env python
+#! /usr/bin/env python3
 #
 # This file is part of the LibreOffice project.
 #
@@ -22,7 +22,7 @@ class StateEncoder(json.JSONEncoder):
 class StateDecoder(json.JSONDecoder):
     def decode(self, s):
         obj = super(StateDecoder, self).decode(s)
-        for (key, value) in obj.iteritems():
+        for (key, value) in obj.items():
             if isinstance(value, list):
                 if value[0] == '__datetime__':
                     obj[key] = datetime.datetime.utcfromtimestamp(value[1])
diff --git a/tb3/dist-packages/tb3/scheduler.py b/tb3/dist-packages/tb3/scheduler.py
index 8e9beb1..0f85b4b 100644
--- a/tb3/dist-packages/tb3/scheduler.py
+++ b/tb3/dist-packages/tb3/scheduler.py
@@ -1,4 +1,4 @@
-#!/usr/bin/env python
+#!/usr/bin/env python3
 #
 # This file is part of the LibreOffice project.
 #
@@ -18,8 +18,8 @@ class Proposal:
         (self.score, self.commit, self.scheduler, self.platform, self.repo, self.branch) = (score, commit, scheduler, platform, repo, branch)
     def __repr__(self):
         return 'Proposal(%f, %s, %s, %s, %s, %s)' % (self.score, self.commit, self.scheduler, self.platform, self.repo, self.branch)
-    def __cmp__(self, other):
-        return other.score - self.score
+    def __lt__(self, other):
+        return self.score < other.score
 
 class Scheduler:
     def __init__(self, platform, branch, repo):
@@ -110,5 +110,5 @@ class MergeScheduler(Scheduler):
             for proposal in new_proposals:
                 proposal.score *= scheduler[0]
                 proposals.append(proposal)
-        return sorted(proposals)
+        return sorted(proposals, key=lambda p: -p.score)
 # vim: set et sw=4 ts=4:
diff --git a/tb3/replay-branch b/tb3/replay-branch
index 79fdfcc..d307fe7 100755
--- a/tb3/replay-branch
+++ b/tb3/replay-branch
@@ -1,4 +1,4 @@
-#!/usr/bin/python
+#!/usr/bin/python3
 #
 # This file is part of the LibreOffice project.
 #
diff --git a/tb3/tb3 b/tb3/tb3
index 850906b..6ab865e 100755
--- a/tb3/tb3
+++ b/tb3/tb3
@@ -1,4 +1,4 @@
-#!/usr/bin/python
+#!/usr/bin/python3
 #
 # This file is part of the LibreOffice project.
 #
@@ -40,12 +40,12 @@ def set_commit_running(parms):
     get_updater(parms).set_scheduled(parms['set_commit_running'], parms['builder'], parms['estimated_duration'])
 
 def show_state(parms):
-    if parms.has_key('format') and parms['format'] == 'json':
+    if 'format' in parms and parms['format'] == 'json':
         raise NotImplementedError
     print(get_repostate(parms))
     
 def show_history(parms):
-    if parms.has_key('format') and parms['format'] == 'json':
+    if 'format' in parms and parms['format'] == 'json':
         raise NotImplementedError
     history = tb3.repostate.RepoHistory(parms['platform'], parms['repo'])
     for (commit, state) in history.get_recent_commit_states(parms['branch'], parms['history_count']):
@@ -65,17 +65,17 @@ def show_proposals(parms):
         print(json.dumps([p.__dict__ for p in proposals]))
 
 def execute(parms):
-    if parms.has_key('estimated_duration') and type(parms['estimated_duration']) is float:
+    if 'estimated_duration' in parms and type(parms['estimated_duration']) is float:
         parms['estimated_duration'] = datetime.timedelta(minutes=parms['estimated_duration'])
     if parms['sync']:
         sync(parms)
-    if parms.has_key('set_commit_finished') and parms['set_commit_finished']:
+    if 'set_commit_finished' in parms and parms['set_commit_finished']:
         set_commit_finished(parms)
-    if parms.has_key('set_commit_running') and parms['set_commit_running']:
+    if 'set_commit_running' in parms and parms['set_commit_running']:
         set_commit_running(parms)
     if parms['show_state']:
         show_state(parms)
-    if parms.has_key('show_history') and parms['show_history']:
+    if 'show_history' in parms and parms['show_history']:
         show_history(parms)
     if parms['show_proposals']:
         show_proposals(parms)
@@ -128,11 +128,11 @@ if __name__ == '__main__':
     if fullcommand or commandname == 'tb3-show-proposals' or commandname == 'tb3-show-history':
         parser.add_argument('--format', help='set format for proposals and history (default: text)', choices=['text', 'json'], default='text')
     args = vars(parser.parse_args())
-    if not args.has_key('builder') and (args.has_key('set_commit_running') or args.has_key('set_commit_finished')):
+    if not 'builder' in args and ('set_commit_running' in args or 'set_commit_finished' in args):
         parser.print_help()
         sys.exit(1)
-    if args.has_key('set_commit_finished') or args.has_key('set_commit_running') or args.has_key('show_state') or args.has_key('show_history') or args.has_key('show_proposals'):
-        if not (args.has_key('branch') and args.has_key('platform')):
+    if 'set_commit_finished' in args or 'set_commit_running' in args or 'show_state' in args or 'show_history' in args or 'show_proposals' in args:
+        if not 'branch' in args and 'platform' in args:
             parser.print_help()
             sys.exit(1)
     if not fullcommand:
diff --git a/tb3/tb3-local-client b/tb3/tb3-local-client
index 4c91de3..6665201 100755
--- a/tb3/tb3-local-client
+++ b/tb3/tb3-local-client
@@ -1,4 +1,4 @@
-#!/usr/bin/python
+#!/usr/bin/python3
 #
 # This file is part of the LibreOffice project.
 #
@@ -52,7 +52,7 @@ class LocalClient:
             return None
     def report_start(self, proposal):
         estimated_buildtime = float(120)
-        if self.buildtimes.has_key( (proposal['repo'], proposal['branch'], proposal['platform']) ):
+        if (proposal['repo'], proposal['branch'], proposal['platform']) in self.buildtimes:
             scenario_buildtimes = self.buildtimes[ (proposal['repo'], proposal['branch'], proposal['platform']) ]
             estimated_buildtime = scenario_buildtimes[len(scenario_buildtimes)/2]
         self.tb3(repo=proposal['repo'], branch=proposal['branch'], platform=proposal['platform'], set_commit_running=proposal['commit'], estimated_duration=estimated_buildtime)
@@ -74,7 +74,7 @@ class LocalClient:
             _out=outfile,
             _ok_code=range(256)).exit_code
         duration_in_minutes = ((datetime.datetime.now() - starttime).total_seconds())/60
-        if self.buildtimes.has_key( (proposal['repo'], proposal['branch'], proposal['platform']) ):
+        if (proposal['repo'], proposal['branch'], proposal['platform']) in self.buildtimes:
             scenario_buildtimes = self.buildtimes[ (proposal['repo'], proposal['branch'], proposal['platform']) ]
             scenario_buildtimes.append(duration_in_minutes)
             scenario_buildtimes = sorted(scenario_buildtimes)
@@ -99,11 +99,11 @@ class LocalClient:
                     proposal = p
             if not proposal or float(proposal['score']) < self.args['min_score']:
                 time.sleep(self.args['poll_idle_time'])
-        print proposal
+        print(proposal)
         try:
             self.report_start(proposal)
         except Exception as e:
-            print "except %s" % e
+            print("except %s" % e)
         result = self.run_build(proposal)
         self.report_result(proposal, result)
     def execute(self):
diff --git a/tb3/tests/helpers.py b/tb3/tests/helpers.py
index 821882f..a82d5d9 100755
--- a/tb3/tests/helpers.py
+++ b/tb3/tests/helpers.py
@@ -1,4 +1,4 @@
-#! /usr/bin/env python
+#! /usr/bin/env python3
 #
 # This file is part of the LibreOffice project.
 #
diff --git a/tb3/tests/tb3-cli.py b/tb3/tests/tb3-cli.py
index 0dbc906..84142af 100755
--- a/tb3/tests/tb3-cli.py
+++ b/tb3/tests/tb3-cli.py
@@ -1,4 +1,4 @@
-#!/usr/bin/python
+#!/usr/bin/python3
 #
 # This file is part of the LibreOffice project.
 #
diff --git a/tb3/tests/tb3-local-client.py b/tb3/tests/tb3-local-client.py
index 64e1c0f..d1de4c0 100755
--- a/tb3/tests/tb3-local-client.py
+++ b/tb3/tests/tb3-local-client.py
@@ -1,4 +1,4 @@
-#!/usr/bin/python
+#!/usr/bin/python3
 #
 # This file is part of the LibreOffice project.
 #
diff --git a/tb3/tests/tb3/repostate.py b/tb3/tests/tb3/repostate.py
index 436c3f3..8656697 100755
--- a/tb3/tests/tb3/repostate.py
+++ b/tb3/tests/tb3/repostate.py
@@ -1,4 +1,4 @@
-#! /usr/bin/env python
+#! /usr/bin/env python3
 #
 # This file is part of the LibreOffice project.
 #
@@ -75,8 +75,8 @@ class TestRepoHistory(unittest.TestCase):
         commitstate = tb3.repostate.CommitState(started=now, finished=now)
         self.history.set_commit_state(self.head, commitstate)
         commitstate = self.history.get_commit_state(self.head)
-        self.assertEqual(commitstate.started, now)
-        self.assertEqual(commitstate.finished, now)
+        self.assertLess(abs((commitstate.started - now).total_seconds()), 0.01)
+        self.assertLess(abs((commitstate.finished -now).total_seconds()), 0.01)
 
 class TestRepoUpdater(unittest.TestCase):
     def __resolve_ref(self, refname):
diff --git a/tb3/tests/tb3/scheduler.py b/tb3/tests/tb3/scheduler.py
index bf0e328..91b77dd 100755
--- a/tb3/tests/tb3/scheduler.py
+++ b/tb3/tests/tb3/scheduler.py
@@ -1,4 +1,4 @@
-#! /usr/bin/env python
+#! /usr/bin/env python3
 #
 # This file is part of the LibreOffice project.
 #
@@ -24,11 +24,11 @@ class TestScheduler(unittest.TestCase):
     def _show_log(self, commit):
         for line in self.git("log", "--pretty=oneline", commit):
             sys.stdout.write(line)
-        print
+        print()
     def _show_proposals(self, proposals):
         for proposal in proposals:
             sys.stdout.write("%f %s" %(proposal.score, self.git("log", "-1", "--pretty=oneline",  proposal.commit)))
-        print
+        print()
     def setUp(self):
         (self.testdir, self.git) = helpers.createTestRepo()
         self.state = tb3.repostate.RepoState('linux', 'master', self.testdir)
commit fe44190941d30e0d753776e988124584664fce16
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Jul 31 01:58:15 2013 +0200

    we hardcode a maximum, thus use min()

diff --git a/tb3/dist-packages/tb3/repostate.py b/tb3/dist-packages/tb3/repostate.py
index aee3061..6963da5 100644
--- a/tb3/dist-packages/tb3/repostate.py
+++ b/tb3/dist-packages/tb3/repostate.py
@@ -178,7 +178,7 @@ class RepoStateUpdater:
             self.repostate.clear_last_bad()
     def set_scheduled(self, commit, builder, estimated_duration):
         # FIXME: dont hardcode limit
-        estimated_duration = max(estimated_duration, datetime.timedelta(hours=4))
+        estimated_duration = min(estimated_duration, datetime.timedelta(hours=4))
         commitstate = CommitState('RUNNING', datetime.datetime.now(), builder, estimated_duration)
         self.repohistory.set_commit_state(commit, commitstate)
     def set_finished(self, commit, builder, state, artifactreference):
commit ba54447feda3b6276d6df96b90b24266b5fb333f
Author: Bjoern Michaelsen <bjoern.michaelsen at canonical.com>
Date:   Wed Jul 31 01:56:21 2013 +0200

    fix naming estimated_buildtime->estimated_duration

diff --git a/tb3/tb3-local-client b/tb3/tb3-local-client
index f2e02c7..4c91de3 100755
--- a/tb3/tb3-local-client
+++ b/tb3/tb3-local-client
@@ -55,7 +55,7 @@ class LocalClient:
         if self.buildtimes.has_key( (proposal['repo'], proposal['branch'], proposal['platform']) ):
             scenario_buildtimes = self.buildtimes[ (proposal['repo'], proposal['branch'], proposal['platform']) ]
             estimated_buildtime = scenario_buildtimes[len(scenario_buildtimes)/2]
-        self.tb3(repo=proposal['repo'], branch=proposal['branch'], platform=proposal['platform'], set_commit_running=proposal['commit'], estimated_buildtime=estimated_buildtime)
+        self.tb3(repo=proposal['repo'], branch=proposal['branch'], platform=proposal['platform'], set_commit_running=proposal['commit'], estimated_duration=estimated_buildtime)
     def run_build(self, proposal):
         buildtime = int(time.time()*100)
         if self.logdir:


More information about the Libreoffice-commits mailing list