|  | #!/usr/bin/env python3 | 
|  |  | 
|  | # This script can be used to verify HOMEPAGE values for all recipes in | 
|  | # the current configuration. | 
|  | # The result is influenced by network environment, since the timeout of connect url is 5 seconds as default. | 
|  |  | 
|  | import sys | 
|  | import os | 
|  | import subprocess | 
|  | import urllib.request | 
|  |  | 
|  |  | 
|  | # Allow importing scripts/lib modules | 
|  | scripts_path = os.path.abspath(os.path.dirname(os.path.realpath(__file__)) + '/..') | 
|  | lib_path = scripts_path + '/lib' | 
|  | sys.path = sys.path + [lib_path] | 
|  | import scriptpath | 
|  | import scriptutils | 
|  |  | 
|  | # Allow importing bitbake modules | 
|  | bitbakepath = scriptpath.add_bitbake_lib_path() | 
|  |  | 
|  | import bb.tinfoil | 
|  |  | 
|  | logger = scriptutils.logger_create('verify_homepage') | 
|  |  | 
|  | def wgetHomepage(pn, homepage): | 
|  | result = subprocess.call('wget ' + '-q -T 5 -t 1 --spider ' + homepage, shell = True) | 
|  | if result: | 
|  | logger.warn("%s: failed to verify HOMEPAGE: %s " % (pn, homepage)) | 
|  | return 1 | 
|  | else: | 
|  | return 0 | 
|  |  | 
|  | def verifyHomepage(bbhandler): | 
|  | pkg_pn = bbhandler.cooker.recipecaches[''].pkg_pn | 
|  | pnlist = sorted(pkg_pn) | 
|  | count = 0 | 
|  | checked = [] | 
|  | for pn in pnlist: | 
|  | for fn in pkg_pn[pn]: | 
|  | # There's no point checking multiple BBCLASSEXTENDed variants of the same recipe | 
|  | realfn, _, _ = bb.cache.virtualfn2realfn(fn) | 
|  | if realfn in checked: | 
|  | continue | 
|  | data = bbhandler.parse_recipe_file(realfn) | 
|  | homepage = data.getVar("HOMEPAGE", True) | 
|  | if homepage: | 
|  | try: | 
|  | urllib.request.urlopen(homepage, timeout=5) | 
|  | except Exception: | 
|  | count = count + wgetHomepage(os.path.basename(realfn), homepage) | 
|  | checked.append(realfn) | 
|  | return count | 
|  |  | 
|  | if __name__=='__main__': | 
|  | with bb.tinfoil.Tinfoil() as bbhandler: | 
|  | bbhandler.prepare() | 
|  | logger.info("Start verifying HOMEPAGE:") | 
|  | failcount = verifyHomepage(bbhandler) | 
|  | logger.info("Finished verifying HOMEPAGE.") | 
|  | logger.info("Summary: %s failed" % failcount) |