From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jonatan Schlag To: development@lists.ipfire.org Subject: Re: [PATCH 13/21] initscript fkt: ignore blank lines in readhash Date: Sun, 02 Jun 2024 20:07:37 +0200 Message-ID: <7c93843e3978ecf281af842ae94220a678a49ce6.camel@ipfire.org> In-Reply-To: <2F5DC8C8-DA61-4C2B-9F04-9A6DA689DBF5@ipfire.org> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============1835970722260763715==" List-Id: --===============1835970722260763715== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Hi, Am Freitag, dem 31.05.2024 um 10:55 +0100 schrieb Michael Tremer: >=20 >=20 > > On 20 May 2024, at 10:06, Jonatan Schlag > > wrote: > >=20 > > Signed-off-by: Jonatan Schlag > > --- > > src/initscripts/system/functions=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2= =A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0= =C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 | 6 > > ++++++ > > tests/src/initscripts/system/functions/data/1_output_stderr | 0 > > tests/src/initscripts/system/functions/data/1_output_stdout | 0 > > tests/src/initscripts/system/functions/test.sh=C2=A0=C2=A0=C2=A0=C2=A0=C2= =A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0=C2=A0 | 3 +++ > > 4 files changed, 9 insertions(+) > > create mode 100644 > > tests/src/initscripts/system/functions/data/1_output_stderr > > create mode 100644 > > tests/src/initscripts/system/functions/data/1_output_stdout > >=20 > > diff --git a/src/initscripts/system/functions > > b/src/initscripts/system/functions > > index 44ce999d3..3f01be9e0 100644 > > --- a/src/initscripts/system/functions > > +++ b/src/initscripts/system/functions > > @@ -900,6 +900,12 @@ readhash() { > >=20 > > local line > > while read -r line; do > > + > > + # Skip Blank Lines > > + if [[ ${line} =3D~ ^[[:space:]]*$ ]]; then > > + continue > > + fi > > + > > local key=3D"${line%=3D*}" > > local val=3D"${line#*=3D}" >=20 > I don=E2=80=99t think this is quite sufficient. >=20 > You might have other lines that are invalid. For example =E2=80=9C=3DVALUE= =E2=80=9D. I > think we should check that key isn=E2=80=99t empty, and we should limit what > characters can be used in keys and values as it used to be before in > the script. >=20 > https://git.ipfire.org/?p=3Dipfire-2.x.git;a=3Dblob;f=3Dsrc/scripts/readhas= h;h=3Dbffc93fbd00c31a76e9c96fc17dabf0a87c3c9ef;hb=3DHEAD >=20 Hi, I will merge all commits for checks in the next series. There are more checks to come. In a later commit, I check for correct values and keys. Jonatan > >=20 > > diff --git > > a/tests/src/initscripts/system/functions/data/1_output_stderr > > b/tests/src/initscripts/system/functions/data/1_output_stderr > > new file mode 100644 > > index 000000000..e69de29bb > > diff --git > > a/tests/src/initscripts/system/functions/data/1_output_stdout > > b/tests/src/initscripts/system/functions/data/1_output_stdout > > new file mode 100644 > > index 000000000..e69de29bb > > diff --git a/tests/src/initscripts/system/functions/test.sh > > b/tests/src/initscripts/system/functions/test.sh > > index ec502e199..8d644b8cd 100755 > > --- a/tests/src/initscripts/system/functions/test.sh > > +++ b/tests/src/initscripts/system/functions/test.sh > > @@ -14,3 +14,6 @@ readhash "CONFIG" "${SCRIPT_PATH}/data/1" > > # test if we read the correct data > > test_that_key_in_arry_has_value "CONFIG" "RED_DHCP_HOSTNAME" > > "ipfire" > > test_that_key_in_arry_has_value "CONFIG" "BLUE_MACADDR" > > "bc:30:7d:58:6b:e3" > > + > > +test_that_output_is "${SCRIPT_PATH}/data/1_output_stdout" "1" > > readhash "CONFIG" "${SCRIPT_PATH}/data/1" > > +test_that_output_is "${SCRIPT_PATH}/data/1_output_stderr" "2" > > readhash "CONFIG" "${SCRIPT_PATH}/data/1" > > --=20 > > 2.39.2 > >=20 >=20 --===============1835970722260763715==--