buildhistory.py 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. import os
  2. from oeqa.selftest.case import OESelftestTestCase
  3. import tempfile
  4. from oeqa.utils.commands import get_bb_var
  5. class TestBlobParsing(OESelftestTestCase):
  6. def setUp(self):
  7. import time
  8. self.repo_path = tempfile.mkdtemp(prefix='selftest-buildhistory',
  9. dir=get_bb_var('TOPDIR'))
  10. try:
  11. from git import Repo
  12. self.repo = Repo.init(self.repo_path)
  13. except ImportError:
  14. self.skipTest('Python module GitPython is not present')
  15. self.test_file = "test"
  16. self.var_map = {}
  17. def tearDown(self):
  18. import shutil
  19. shutil.rmtree(self.repo_path)
  20. def commit_vars(self, to_add={}, to_remove = [], msg="A commit message"):
  21. if len(to_add) == 0 and len(to_remove) == 0:
  22. return
  23. for k in to_remove:
  24. self.var_map.pop(x,None)
  25. for k in to_add:
  26. self.var_map[k] = to_add[k]
  27. with open(os.path.join(self.repo_path, self.test_file), 'w') as repo_file:
  28. for k in self.var_map:
  29. repo_file.write("%s = %s\n" % (k, self.var_map[k]))
  30. self.repo.git.add("--all")
  31. self.repo.git.commit(message=msg)
  32. def test_blob_to_dict(self):
  33. """
  34. Test convertion of git blobs to dictionary
  35. """
  36. from oe.buildhistory_analysis import blob_to_dict
  37. valuesmap = { "foo" : "1", "bar" : "2" }
  38. self.commit_vars(to_add = valuesmap)
  39. blob = self.repo.head.commit.tree.blobs[0]
  40. self.assertEqual(valuesmap, blob_to_dict(blob),
  41. "commit was not translated correctly to dictionary")
  42. def test_compare_dict_blobs(self):
  43. """
  44. Test comparisson of dictionaries extracted from git blobs
  45. """
  46. from oe.buildhistory_analysis import compare_dict_blobs
  47. changesmap = { "foo-2" : ("2", "8"), "bar" : ("","4"), "bar-2" : ("","5")}
  48. self.commit_vars(to_add = { "foo" : "1", "foo-2" : "2", "foo-3" : "3" })
  49. blob1 = self.repo.heads.master.commit.tree.blobs[0]
  50. self.commit_vars(to_add = { "foo-2" : "8", "bar" : "4", "bar-2" : "5" })
  51. blob2 = self.repo.heads.master.commit.tree.blobs[0]
  52. change_records = compare_dict_blobs(os.path.join(self.repo_path, self.test_file),
  53. blob1, blob2, False, False)
  54. var_changes = { x.fieldname : (x.oldvalue, x.newvalue) for x in change_records}
  55. self.assertEqual(changesmap, var_changes, "Changes not reported correctly")
  56. def test_compare_dict_blobs_default(self):
  57. """
  58. Test default values for comparisson of git blob dictionaries
  59. """
  60. from oe.buildhistory_analysis import compare_dict_blobs
  61. defaultmap = { x : ("default", "1") for x in ["PKG", "PKGE", "PKGV", "PKGR"]}
  62. self.commit_vars(to_add = { "foo" : "1" })
  63. blob1 = self.repo.heads.master.commit.tree.blobs[0]
  64. self.commit_vars(to_add = { "PKG" : "1", "PKGE" : "1", "PKGV" : "1", "PKGR" : "1" })
  65. blob2 = self.repo.heads.master.commit.tree.blobs[0]
  66. change_records = compare_dict_blobs(os.path.join(self.repo_path, self.test_file),
  67. blob1, blob2, False, False)
  68. var_changes = {}
  69. for x in change_records:
  70. oldvalue = "default" if ("default" in x.oldvalue) else x.oldvalue
  71. var_changes[x.fieldname] = (oldvalue, x.newvalue)
  72. self.assertEqual(defaultmap, var_changes, "Defaults not set properly")