blob: f1dd63f65b4f9f9f22d348de100cb7d62326e10f [file] [log] [blame]
#
# SPDX-License-Identifier: MIT
#
import os
import re
import time
import logging
import bb.tinfoil
from oeqa.selftest.case import OESelftestTestCase
from oeqa.utils.commands import runCmd, get_test_layer
def setUpModule():
global tinfoil
global metaselftestpath
metaselftestpath = get_test_layer()
tinfoil = bb.tinfoil.Tinfoil(tracking=True)
tinfoil.prepare(config_only=False, quiet=2)
def tearDownModule():
tinfoil.shutdown()
class RecipeUtilsTests(OESelftestTestCase):
""" Tests for the recipeutils module functions """
def test_patch_recipe_varflag(self):
import oe.recipeutils
rd = tinfoil.parse_recipe('python3-async-test')
vals = {'SRC_URI[md5sum]': 'aaaaaa', 'LICENSE': 'something'}
patches = oe.recipeutils.patch_recipe(rd, rd.getVar('FILE'), vals, patch=True, relpath=metaselftestpath)
expected_patch = """
--- a/recipes-devtools/python/python-async-test.inc
+++ b/recipes-devtools/python/python-async-test.inc
@@ -1,14 +1,14 @@
SUMMARY = "Python framework to process interdependent tasks in a pool of workers"
HOMEPAGE = "http://github.com/gitpython-developers/async"
SECTION = "devel/python"
-LICENSE = "BSD-3-Clause"
+LICENSE = "something"
LIC_FILES_CHKSUM = "file://PKG-INFO;beginline=8;endline=8;md5=88df8e78b9edfd744953862179f2d14e"
inherit pypi
PYPI_PACKAGE = "async"
-SRC_URI[md5sum] = "9b06b5997de2154f3bc0273f80bcef6b"
+SRC_URI[md5sum] = "aaaaaa"
SRC_URI[sha256sum] = "ac6894d876e45878faae493b0cf61d0e28ec417334448ac0a6ea2229d8343051"
RDEPENDS:${PN} += "${PYTHON_PN}-threading"
"""
patchlines = []
for f in patches:
for line in f:
patchlines.append(line)
self.maxDiff = None
self.assertEqual(''.join(patchlines).strip(), expected_patch.strip())
def test_patch_recipe_singleappend(self):
import oe.recipeutils
rd = tinfoil.parse_recipe('recipeutils-test')
val = rd.getVar('SRC_URI', False).split()
del val[1]
val = ' '.join(val)
vals = {'SRC_URI': val}
patches = oe.recipeutils.patch_recipe(rd, rd.getVar('FILE'), vals, patch=True, relpath=metaselftestpath)
expected_patch = """
--- a/recipes-test/recipeutils/recipeutils-test_1.2.bb
+++ b/recipes-test/recipeutils/recipeutils-test_1.2.bb
@@ -8,6 +8,4 @@
BBCLASSEXTEND = "native nativesdk"
-SRC_URI += "file://somefile"
-
SRC_URI:append = " file://anotherfile"
"""
patchlines = []
for f in patches:
for line in f:
patchlines.append(line)
self.assertEqual(''.join(patchlines).strip(), expected_patch.strip())
def test_patch_recipe_appends(self):
import oe.recipeutils
rd = tinfoil.parse_recipe('recipeutils-test')
val = rd.getVar('SRC_URI', False).split()
vals = {'SRC_URI': val[0]}
patches = oe.recipeutils.patch_recipe(rd, rd.getVar('FILE'), vals, patch=True, relpath=metaselftestpath)
expected_patch = """
--- a/recipes-test/recipeutils/recipeutils-test_1.2.bb
+++ b/recipes-test/recipeutils/recipeutils-test_1.2.bb
@@ -8,6 +8,3 @@
BBCLASSEXTEND = "native nativesdk"
-SRC_URI += "file://somefile"
-
-SRC_URI:append = " file://anotherfile"
"""
patchlines = []
for f in patches:
for line in f:
patchlines.append(line)
self.assertEqual(''.join(patchlines).strip(), expected_patch.strip())
def test_validate_pn(self):
import oe.recipeutils
expected_results = {
'test': '',
'glib-2.0': '',
'gtk+': '',
'forcevariable': 'reserved',
'pn-something': 'reserved',
'test.bb': 'file',
'test_one': 'character',
'test!': 'character',
}
for pn, expected in expected_results.items():
result = oe.recipeutils.validate_pn(pn)
if expected:
self.assertIn(expected, result)
else:
self.assertEqual(result, '')
def test_split_var_value(self):
import oe.recipeutils
res = oe.recipeutils.split_var_value('test.1 test.2 ${@call_function("hi there world", false)} test.4')
self.assertEqual(res, ['test.1', 'test.2', '${@call_function("hi there world", false)}', 'test.4'])