Message ID | 20230712-asoc-topology-kunit-enable-v1-2-b9f2da9dca23@kernel.org (mailing list archive) |
---|---|
State | Accepted |
Commit | b7dc237ef8b0897f5750a738d2c57469909a6a15 |
Headers | show |
Series | ASoC: Improve coverage in default KUnit runs | expand |
On Wed, 12 Jul 2023 at 23:40, Mark Brown <broonie@kernel.org> wrote: > > The default KUnit build options are not supposed to enable any > subsystems that were not already enabled but the topology code is a > library which is generally selected by drivers that want to use it. > Since KUnit is frequently run in virtual environments with minimal > driver support this makes it difficult to enable the toplogy tests so > provide an explicit Kconfig option which can be directly enabled when > using KUnit, and also include this in the KUnit all_tests.config. > > Signed-off-by: Mark Brown <broonie@kernel.org> > --- Thanks a bunch for this: the topology tests have always been some of the most annoying to run, and this makes it so much easier. That being said, it does still break when run with ARCH=um (see the response to patch 1/2), so we might need to remove it from all_tests.config or make some other changes. Having the CONFIG_SND_SOC_TOPOLOGY_BUILD option is definitely much better, regardless of whether it's default or not. Reviewed-by: David Gow <davidgow@google.com> Cheers, -- David > sound/soc/Kconfig | 11 +++++++++++ > tools/testing/kunit/configs/all_tests.config | 1 + > 2 files changed, 12 insertions(+) > > diff --git a/sound/soc/Kconfig b/sound/soc/Kconfig > index bfa9622e1ab1..439fa631c342 100644 > --- a/sound/soc/Kconfig > +++ b/sound/soc/Kconfig > @@ -38,6 +38,17 @@ config SND_SOC_TOPOLOGY > bool > select SND_DYNAMIC_MINORS > > +config SND_SOC_TOPOLOGY_BUILD > + bool "Build topology core" > + select SND_SOC_TOPOLOGY > + depends on KUNIT > + help > + This option exists to facilitate running the KUnit tests for > + the topology core, KUnit is frequently tested in virtual > + environments with minimal drivers enabled but the topology > + core is usually selected by drivers. There is little reason > + to enable it if not doing a KUnit build. > + > config SND_SOC_TOPOLOGY_KUNIT_TEST > tristate "KUnit tests for SoC topology" > depends on KUNIT > diff --git a/tools/testing/kunit/configs/all_tests.config b/tools/testing/kunit/configs/all_tests.config > index 13d15bc693fb..b8adb59455ef 100644 > --- a/tools/testing/kunit/configs/all_tests.config > +++ b/tools/testing/kunit/configs/all_tests.config > @@ -39,3 +39,4 @@ CONFIG_SECURITY_APPARMOR=y > CONFIG_SOUND=y > CONFIG_SND=y > CONFIG_SND_SOC=y > +CONFIG_SND_SOC_TOPOLOGY_BUILD=y > > -- > 2.39.2 >
diff --git a/sound/soc/Kconfig b/sound/soc/Kconfig index bfa9622e1ab1..439fa631c342 100644 --- a/sound/soc/Kconfig +++ b/sound/soc/Kconfig @@ -38,6 +38,17 @@ config SND_SOC_TOPOLOGY bool select SND_DYNAMIC_MINORS +config SND_SOC_TOPOLOGY_BUILD + bool "Build topology core" + select SND_SOC_TOPOLOGY + depends on KUNIT + help + This option exists to facilitate running the KUnit tests for + the topology core, KUnit is frequently tested in virtual + environments with minimal drivers enabled but the topology + core is usually selected by drivers. There is little reason + to enable it if not doing a KUnit build. + config SND_SOC_TOPOLOGY_KUNIT_TEST tristate "KUnit tests for SoC topology" depends on KUNIT diff --git a/tools/testing/kunit/configs/all_tests.config b/tools/testing/kunit/configs/all_tests.config index 13d15bc693fb..b8adb59455ef 100644 --- a/tools/testing/kunit/configs/all_tests.config +++ b/tools/testing/kunit/configs/all_tests.config @@ -39,3 +39,4 @@ CONFIG_SECURITY_APPARMOR=y CONFIG_SOUND=y CONFIG_SND=y CONFIG_SND_SOC=y +CONFIG_SND_SOC_TOPOLOGY_BUILD=y
The default KUnit build options are not supposed to enable any subsystems that were not already enabled but the topology code is a library which is generally selected by drivers that want to use it. Since KUnit is frequently run in virtual environments with minimal driver support this makes it difficult to enable the toplogy tests so provide an explicit Kconfig option which can be directly enabled when using KUnit, and also include this in the KUnit all_tests.config. Signed-off-by: Mark Brown <broonie@kernel.org> --- sound/soc/Kconfig | 11 +++++++++++ tools/testing/kunit/configs/all_tests.config | 1 + 2 files changed, 12 insertions(+)