oelib/buildhistory.py: Add unittest for buildhistory_analysis
The buildhistory_analysis module (in which buildhistory-diff is based) was lacking unittest for its functions. Created selftest module for this and a few testcases to cover basic cases. [YOCTO #10727] (From OE-Core rev: d868816ecb470d59216eecc97ef5d42261625cc1) Signed-off-by: Humberto Ibarra <humberto.ibarra.lopez@intel.com> Signed-off-by: Ross Burton <ross.burton@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
parent
661c73b716
commit
df55b06ceb
|
@ -0,0 +1,88 @@
|
|||
import os
|
||||
import unittest
|
||||
import tempfile
|
||||
from git import Repo
|
||||
from oeqa.utils.commands import get_bb_var
|
||||
from oe.buildhistory_analysis import blob_to_dict, compare_dict_blobs
|
||||
|
||||
class TestBlobParsing(unittest.TestCase):
|
||||
|
||||
def setUp(self):
|
||||
import time
|
||||
self.repo_path = tempfile.mkdtemp(prefix='selftest-buildhistory',
|
||||
dir=get_bb_var('TOPDIR'))
|
||||
|
||||
self.repo = Repo.init(self.repo_path)
|
||||
self.test_file = "test"
|
||||
self.var_map = {}
|
||||
|
||||
def tearDown(self):
|
||||
import shutil
|
||||
shutil.rmtree(self.repo_path)
|
||||
|
||||
def commit_vars(self, to_add={}, to_remove = [], msg="A commit message"):
|
||||
if len(to_add) == 0 and len(to_remove) == 0:
|
||||
return
|
||||
|
||||
for k in to_remove:
|
||||
self.var_map.pop(x,None)
|
||||
for k in to_add:
|
||||
self.var_map[k] = to_add[k]
|
||||
|
||||
with open(os.path.join(self.repo_path, self.test_file), 'w') as repo_file:
|
||||
for k in self.var_map:
|
||||
repo_file.write("%s = %s\n" % (k, self.var_map[k]))
|
||||
|
||||
self.repo.git.add("--all")
|
||||
self.repo.git.commit(message=msg)
|
||||
|
||||
def test_blob_to_dict(self):
|
||||
"""
|
||||
Test convertion of git blobs to dictionary
|
||||
"""
|
||||
valuesmap = { "foo" : "1", "bar" : "2" }
|
||||
self.commit_vars(to_add = valuesmap)
|
||||
|
||||
blob = self.repo.head.commit.tree.blobs[0]
|
||||
self.assertEqual(valuesmap, blob_to_dict(blob),
|
||||
"commit was not translated correctly to dictionary")
|
||||
|
||||
def test_compare_dict_blobs(self):
|
||||
"""
|
||||
Test comparisson of dictionaries extracted from git blobs
|
||||
"""
|
||||
changesmap = { "foo-2" : ("2", "8"), "bar" : ("","4"), "bar-2" : ("","5")}
|
||||
|
||||
self.commit_vars(to_add = { "foo" : "1", "foo-2" : "2", "foo-3" : "3" })
|
||||
blob1 = self.repo.heads.master.commit.tree.blobs[0]
|
||||
|
||||
self.commit_vars(to_add = { "foo-2" : "8", "bar" : "4", "bar-2" : "5" })
|
||||
blob2 = self.repo.heads.master.commit.tree.blobs[0]
|
||||
|
||||
change_records = compare_dict_blobs(os.path.join(self.repo_path, self.test_file),
|
||||
blob1, blob2, False, False)
|
||||
|
||||
var_changes = { x.fieldname : (x.oldvalue, x.newvalue) for x in change_records}
|
||||
self.assertEqual(changesmap, var_changes, "Changes not reported correctly")
|
||||
|
||||
def test_compare_dict_blobs_default(self):
|
||||
"""
|
||||
Test default values for comparisson of git blob dictionaries
|
||||
"""
|
||||
defaultmap = { x : ("default", "1") for x in ["PKG", "PKGE", "PKGV", "PKGR"]}
|
||||
|
||||
self.commit_vars(to_add = { "foo" : "1" })
|
||||
blob1 = self.repo.heads.master.commit.tree.blobs[0]
|
||||
|
||||
self.commit_vars(to_add = { "PKG" : "1", "PKGE" : "1", "PKGV" : "1", "PKGR" : "1" })
|
||||
blob2 = self.repo.heads.master.commit.tree.blobs[0]
|
||||
|
||||
change_records = compare_dict_blobs(os.path.join(self.repo_path, self.test_file),
|
||||
blob1, blob2, False, False)
|
||||
|
||||
var_changes = {}
|
||||
for x in change_records:
|
||||
oldvalue = "default" if ("default" in x.oldvalue) else x.oldvalue
|
||||
var_changes[x.fieldname] = (oldvalue, x.newvalue)
|
||||
|
||||
self.assertEqual(defaultmap, var_changes, "Defaults not set properly")
|
Loading…
Reference in New Issue