Message ID | 1517877294-4826-11-git-send-email-yamada.masahiro@socionext.com |
---|---|
State | Superseded |
Headers | show |
Series | Add Kconfig unit tests | expand |
On Tue, Feb 6, 2018 at 1:34 AM, Masahiro Yamada <yamada.masahiro@socionext.com> wrote: > If new choice values are added with new dependency, and they become > visible during user configuration, oldconfig should recognize them > as (NEW), and ask the user for choice. > > This issue was fixed by commit 5d09598d488f ("kconfig: fix new choices > being skipped upon config update"). > > This is a subtle corner case. Add a test case to avoid breakage. > > Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com> > --- > > scripts/kconfig/tests/new_choice_with_dep/Kconfig | 37 ++++++++++++++++++++++ > .../kconfig/tests/new_choice_with_dep/__init__.py | 14 ++++++++ > scripts/kconfig/tests/new_choice_with_dep/config | 3 ++ > .../tests/new_choice_with_dep/expected_stdout | 10 ++++++ > 4 files changed, 64 insertions(+) > create mode 100644 scripts/kconfig/tests/new_choice_with_dep/Kconfig > create mode 100644 scripts/kconfig/tests/new_choice_with_dep/__init__.py > create mode 100644 scripts/kconfig/tests/new_choice_with_dep/config > create mode 100644 scripts/kconfig/tests/new_choice_with_dep/expected_stdout > > diff --git a/scripts/kconfig/tests/new_choice_with_dep/Kconfig b/scripts/kconfig/tests/new_choice_with_dep/Kconfig > new file mode 100644 > index 0000000..53ef1b8 > --- /dev/null > +++ b/scripts/kconfig/tests/new_choice_with_dep/Kconfig > @@ -0,0 +1,37 @@ > +config A > + bool "A" > + help > + This is a new symbol. > + > +choice > + prompt "Choice ?" > + depends on A > + help > + "depends on A" has been newly added. > + > +config CHOICE_B > + bool "Choice B" > + > +config CHOICE_C > + bool "Choice C" > + help > + This is a new symbol, so should be asked. > + > +endchoice > + > +choice > + prompt "Choice2 ?" > + > +config CHOICE_D > + bool "Choice D" > + > +config CHOICE_E > + bool "Choice E" > + > +config CHOICE_F > + bool "Choice F" > + depends on A > + help > + This is a new symbol, so should be asked. > + > +endchoice > diff --git a/scripts/kconfig/tests/new_choice_with_dep/__init__.py b/scripts/kconfig/tests/new_choice_with_dep/__init__.py > new file mode 100644 > index 0000000..4306ccf > --- /dev/null > +++ b/scripts/kconfig/tests/new_choice_with_dep/__init__.py > @@ -0,0 +1,14 @@ > +""" > +Ask new choice values when they become visible > +============================================== > + > +If new choice values are added with new dependency, and they become > +visible during user configuration, oldconfig should recognize them > +as (NEW), and ask the user for choice. > + > +Related Linux commit: 5d09598d488f081e3be23f885ed65cbbe2d073b5 > +""" > + > +def test(conf): > + assert conf.oldconfig('config', 'y') == 0 > + assert conf.stdout_contains('expected_stdout') > diff --git a/scripts/kconfig/tests/new_choice_with_dep/config b/scripts/kconfig/tests/new_choice_with_dep/config > new file mode 100644 > index 0000000..47ef95d > --- /dev/null > +++ b/scripts/kconfig/tests/new_choice_with_dep/config > @@ -0,0 +1,3 @@ > +CONFIG_CHOICE_B=y > +# CONFIG_CHOICE_D is not set > +CONFIG_CHOICE_E=y > diff --git a/scripts/kconfig/tests/new_choice_with_dep/expected_stdout b/scripts/kconfig/tests/new_choice_with_dep/expected_stdout > new file mode 100644 > index 0000000..358d5cf > --- /dev/null > +++ b/scripts/kconfig/tests/new_choice_with_dep/expected_stdout > @@ -0,0 +1,10 @@ > +A (A) [N/y/?] (NEW) > + Choice ? > + > 1. Choice B (CHOICE_B) > + 2. Choice C (CHOICE_C) (NEW) > + choice[1-2?]: > +Choice2 ? > + 1. Choice D (CHOICE_D) > +> 2. Choice E (CHOICE_E) > + 3. Choice F (CHOICE_F) (NEW) > +choice[1-3?]: > -- > 2.7.4 > Reviewed-by: Ulf Magnusson <ulfalizer@gmail.com>
diff --git a/scripts/kconfig/tests/new_choice_with_dep/Kconfig b/scripts/kconfig/tests/new_choice_with_dep/Kconfig new file mode 100644 index 0000000..53ef1b8 --- /dev/null +++ b/scripts/kconfig/tests/new_choice_with_dep/Kconfig @@ -0,0 +1,37 @@ +config A + bool "A" + help + This is a new symbol. + +choice + prompt "Choice ?" + depends on A + help + "depends on A" has been newly added. + +config CHOICE_B + bool "Choice B" + +config CHOICE_C + bool "Choice C" + help + This is a new symbol, so should be asked. + +endchoice + +choice + prompt "Choice2 ?" + +config CHOICE_D + bool "Choice D" + +config CHOICE_E + bool "Choice E" + +config CHOICE_F + bool "Choice F" + depends on A + help + This is a new symbol, so should be asked. + +endchoice diff --git a/scripts/kconfig/tests/new_choice_with_dep/__init__.py b/scripts/kconfig/tests/new_choice_with_dep/__init__.py new file mode 100644 index 0000000..4306ccf --- /dev/null +++ b/scripts/kconfig/tests/new_choice_with_dep/__init__.py @@ -0,0 +1,14 @@ +""" +Ask new choice values when they become visible +============================================== + +If new choice values are added with new dependency, and they become +visible during user configuration, oldconfig should recognize them +as (NEW), and ask the user for choice. + +Related Linux commit: 5d09598d488f081e3be23f885ed65cbbe2d073b5 +""" + +def test(conf): + assert conf.oldconfig('config', 'y') == 0 + assert conf.stdout_contains('expected_stdout') diff --git a/scripts/kconfig/tests/new_choice_with_dep/config b/scripts/kconfig/tests/new_choice_with_dep/config new file mode 100644 index 0000000..47ef95d --- /dev/null +++ b/scripts/kconfig/tests/new_choice_with_dep/config @@ -0,0 +1,3 @@ +CONFIG_CHOICE_B=y +# CONFIG_CHOICE_D is not set +CONFIG_CHOICE_E=y diff --git a/scripts/kconfig/tests/new_choice_with_dep/expected_stdout b/scripts/kconfig/tests/new_choice_with_dep/expected_stdout new file mode 100644 index 0000000..358d5cf --- /dev/null +++ b/scripts/kconfig/tests/new_choice_with_dep/expected_stdout @@ -0,0 +1,10 @@ +A (A) [N/y/?] (NEW) + Choice ? + > 1. Choice B (CHOICE_B) + 2. Choice C (CHOICE_C) (NEW) + choice[1-2?]: +Choice2 ? + 1. Choice D (CHOICE_D) +> 2. Choice E (CHOICE_E) + 3. Choice F (CHOICE_F) (NEW) +choice[1-3?]:
If new choice values are added with new dependency, and they become visible during user configuration, oldconfig should recognize them as (NEW), and ask the user for choice. This issue was fixed by commit 5d09598d488f ("kconfig: fix new choices being skipped upon config update"). This is a subtle corner case. Add a test case to avoid breakage. Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com> --- scripts/kconfig/tests/new_choice_with_dep/Kconfig | 37 ++++++++++++++++++++++ .../kconfig/tests/new_choice_with_dep/__init__.py | 14 ++++++++ scripts/kconfig/tests/new_choice_with_dep/config | 3 ++ .../tests/new_choice_with_dep/expected_stdout | 10 ++++++ 4 files changed, 64 insertions(+) create mode 100644 scripts/kconfig/tests/new_choice_with_dep/Kconfig create mode 100644 scripts/kconfig/tests/new_choice_with_dep/__init__.py create mode 100644 scripts/kconfig/tests/new_choice_with_dep/config create mode 100644 scripts/kconfig/tests/new_choice_with_dep/expected_stdout -- 2.7.4