mirror of
https://git.yoctoproject.org/poky
synced 2026-02-21 08:59:41 +01:00
Currently selftest doesn't use sstates because some tests clean sstate cache; using sstates would give a performance boost instead of building everything from scratch. With this sstates are not corrupted using different methods depending on tests: devtool: These tests needed to delete the cache so SSTATE_DIR as SSTATE_MIRRORS and set a temporal SSTATE_DIR. sstatetests: This module already used a temporal SSTATE_DIR, so just set up the SSTATE_MIRRORS. Rest: Removed cleansstate, some of them required to force a certain task, others were just removed or changed for another task. [YOCTO #10929] (From OE-Core rev: 62c61087a10cc3b26fbff32c9e2efd1704a39724) (From OE-Core rev: 44ca8b1c23e4b2cf470e9be42705e3cca23b7f85) Signed-off-by: Mariano Lopez <mariano.lopez@linux.intel.com> Signed-off-by: Ross Burton <ross.burton@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
51 lines
2.3 KiB
Python
51 lines
2.3 KiB
Python
import datetime
|
|
import unittest
|
|
import os
|
|
import re
|
|
import shutil
|
|
|
|
import oeqa.utils.ftools as ftools
|
|
from oeqa.selftest.base import oeSelfTest
|
|
from oeqa.selftest.buildhistory import BuildhistoryBase
|
|
from oeqa.utils.commands import Command, runCmd, bitbake, get_bb_var, get_test_layer
|
|
from oeqa.utils.decorators import testcase
|
|
|
|
class TestScripts(oeSelfTest):
|
|
|
|
@testcase(300)
|
|
def test_cleanup_workdir(self):
|
|
path = os.path.dirname(get_bb_var('WORKDIR', 'gzip'))
|
|
old_version_recipe = os.path.join(get_bb_var('COREBASE'), 'meta/recipes-extended/gzip/gzip_1.3.12.bb')
|
|
old_version = '1.3.12'
|
|
bitbake("-c clean gzip")
|
|
bitbake("-c clean -b %s" % old_version_recipe)
|
|
|
|
if os.path.exists(path):
|
|
initial_contents = os.listdir(path)
|
|
else:
|
|
initial_contents = []
|
|
|
|
bitbake('gzip')
|
|
intermediary_contents = os.listdir(path)
|
|
bitbake("-b %s" % old_version_recipe)
|
|
runCmd('cleanup-workdir')
|
|
remaining_contents = os.listdir(path)
|
|
|
|
expected_contents = [x for x in intermediary_contents if x not in initial_contents]
|
|
remaining_not_expected = [x for x in remaining_contents if x not in expected_contents]
|
|
self.assertFalse(remaining_not_expected, msg="Not all necessary content has been deleted from %s: %s" % (path, ', '.join(map(str, remaining_not_expected))))
|
|
expected_not_remaining = [x for x in expected_contents if x not in remaining_contents]
|
|
self.assertFalse(expected_not_remaining, msg="The script removed extra contents from %s: %s" % (path, ', '.join(map(str, expected_not_remaining))))
|
|
|
|
class BuildhistoryDiffTests(BuildhistoryBase):
|
|
|
|
@testcase(295)
|
|
def test_buildhistory_diff(self):
|
|
self.add_command_to_tearDown('cleanup-workdir')
|
|
target = 'xcursor-transparent-theme'
|
|
self.run_buildhistory_operation(target, target_config="PR = \"r1\"", change_bh_location=True)
|
|
self.run_buildhistory_operation(target, target_config="PR = \"r0\"", change_bh_location=False, expect_error=True)
|
|
result = runCmd("buildhistory-diff -p %s" % get_bb_var('BUILDHISTORY_DIR'))
|
|
expected_output = 'PR changed from "r1" to "r0"'
|
|
self.assertTrue(expected_output in result.output, msg="Did not find expected output: %s" % result.output)
|