prservice.py 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. #
  2. # Copyright OpenEmbedded Contributors
  3. #
  4. # SPDX-License-Identifier: MIT
  5. #
  6. import os
  7. import re
  8. import shutil
  9. import datetime
  10. import oeqa.utils.ftools as ftools
  11. from oeqa.selftest.case import OESelftestTestCase
  12. from oeqa.utils.commands import runCmd, bitbake, get_bb_var
  13. from oeqa.utils.network import get_free_port
  14. import bb.utils
  15. class BitbakePrTests(OESelftestTestCase):
  16. @classmethod
  17. def setUpClass(cls):
  18. super(BitbakePrTests, cls).setUpClass()
  19. cls.pkgdata_dir = get_bb_var('PKGDATA_DIR')
  20. cls.exported_db_path = os.path.join(cls.builddir, 'export.inc')
  21. cls.current_db_path = os.path.join(get_bb_var('PERSISTENT_DIR'), 'prserv.sqlite3')
  22. def cleanup(self):
  23. # Ensure any memory resident bitbake is stopped
  24. bitbake("-m")
  25. # Remove any existing export file or prserv database
  26. bb.utils.remove(self.exported_db_path)
  27. bb.utils.remove(self.current_db_path + "*")
  28. def get_pr_version(self, package_name):
  29. package_data_file = os.path.join(self.pkgdata_dir, 'runtime', package_name)
  30. package_data = ftools.read_file(package_data_file)
  31. find_pr = re.search(r"PKGR: r[0-9]+\.([0-9]+)", package_data)
  32. self.assertTrue(find_pr, "No PKG revision found via regex 'PKGR: r[0-9]+\.([0-9]+)' in %s" % package_data_file)
  33. return int(find_pr.group(1))
  34. def get_task_stamp(self, package_name, recipe_task):
  35. stampdata = get_bb_var('STAMP', target=package_name).split('/')
  36. prefix = stampdata[-1]
  37. package_stamps_path = "/".join(stampdata[:-1])
  38. stamps = []
  39. for stamp in os.listdir(package_stamps_path):
  40. find_stamp = re.match(r"%s\.%s\.([a-z0-9]{32})" % (re.escape(prefix), recipe_task), stamp)
  41. if find_stamp:
  42. stamps.append(find_stamp.group(1))
  43. self.assertFalse(len(stamps) == 0, msg="Cound not find stamp for task %s for recipe %s" % (recipe_task, package_name))
  44. self.assertFalse(len(stamps) > 1, msg="Found multiple %s stamps for the %s recipe in the %s directory." % (recipe_task, package_name, package_stamps_path))
  45. return str(stamps[0])
  46. def increment_package_pr(self, package_name):
  47. inc_data = "do_package:append() {\n bb.build.exec_func('do_test_prserv', d)\n}\ndo_test_prserv() {\necho \"The current date is: %s\" > ${PKGDESTWORK}/${PN}.datestamp\n}" % datetime.datetime.now()
  48. self.write_recipeinc(package_name, inc_data)
  49. res = bitbake(package_name, ignore_status=True)
  50. self.delete_recipeinc(package_name)
  51. self.assertEqual(res.status, 0, msg=res.output)
  52. def config_pr_tests(self, package_name, package_type='rpm', pr_socket='localhost:0'):
  53. self.cleanup()
  54. config_package_data = 'PACKAGE_CLASSES = "package_%s"' % package_type
  55. self.write_config(config_package_data)
  56. config_server_data = 'PRSERV_HOST = "%s"' % pr_socket
  57. self.append_config(config_server_data)
  58. def run_test_pr_service(self, package_name, package_type='rpm', track_task='do_package', pr_socket='localhost:0'):
  59. self.config_pr_tests(package_name, package_type, pr_socket)
  60. self.increment_package_pr(package_name)
  61. pr_1 = self.get_pr_version(package_name)
  62. stamp_1 = self.get_task_stamp(package_name, track_task)
  63. self.increment_package_pr(package_name)
  64. pr_2 = self.get_pr_version(package_name)
  65. stamp_2 = self.get_task_stamp(package_name, track_task)
  66. self.assertTrue(pr_2 - pr_1 == 1, "New PR %s did not increment as expected (from %s), difference should be 1" % (pr_2, pr_1))
  67. self.assertTrue(stamp_1 != stamp_2, "Different pkg rev. but same stamp: %s" % stamp_1)
  68. self.cleanup()
  69. def run_test_pr_export_import(self, package_name, replace_current_db=True):
  70. self.config_pr_tests(package_name)
  71. self.increment_package_pr(package_name)
  72. pr_1 = self.get_pr_version(package_name)
  73. export_result = runCmd("bitbake-prserv-tool export %s" % self.exported_db_path, ignore_status=True)
  74. self.assertEqual(export_result.status, 0, msg="PR Service database export failed: %s" % export_result.output)
  75. self.assertTrue(os.path.exists(self.exported_db_path), msg="%s didn't exist, tool output %s" % (self.exported_db_path, export_result.output))
  76. if replace_current_db:
  77. self.assertTrue(os.path.exists(self.current_db_path), msg="Path to current PR Service database is invalid: %s" % self.current_db_path)
  78. os.remove(self.current_db_path)
  79. import_result = runCmd("bitbake-prserv-tool import %s" % self.exported_db_path, ignore_status=True)
  80. #os.remove(self.exported_db_path)
  81. self.assertEqual(import_result.status, 0, msg="PR Service database import failed: %s" % import_result.output)
  82. self.increment_package_pr(package_name)
  83. pr_2 = self.get_pr_version(package_name)
  84. self.assertTrue(pr_2 - pr_1 == 1, "New PR %s did not increment as expected (from %s), difference should be 1" % (pr_2, pr_1))
  85. self.cleanup()
  86. def test_import_export_replace_db(self):
  87. self.run_test_pr_export_import('m4')
  88. def test_import_export_override_db(self):
  89. self.run_test_pr_export_import('m4', replace_current_db=False)
  90. def test_pr_service_rpm_arch_dep(self):
  91. self.run_test_pr_service('m4', 'rpm', 'do_package')
  92. def test_pr_service_deb_arch_dep(self):
  93. self.run_test_pr_service('m4', 'deb', 'do_package')
  94. def test_pr_service_ipk_arch_dep(self):
  95. self.run_test_pr_service('m4', 'ipk', 'do_package')
  96. def test_pr_service_rpm_arch_indep(self):
  97. self.run_test_pr_service('xcursor-transparent-theme', 'rpm', 'do_package')
  98. def test_pr_service_deb_arch_indep(self):
  99. self.run_test_pr_service('xcursor-transparent-theme', 'deb', 'do_package')
  100. def test_pr_service_ipk_arch_indep(self):
  101. self.run_test_pr_service('xcursor-transparent-theme', 'ipk', 'do_package')
  102. def test_stopping_prservice_message(self):
  103. port = get_free_port()
  104. runCmd('bitbake-prserv --host localhost --port %s --loglevel=DEBUG --start' % port)
  105. ret = runCmd('bitbake-prserv --host localhost --port %s --loglevel=DEBUG --stop' % port)
  106. self.assertEqual(ret.status, 0)