Skip to content

Commit

Permalink
Move tresult into sktm.misc
Browse files Browse the repository at this point in the history
Move sktm.tresult to sktm.misc.tresult to fix composition, so that
modules lower in the hierarchy (e.g. sktm.jenkins) do not have to import
the module above (i.e. sktm).

Fixes cki-project#6
  • Loading branch information
spbnick committed May 24, 2018
1 parent 44f097c commit f872c9f
Show file tree
Hide file tree
Showing 5 changed files with 47 additions and 31 deletions.
17 changes: 4 additions & 13 deletions sktm/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,16 +20,7 @@
import sktm.db
import sktm.jenkins
import sktm.patchwork


class tresult(enum.IntEnum):
"""Test result"""
SUCCESS = 0
MERGE_FAILURE = 1
BUILD_FAILURE = 2
PUBLISH_FAILURE = 3
TEST_FAILURE = 4
BASELINE_FAILURE = 5
import sktm.misc


class jtype(enum.IntEnum):
Expand Down Expand Up @@ -245,12 +236,12 @@ def check_pending(self):
logging.info("url=%s", rurl)
basehash = self.jk.get_base_hash(self.jobname, bid)
logging.info("basehash=%s", basehash)
if bres == sktm.tresult.BASELINE_FAILURE:
if bres == sktm.misc.tresult.BASELINE_FAILURE:
self.db.update_baseline(
self.baserepo,
basehash,
self.jk.get_base_commitdate(self.jobname, bid),
sktm.tresult.TEST_FAILURE,
sktm.misc.tresult.TEST_FAILURE,
bid
)

Expand Down Expand Up @@ -284,7 +275,7 @@ def check_pending(self):
except ValueError:
pass

if bres != sktm.tresult.BASELINE_FAILURE:
if bres != sktm.misc.tresult.BASELINE_FAILURE:
self.db.commit_patchtest(self.baserepo, basehash,
patches, bres, bid, series)
else:
Expand Down
6 changes: 3 additions & 3 deletions sktm/db.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
import os
import sqlite3
import time
import sktm
import sktm.misc


class skt_db(object):
Expand Down Expand Up @@ -267,7 +267,7 @@ def get_baselineresult(self, baserepo, commithash):
'ORDER BY baseline.commitdate DESC LIMIT 1',
(commithash, brid))
res = self.cur.fetchone()
return None if res is None else sktm.tresult(res[0])
return None if res is None else sktm.misc.tresult(res[0])

def get_stable(self, baserepo):
"""
Expand Down Expand Up @@ -457,7 +457,7 @@ def dump_baseline_tests(self):
for (burl, commit, res, buildid) in self.cur.fetchall():
print "repo url: %s" % burl
print "commit id: %s" % commit
print "result: %s" % sktm.tresult(res).name
print "result: %s" % sktm.misc.tresult(res).name
print "build id: #%s" % buildid
print "---"

Expand Down
16 changes: 8 additions & 8 deletions sktm/jenkins.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@

import jenkinsapi

import sktm
import sktm.misc


class skt_jenkins(object):
Expand Down Expand Up @@ -138,7 +138,7 @@ def get_result(self, jobname, buildid):
logging.info("build_status=%s", bstatus)

if bstatus == "SUCCESS":
return sktm.tresult.SUCCESS
return sktm.misc.tresult.SUCCESS

if not build.has_resultset():
raise Exception("No results for build %d (%s)" %
Expand All @@ -149,9 +149,9 @@ def get_result(self, jobname, buildid):
["PASSED", "FIXED"]):
if self.get_baseretcode(jobname, buildid) != 0:
logging.warning("baseline failure found during patch testing")
return sktm.tresult.BASELINE_FAILURE
return sktm.misc.tresult.BASELINE_FAILURE

return sktm.tresult.SUCCESS
return sktm.misc.tresult.SUCCESS

for (key, val) in build.get_resultset().iteritems():
if not key.startswith("skt."):
Expand All @@ -160,14 +160,14 @@ def get_result(self, jobname, buildid):
logging.debug("key=%s; value=%s", key, val.status)
if val.status == "FAILED" or val.status == "REGRESSION":
if key == "skt.cmd_merge":
return sktm.tresult.MERGE_FAILURE
return sktm.misc.tresult.MERGE_FAILURE
elif key == "skt.cmd_build":
return sktm.tresult.BUILD_FAILURE
return sktm.misc.tresult.BUILD_FAILURE
elif key == "skt.cmd_run":
return sktm.tresult.TEST_FAILURE
return sktm.misc.tresult.TEST_FAILURE

logging.warning("Unknown status. marking as test failure")
return sktm.tresult.TEST_FAILURE
return sktm.misc.tresult.TEST_FAILURE

# FIXME Clarify/fix argument names
def build(self, jobname, baserepo=None, ref=None, baseconfig=None,
Expand Down
25 changes: 25 additions & 0 deletions sktm/misc.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# Copyright (c) 2017-2018 Red Hat, Inc. All rights reserved. This copyrighted
# material is made available to anyone wishing to use, modify, copy, or
# redistribute it subject to the terms and conditions of the GNU General
# Public License v.2 or later.
#
# This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
# details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.

import enum


class tresult(enum.IntEnum):
"""Test result"""
SUCCESS = 0
MERGE_FAILURE = 1
BUILD_FAILURE = 2
PUBLISH_FAILURE = 3
TEST_FAILURE = 4
BASELINE_FAILURE = 5
14 changes: 7 additions & 7 deletions sktm/patchwork.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
import re
import urllib
import xmlrpclib
import sktm
import sktm.misc


class PatchsetSummary(object):
Expand Down Expand Up @@ -434,12 +434,12 @@ def _set_patch_check(self, patch, payload):
def set_patch_check(self, pid, jurl, result):
"""
Add a patch "check" for the specified patch, with the specified
Jenkins build URL and result (sktm.tresult).
Jenkins build URL and result (sktm.misc.tresult).
Args:
pid: The ID of the patch to add the "check" for.
jurl: Jenkins build URL for the "check" to reference.
result: Test result (sktm.tresult) to feature in the "check"
result: Test result (sktm.misc.tresult) to feature in the "check"
state.
"""
if self.apikey is None:
Expand All @@ -451,9 +451,9 @@ def set_patch_check(self, pid, jurl, result):
'target_url': jurl,
'context': 'skt',
'description': 'skt boot test'}
if result == sktm.tresult.SUCCESS:
if result == sktm.misc.tresult.SUCCESS:
payload['state'] = int(pwresult.SUCCESS)
elif result == sktm.tresult.BASELINE_FAILURE:
elif result == sktm.misc.tresult.BASELINE_FAILURE:
payload['state'] = int(pwresult.WARNING)
payload['description'] = 'Baseline failure found while testing '
'this patch'
Expand Down Expand Up @@ -843,12 +843,12 @@ def get_emails(self, pid):
def set_patch_check(self, pid, jurl, result):
"""
Add a patch "check" for the specified patch, with the specified
Jenkins build URL and result (sktm.tresult).
Jenkins build URL and result (sktm.misc.tresult).
Args:
pid: The ID of the patch to add the "check" for.
jurl: Jenkins build URL for the "check" to reference.
result: Test result (sktm.tresult) to feature in the "check"
result: Test result (sktm.misc.tresult) to feature in the "check"
state.
"""
# TODO: Implement this for xmlrpc
Expand Down

0 comments on commit f872c9f

Please sign in to comment.