recipetool: selftest: Add test for recipetool plugin loading
Test that recipetool plugins are loaded in a well defined order. (From OE-Core rev: 044de8424a454a7057906e44eb56e2134ebb17e4) Signed-off-by: Ola x Nilsson <ola.x.nilsson@axis.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
9170a88cbd
commit
2765231499
|
@ -0,0 +1,41 @@
|
||||||
|
import argparse
|
||||||
|
|
||||||
|
already_loaded = False
|
||||||
|
register_count = 0
|
||||||
|
|
||||||
|
def plugin_name(filename):
|
||||||
|
return os.path.splitext(os.path.basename(filename))[0]
|
||||||
|
|
||||||
|
def plugin_init(plugins):
|
||||||
|
global already_loaded
|
||||||
|
already_loaded = plugin_name(__file__) in (plugin_name(p.__name__) for p in plugins)
|
||||||
|
|
||||||
|
def print_name(opts):
|
||||||
|
print (__file__)
|
||||||
|
|
||||||
|
def print_bbdir(opts):
|
||||||
|
print (__file__.replace('/lib/recipetool/bbpath.py',''))
|
||||||
|
|
||||||
|
def print_registered(opts):
|
||||||
|
#global kept_context
|
||||||
|
#print(kept_context.loaded)
|
||||||
|
print ("1")
|
||||||
|
|
||||||
|
def multiloaded(opts):
|
||||||
|
global already_loaded
|
||||||
|
print("yes" if already_loaded else "no")
|
||||||
|
|
||||||
|
def register_commands(subparsers):
|
||||||
|
global register_count
|
||||||
|
register_count += 1
|
||||||
|
|
||||||
|
def addparser(name, helptxt, func):
|
||||||
|
parser = subparsers.add_parser(name, help=helptxt,
|
||||||
|
formatter_class=argparse.ArgumentDefaultsHelpFormatter)
|
||||||
|
parser.set_defaults(func=func)
|
||||||
|
return parser
|
||||||
|
|
||||||
|
addparser('pluginfile', 'Print the filename of this plugin', print_name)
|
||||||
|
addparser('bbdir', 'Print the BBPATH directory of this plugin', print_bbdir)
|
||||||
|
addparser('count', 'How many times have this plugin been registered.', print_registered)
|
||||||
|
addparser('multiloaded', 'How many times have this plugin been initialized', multiloaded)
|
|
@ -1,5 +1,6 @@
|
||||||
import os
|
import os
|
||||||
import logging
|
import logging
|
||||||
|
import shutil
|
||||||
import tempfile
|
import tempfile
|
||||||
import urllib.parse
|
import urllib.parse
|
||||||
|
|
||||||
|
@ -485,6 +486,47 @@ class RecipetoolTests(RecipetoolBase):
|
||||||
inherits = ['pkgconfig', 'autotools']
|
inherits = ['pkgconfig', 'autotools']
|
||||||
self._test_recipe_contents(recipefile, checkvars, inherits)
|
self._test_recipe_contents(recipefile, checkvars, inherits)
|
||||||
|
|
||||||
|
def _copy_file_with_cleanup(self, srcfile, basedstdir, *paths):
|
||||||
|
dstdir = basedstdir
|
||||||
|
self.assertTrue(os.path.exists(dstdir))
|
||||||
|
for p in paths:
|
||||||
|
dstdir = os.path.join(dstdir, p)
|
||||||
|
if not os.path.exists(dstdir):
|
||||||
|
os.makedirs(dstdir)
|
||||||
|
self.track_for_cleanup(dstdir)
|
||||||
|
dstfile = os.path.join(dstdir, os.path.basename(srcfile))
|
||||||
|
if srcfile != dstfile:
|
||||||
|
shutil.copy(srcfile, dstfile)
|
||||||
|
self.track_for_cleanup(dstfile)
|
||||||
|
|
||||||
|
def test_recipetool_load_plugin(self):
|
||||||
|
"""Test that recipetool loads only the first found plugin in BBPATH."""
|
||||||
|
|
||||||
|
recipetool = runCmd("which recipetool")
|
||||||
|
fromname = runCmd("recipetool --quiet pluginfile")
|
||||||
|
srcfile = fromname.output
|
||||||
|
bbpath = get_bb_var('BBPATH')
|
||||||
|
searchpath = bbpath.split(':') + [os.path.dirname(recipetool.output)]
|
||||||
|
plugincontent = []
|
||||||
|
with open(srcfile) as fh:
|
||||||
|
plugincontent = fh.readlines()
|
||||||
|
try:
|
||||||
|
self.assertIn('meta-selftest', srcfile, 'wrong bbpath plugin found')
|
||||||
|
for path in searchpath:
|
||||||
|
self._copy_file_with_cleanup(srcfile, path, 'lib', 'recipetool')
|
||||||
|
result = runCmd("recipetool --quiet count")
|
||||||
|
self.assertEqual(result.output, '1')
|
||||||
|
result = runCmd("recipetool --quiet multiloaded")
|
||||||
|
self.assertEqual(result.output, "no")
|
||||||
|
for path in searchpath:
|
||||||
|
result = runCmd("recipetool --quiet bbdir")
|
||||||
|
self.assertEqual(result.output, path)
|
||||||
|
os.unlink(os.path.join(result.output, 'lib', 'recipetool', 'bbpath.py'))
|
||||||
|
finally:
|
||||||
|
with open(srcfile, 'w') as fh:
|
||||||
|
fh.writelines(plugincontent)
|
||||||
|
|
||||||
|
|
||||||
class RecipetoolAppendsrcBase(RecipetoolBase):
|
class RecipetoolAppendsrcBase(RecipetoolBase):
|
||||||
def _try_recipetool_appendsrcfile(self, testrecipe, newfile, destfile, options, expectedlines, expectedfiles):
|
def _try_recipetool_appendsrcfile(self, testrecipe, newfile, destfile, options, expectedlines, expectedfiles):
|
||||||
cmd = 'recipetool appendsrcfile %s %s %s %s %s' % (options, self.templayerdir, testrecipe, newfile, destfile)
|
cmd = 'recipetool appendsrcfile %s %s %s %s %s' % (options, self.templayerdir, testrecipe, newfile, destfile)
|
||||||
|
@ -574,6 +616,8 @@ class RecipetoolAppendsrcBase(RecipetoolBase):
|
||||||
self.assertIn(filesdir, filesextrapaths)
|
self.assertIn(filesdir, filesextrapaths)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class RecipetoolAppendsrcTests(RecipetoolAppendsrcBase):
|
class RecipetoolAppendsrcTests(RecipetoolAppendsrcBase):
|
||||||
|
|
||||||
@testcase(1273)
|
@testcase(1273)
|
||||||
|
|
Loading…
Reference in New Issue