mirror of
https://git.yoctoproject.org/poky
synced 2026-06-01 13:09:50 +00:00
bitbake: toaster:test:Create selenium tests for project dashboard page
Added 7 new testcases that verify the UI interface and elements of the project detail page. This testcases can be found on testopia in the links: Verifies that the project is created and that you get redirected to the configuration page https://bugzilla.yoctoproject.org/tr_show_case.cgi?case_id=1514 Verifies that the left side bar menu, all links are clickable and they show on the UI https://bugzilla.yoctoproject.org/tr_show_case.cgi?case_id=1515 Verifies that after creating a project the default project configuration is created https://bugzilla.yoctoproject.org/tr_show_case.cgi?case_id=1516 Verifies that the default machine is set, once creating the project https://bugzilla.yoctoproject.org/tr_show_case.cgi?case_id=1517 Verifies the built recipes information of the project detail page https://bugzilla.yoctoproject.org/tr_show_case.cgi?case_id=1518 Verifies the default release information of the project https://bugzilla.yoctoproject.org/tr_show_case.cgi?case_id=1519 Verifies that the default layers are assigned to the project https://bugzilla.yoctoproject.org/tr_show_case.cgi?case_id=1520 Verifies that the links to the Configuration, Builds, Import layer and New Custom Image are present and work. [YOCTO #9808] (Bitbake rev: eaeddaf96efb8079b307652eac208f4ab5019ad4) Signed-off-by: Libertad Cruz <libertad.cruz@intel.com> Signed-off-by: Aníbal Limón <anibal.limon@linux.intel.com> Signed-off-by: David Reyna <David.Reyna@windriver.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
f45a5a5de8
commit
123ec6ebc2
@@ -41,6 +41,61 @@ logger = logging.getLogger("toaster")
|
||||
# want to wrap everything in a database transaction as an external process
|
||||
# (bitbake needs access to the database)
|
||||
|
||||
def load_build_environment():
|
||||
call_command('loaddata', 'settings.xml', app_label="orm")
|
||||
call_command('loaddata', 'poky.xml', app_label="orm")
|
||||
|
||||
current_builddir = os.environ.get("BUILDDIR")
|
||||
if current_builddir:
|
||||
BuildTest.BUILDDIR = current_builddir
|
||||
else:
|
||||
# Setup a builddir based on default layout
|
||||
# bitbake inside openebedded-core
|
||||
oe_init_build_env_path = os.path.join(
|
||||
os.path.dirname(os.path.abspath(__file__)),
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
'oe-init-build-env'
|
||||
)
|
||||
if not os.path.exists(oe_init_build_env_path):
|
||||
raise Exception("We had no BUILDDIR set and couldn't "
|
||||
"find oe-init-build-env to set this up "
|
||||
"ourselves please run oe-init-build-env "
|
||||
"before running these tests")
|
||||
|
||||
oe_init_build_env_path = os.path.realpath(oe_init_build_env_path)
|
||||
cmd = "bash -c 'source oe-init-build-env %s'" % BuildTest.BUILDDIR
|
||||
p = subprocess.Popen(
|
||||
cmd,
|
||||
cwd=os.path.dirname(oe_init_build_env_path),
|
||||
shell=True,
|
||||
stdout=subprocess.PIPE,
|
||||
stderr=subprocess.PIPE)
|
||||
|
||||
output, err = p.communicate()
|
||||
p.wait()
|
||||
|
||||
logger.info("oe-init-build-env %s %s" % (output, err))
|
||||
|
||||
os.environ['BUILDDIR'] = BuildTest.BUILDDIR
|
||||
|
||||
# Setup the path to bitbake we know where to find this
|
||||
bitbake_path = os.path.join(
|
||||
os.path.dirname(os.path.abspath(__file__)),
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
'bin',
|
||||
'bitbake')
|
||||
if not os.path.exists(bitbake_path):
|
||||
raise Exception("Could not find bitbake at the expected path %s"
|
||||
% bitbake_path)
|
||||
|
||||
os.environ['BBBASEDIR'] = bitbake_path
|
||||
|
||||
class BuildTest(unittest.TestCase):
|
||||
|
||||
@@ -59,60 +114,7 @@ class BuildTest(unittest.TestCase):
|
||||
if built:
|
||||
return built
|
||||
|
||||
call_command('loaddata', 'settings.xml', app_label="orm")
|
||||
call_command('loaddata', 'poky.xml', app_label="orm")
|
||||
|
||||
current_builddir = os.environ.get("BUILDDIR")
|
||||
if current_builddir:
|
||||
BuildTest.BUILDDIR = current_builddir
|
||||
else:
|
||||
# Setup a builddir based on default layout
|
||||
# bitbake inside openebedded-core
|
||||
oe_init_build_env_path = os.path.join(
|
||||
os.path.dirname(os.path.abspath(__file__)),
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
'oe-init-build-env'
|
||||
)
|
||||
if not os.path.exists(oe_init_build_env_path):
|
||||
raise Exception("We had no BUILDDIR set and couldn't "
|
||||
"find oe-init-build-env to set this up "
|
||||
"ourselves please run oe-init-build-env "
|
||||
"before running these tests")
|
||||
|
||||
oe_init_build_env_path = os.path.realpath(oe_init_build_env_path)
|
||||
cmd = "bash -c 'source oe-init-build-env %s'" % BuildTest.BUILDDIR
|
||||
p = subprocess.Popen(
|
||||
cmd,
|
||||
cwd=os.path.dirname(oe_init_build_env_path),
|
||||
shell=True,
|
||||
stdout=subprocess.PIPE,
|
||||
stderr=subprocess.PIPE)
|
||||
|
||||
output, err = p.communicate()
|
||||
p.wait()
|
||||
|
||||
logger.info("oe-init-build-env %s %s" % (output, err))
|
||||
|
||||
os.environ['BUILDDIR'] = BuildTest.BUILDDIR
|
||||
|
||||
# Setup the path to bitbake we know where to find this
|
||||
bitbake_path = os.path.join(
|
||||
os.path.dirname(os.path.abspath(__file__)),
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
os.pardir,
|
||||
'bin',
|
||||
'bitbake')
|
||||
if not os.path.exists(bitbake_path):
|
||||
raise Exception("Could not find bitbake at the expected path %s"
|
||||
% bitbake_path)
|
||||
|
||||
os.environ['BBBASEDIR'] = bitbake_path
|
||||
load_build_environment()
|
||||
|
||||
BuildEnvironment.objects.get_or_create(
|
||||
betype=BuildEnvironment.TYPE_LOCAL,
|
||||
|
||||
Reference in New Issue
Block a user