On Mon, 2022-02-21 at 15:20 +0100, Pavel Zhukov wrote:
> There were few bugs in the _isInitialized() function which might trigger
> git repo to be reinitialized and patches failing to apply.
> 
> Signed-off-by: Pavel Zhukov <[email protected]>
> ---
>  .../net-tools/Add_missing_headers.patch       |  15 +++
>  .../net-tools/net-tools/net-tools-config.h    |  75 +++++++++++
>  .../net-tools/net-tools/net-tools-config.make |  36 ++++++
>  .../recipes-test/net-tools/net-tools_2.10.bb  | 121 ++++++++++++++++++
>  meta/lib/oe/patch.py                          |   6 +-
>  meta/lib/oeqa/selftest/cases/bbtests.py       |  20 ++-
>  6 files changed, 268 insertions(+), 5 deletions(-)
>  create mode 100644 
> meta-selftest/recipes-test/net-tools/net-tools/Add_missing_headers.patch
>  create mode 100644 
> meta-selftest/recipes-test/net-tools/net-tools/net-tools-config.h
>  create mode 100644 
> meta-selftest/recipes-test/net-tools/net-tools/net-tools-config.make
>  create mode 100644 meta-selftest/recipes-test/net-tools/net-tools_2.10.bb
> 
> diff --git 
> a/meta-selftest/recipes-test/net-tools/net-tools/Add_missing_headers.patch 
> b/meta-selftest/recipes-test/net-tools/net-tools/Add_missing_headers.patch
> new file mode 100644
> index 0000000000..f15d3654c7
> --- /dev/null
> +++ b/meta-selftest/recipes-test/net-tools/net-tools/Add_missing_headers.patch
> @@ -0,0 +1,15 @@
> +Description: Add missing headers
> +
> +Upstream-Status: Pending
> +Signed-off-by: Martin Jansa <[email protected]>
> +
> +--- a/netstat.c
> ++++ b/netstat.c
> +@@ -88,6 +88,7 @@
> + #include <sys/stat.h>
> + #include <net/if.h>
> + #include <dirent.h>
> ++#include <sys/types.h>
> + 
> + #include "net-support.h"
> + #include "pathnames.h"
> diff --git 
> a/meta-selftest/recipes-test/net-tools/net-tools/net-tools-config.h 
> b/meta-selftest/recipes-test/net-tools/net-tools/net-tools-config.h
> new file mode 100644
> index 0000000000..6d39c2a8cb
> --- /dev/null
> +++ b/meta-selftest/recipes-test/net-tools/net-tools/net-tools-config.h
> @@ -0,0 +1,75 @@
> +/*
> +* config.h   Automatically generated configuration includefile
> +*
> +* NET-TOOLS  A collection of programs that form the base set of the
> +*            NET-3 Networking Distribution for the LINUX operating
> +*            system.
> +*
> +*            DO  NOT  EDIT  DIRECTLY
> +*
> +*/
> +
> +/* 
> + * 
> + * Internationalization
> + * 
> + * The net-tools package has currently been translated to French,
> + * German and Brazilian Portugese.  Other translations are, of
> + * course, welcome.  Answer `n' here if you have no support for
> + * internationalization on your system.
> + * 
> + */
> +#define I18N 1
> +
> +/* 
> + * 
> + * Protocol Families.
> + * 
> + */
> +#define HAVE_AFUNIX 1
> +#define HAVE_AFINET 1
> +#define HAVE_AFINET6 1
> +#define HAVE_AFIPX 0
> +#define HAVE_AFATALK 0
> +#define HAVE_AFAX25 0
> +#define HAVE_AFNETROM 1
> +#define HAVE_AFROSE 0
> +#define HAVE_AFX25 0
> +#define HAVE_AFECONET 0
> +#define HAVE_AFDECnet 0
> +#define HAVE_AFASH 0
> +
> +/* 
> + * 
> + * Device Hardware types.
> + * 
> + */
> +#define HAVE_HWETHER 1
> +#define HAVE_HWARC 1
> +#define HAVE_HWSLIP 1
> +#define HAVE_HWPPP 1
> +#define HAVE_HWTUNNEL 1
> +#define HAVE_HWSTRIP 0
> +#define HAVE_HWTR 0
> +#define HAVE_HWAX25 0
> +#define HAVE_HWROSE 0
> +#define HAVE_HWNETROM 1
> +#define HAVE_HWX25 0
> +#define HAVE_HWFR 1
> +#define HAVE_HWSIT 0
> +#define HAVE_HWFDDI 0
> +#define HAVE_HWHIPPI 0
> +#define HAVE_HWASH 0
> +#define HAVE_HWHDLCLAPB 0
> +#define HAVE_HWIRDA 1
> +#define HAVE_HWEC 0
> +#define HAVE_HWIB 0
> +
> +/* 
> + * 
> + * Other Features.
> + * 
> + */
> +#define HAVE_FW_MASQUERADE 1
> +#define HAVE_IP_TOOLS 1
> +#define HAVE_MII 1
> diff --git 
> a/meta-selftest/recipes-test/net-tools/net-tools/net-tools-config.make 
> b/meta-selftest/recipes-test/net-tools/net-tools/net-tools-config.make
> new file mode 100644
> index 0000000000..ec516f27ee
> --- /dev/null
> +++ b/meta-selftest/recipes-test/net-tools/net-tools/net-tools-config.make
> @@ -0,0 +1,36 @@
> +I18N=1
> +HAVE_AFUNIX=1
> +HAVE_AFINET=1
> +HAVE_AFINET6=1
> +# HAVE_AFIPX=0
> +# HAVE_AFATALK=0
> +# HAVE_AFAX25=0
> +HAVE_AFNETROM=1
> +# HAVE_AFROSE=0
> +# HAVE_AFX25=0
> +# HAVE_AFECONET=0
> +# HAVE_AFDECnet=0
> +# HAVE_AFASH=0
> +HAVE_HWETHER=1
> +HAVE_HWARC=1
> +HAVE_HWSLIP=1
> +HAVE_HWPPP=1
> +HAVE_HWTUNNEL=1
> +HAVE_HWSTRIP=1
> +HAVE_HWTR=1
> +# HAVE_HWAX25=0
> +# HAVE_HWROSE=0
> +HAVE_HWNETROM=1
> +# HAVE_HWX25=0
> +HAVE_HWFR=1
> +# HAVE_HWSIT=0
> +# HAVE_HWFDDI=0
> +# HAVE_HWHIPPI=0
> +# HAVE_HWASH=0
> +# HAVE_HWHDLCLAPB=0
> +HAVE_HWIRDA=1
> +# HAVE_HWEC=0
> +# HAVE_HWIB=0
> +HAVE_FW_MASQUERADE=1
> +HAVE_IP_TOOLS=1
> +HAVE_MII=1
> diff --git a/meta-selftest/recipes-test/net-tools/net-tools_2.10.bb 
> b/meta-selftest/recipes-test/net-tools/net-tools_2.10.bb
> new file mode 100644
> index 0000000000..33304297ec
> --- /dev/null
> +++ b/meta-selftest/recipes-test/net-tools/net-tools_2.10.bb
> @@ -0,0 +1,121 @@
> +SUMMARY = "Basic networking tools"
> +DESCRIPTION = "A collection of programs that form the base set of the NET-3 
> networking distribution for the Linux operating system"
> +HOMEPAGE = "http://net-tools.berlios.de/";
> +BUGTRACKER = "http://bugs.debian.org/net-tools";
> +LICENSE = "GPL-2.0-or-later"
> +LIC_FILES_CHKSUM = "file://COPYING;md5=b234ee4d69f5fce4486a80fdaf4a4263 \
> +                    
> file://ifconfig.c;beginline=11;endline=15;md5=d1ca372080ad5401e23ca0afc35cf9ba"
> +
> +SRCREV = "80d7b95067f1f22fece9537dea6dff53081f4886"
> +SRC_URI = 
> "git://git.code.sf.net/p/net-tools/code;protocol=https;branch=master \
> +    file://net-tools-config.h \
> +    file://net-tools-config.make \
> +    file://Add_missing_headers.patch \
> +"
> +
> +S = "${WORKDIR}/git"
> +
> +inherit gettext
> +
> +# The Makefile is lame, no parallel build
> +PARALLEL_MAKE = ""
> +
> +PACKAGECONFIG ??= "hostname arp serial plip"
> +PACKAGECONFIG[hostname] = ""
> +PACKAGECONFIG[arp] = ""
> +PACKAGECONFIG[serial] = ""
> +PACKAGECONFIG[plip] = ""
> +PACKAGECONFIG[slattach] = ""
> +PACKAGECONFIG[plipconfig] = ""
> +
> +do_configure() {
> +     # net-tools has its own config mechanism requiring "make config"
> +     # we pre-generate desired options and copy to source directory instead
> +     cp ${WORKDIR}/net-tools-config.h    ${S}/config.h
> +     cp ${WORKDIR}/net-tools-config.make ${S}/config.make
> +
> +     if [ "${USE_NLS}" = "no" ]; then
> +             sed -i -e 's/^I18N=1/# I18N=1/' ${S}/config.make
> +     fi
> +
> +     if ${@bb.utils.contains('PACKAGECONFIG', 'hostname', 'true', 'false', 
> d)} ; then
> +             echo "#define HAVE_HOSTNAME_TOOLS 1" >> ${S}/config.h
> +             echo "#define HAVE_HOSTNAME_SYMLINKS 1" >> ${S}/config.h
> +             echo "HAVE_HOSTNAME_TOOLS=1" >> ${S}/config.make
> +             echo "HAVE_HOSTNAME_SYMLINKS=1" >> ${S}/config.make
> +     fi
> +     if ${@bb.utils.contains('PACKAGECONFIG', 'arp', 'true', 'false', d)} ; 
> then
> +             echo "#define HAVE_ARP_TOOLS 1" >> ${S}/config.h
> +             echo "HAVE_ARP_TOOLS=1" >> ${S}/config.make
> +     fi
> +     if ${@bb.utils.contains('PACKAGECONFIG', 'serial', 'true', 'false', d)} 
> ; then
> +             echo "#define HAVE_SERIAL_TOOLS 1" >> ${S}/config.h
> +             echo "HAVE_SERIAL_TOOLS=1" >> ${S}/config.make
> +     fi
> +     if ${@bb.utils.contains('PACKAGECONFIG', 'plip', 'true', 'false', d)} ; 
> then
> +             echo "#define HAVE_PLIP_TOOLS 1" >> ${S}/config.h
> +             echo "HAVE_PLIP_TOOLS=1" >> ${S}/config.make
> +     fi
> +}
> +
> +do_compile() {
> +     # net-tools use COPTS/LOPTS to allow adding custom options
> +     oe_runmake COPTS="$CFLAGS" LOPTS="$LDFLAGS"
> +}
> +
> +do_install() {
> +     # We don't need COPTS or LOPTS, but let's be consistent.
> +     oe_runmake COPTS="$CFLAGS" LOPTS="$LDFLAGS" BASEDIR=${D} 
> INSTALLNLSDIR=${D}${datadir}/locale mandir=${mandir} install
> +
> +     if [ "${base_bindir}" != "/bin" ]; then
> +             mkdir -p ${D}/${base_bindir}
> +             mv ${D}/bin/* ${D}/${base_bindir}/
> +             rmdir ${D}/bin
> +     fi
> +     if [ "${base_sbindir}" != "/sbin" ]; then
> +             mkdir ${D}/${base_sbindir}
> +             mv ${D}/sbin/* ${D}/${base_sbindir}/
> +             rmdir ${D}/sbin
> +     fi
> +}
> +
> +inherit update-alternatives
> +
> +base_sbindir_progs = "ipmaddr iptunnel mii-tool nameif \
> +    ${@bb.utils.contains('PACKAGECONFIG', 'arp', 'arp rarp', '', d)} \
> +    ${@bb.utils.contains('PACKAGECONFIG', 'plip', 'plipconfig', '', d)} \
> +    ${@bb.utils.contains('PACKAGECONFIG', 'serial', 'slattach', '', d)} \
> +"
> +base_bindir_progs  = "ifconfig netstat route \
> +    ${@bb.utils.contains('PACKAGECONFIG', 'hostname', 'dnsdomainname 
> domainname hostname nisdomainname ypdomainname', '', d)} \
> +"
> +
> +ALTERNATIVE:${PN} = "${base_sbindir_progs} ${base_bindir_progs}"
> +ALTERNATIVE:${PN}-doc += "${@bb.utils.contains('PACKAGECONFIG', 'hostname', 
> 'hostname.1 dnsdomainname.1', '', d)}"
> +ALTERNATIVE_LINK_NAME[hostname.1] = "${mandir}/man1/hostname.1"
> +ALTERNATIVE_LINK_NAME[dnsdomainname.1] = "${mandir}/man1/dnsdomainname.1"
> +ALTERNATIVE_PRIORITY[hostname.1] = "10"
> +
> +python __anonymous() {
> +    for prog in d.getVar('base_sbindir_progs').split():
> +        d.setVarFlag('ALTERNATIVE_LINK_NAME', prog, '%s/%s' % 
> (d.getVar('base_sbindir'), prog))
> +    for prog in d.getVar('base_bindir_progs').split():
> +        d.setVarFlag('ALTERNATIVE_LINK_NAME', prog, '%s/%s' % 
> (d.getVar('base_bindir'), prog))
> +}
> +ALTERNATIVE_PRIORITY = "100"
> +
> +NETTOOLS_PACKAGES = "${PN}-mii-tool"
> +NETTOOLS_PACKAGES:class-native = ""
> +
> +PACKAGE_BEFORE_PN = "${NETTOOLS_PACKAGES}"
> +RDEPENDS:${PN} += "${NETTOOLS_PACKAGES}"
> +
> +FILES:${PN}-mii-tool = "${base_sbindir}/mii-tool"
> +
> +ALTERNATIVE:${PN}:remove = "mii-tool"
> +
> +ALTERNATIVE:${PN}-mii-tool = "mii-tool"
> +ALTERNATIVE_TARGET[mii-tool] = "${base_sbindir}/mii-tool"
> +ALTERNATIVE_LINK_NAME[mii-tool] = "${base_sbindir}/mii-tool"
> +
> +BBCLASSEXTEND = "native nativesdk"

I'm not sure we want to add a copy of net-tools to the selftest layer. This
causes conflicts with the real net-tools recipe. Perhaps we can rename it to
something different for the test? You can also likely simplify the recipe, e.g.
remove the BBCLASSEXTEND and alternatives pieces, perhaps more. I doubt we need
those for the test?

Cheers,

Richard

-=-=-=-=-=-=-=-=-=-=-=-
Links: You receive all messages sent to this group.
View/Reply Online (#162059): 
https://lists.openembedded.org/g/openembedded-core/message/162059
Mute This Topic: https://lists.openembedded.org/mt/89294279/21656
Group Owner: [email protected]
Unsubscribe: https://lists.openembedded.org/g/openembedded-core/unsub 
[[email protected]]
-=-=-=-=-=-=-=-=-=-=-=-

Reply via email to