Let the tests work without installing libApp first
This commit is contained in:
parent
b20c1301fc
commit
74e061a9a7
18
tests/appbroker.c
Normal file
18
tests/appbroker.c
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
/* $Id$ */
|
||||||
|
/* Copyright (c) 2020 Pierre Pronchery <khorben@defora.org> */
|
||||||
|
/* This file is part of DeforaOS System libApp */
|
||||||
|
/* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, version 3 of the License.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#include "../tools/appbroker.c"
|
|
@ -27,7 +27,7 @@
|
||||||
#variables
|
#variables
|
||||||
PROGNAME="appbroker.sh"
|
PROGNAME="appbroker.sh"
|
||||||
#executables
|
#executables
|
||||||
APPBROKER="AppBroker"
|
APPBROKER=
|
||||||
DEBUG="_debug"
|
DEBUG="_debug"
|
||||||
|
|
||||||
|
|
||||||
|
@ -85,6 +85,11 @@ fi
|
||||||
|
|
||||||
[ "$clean" -ne 0 ] && exit 0
|
[ "$clean" -ne 0 ] && exit 0
|
||||||
|
|
||||||
|
if [ -z "$APPBROKER" ]; then
|
||||||
|
APPBROKER="./AppBroker$EXEEXT"
|
||||||
|
[ -n "$OBJDIR" ] && APPBROKER="${OBJDIR}AppBroker"
|
||||||
|
fi
|
||||||
|
|
||||||
exec 3>&1
|
exec 3>&1
|
||||||
while [ $# -gt 0 ]; do
|
while [ $# -gt 0 ]; do
|
||||||
target="$1"
|
target="$1"
|
||||||
|
@ -93,5 +98,7 @@ while [ $# -gt 0 ]; do
|
||||||
source="${target#$OBJDIR}"
|
source="${target#$OBJDIR}"
|
||||||
appinterface="${source##*/}"
|
appinterface="${source##*/}"
|
||||||
appinterface="${appinterface%%.h}.interface"
|
appinterface="${appinterface%%.h}.interface"
|
||||||
|
#XXX also look in ../data
|
||||||
|
[ ! -f "$appinterface" ] && appinterface="../data/$appinterface"
|
||||||
_appbroker "$target" "$appinterface" || exit 2
|
_appbroker "$target" "$appinterface" || exit 2
|
||||||
done
|
done
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
targets=Dummy.h,appclient,appinterface,appmessage,appserver,fixme.log,includes,lookup,shlint.log,tests.log,transport
|
targets=AppBroker,Dummy.h,appclient,appinterface,appmessage,appserver,fixme.log,includes,lookup,shlint.log,tests.log,transport
|
||||||
cppflags_force=-I../include -I$(OBJDIR).
|
cppflags_force=-I../include -I$(OBJDIR).
|
||||||
cflags_force=`pkg-config --cflags libSystem`
|
cflags_force=`pkg-config --cflags libSystem`
|
||||||
cflags=-W -Wall -g -O2 -fPIE -D_FORTIFY_SOURCE=2 -fstack-protector-all
|
cflags=-W -Wall -g -O2 -fPIE -D_FORTIFY_SOURCE=2 -fstack-protector-all
|
||||||
|
@ -7,11 +7,15 @@ ldflags=-pie -Wl,-z,relro -Wl,-z,now -rdynamic
|
||||||
dist=System/App.h,appbroker.sh,fixme.sh,Makefile,Test.expected,Test.interface,pkgconfig.sh,shlint.sh,tests.sh
|
dist=System/App.h,appbroker.sh,fixme.sh,Makefile,Test.expected,Test.interface,pkgconfig.sh,shlint.sh,tests.sh
|
||||||
|
|
||||||
#targets
|
#targets
|
||||||
|
[AppBroker]
|
||||||
|
type=binary
|
||||||
|
sources=appbroker.c
|
||||||
|
ldflags=$(OBJDIR)../src/libApp.a
|
||||||
|
|
||||||
[Dummy.h]
|
[Dummy.h]
|
||||||
type=script
|
type=script
|
||||||
script=../tools/appbroker.sh
|
script=./appbroker.sh
|
||||||
flags=-O APPBROKER=$(OBJDIR)../tools/AppBroker$(EXEEXT)
|
depends=../data/Dummy.interface,appbroker.sh
|
||||||
depends=../data/Dummy.interface,../tools/appbroker.sh
|
|
||||||
|
|
||||||
[appclient]
|
[appclient]
|
||||||
type=binary
|
type=binary
|
||||||
|
@ -62,6 +66,9 @@ type=binary
|
||||||
sources=transport.c
|
sources=transport.c
|
||||||
|
|
||||||
#sources
|
#sources
|
||||||
|
[appbroker.c]
|
||||||
|
depends=../tools/appbroker.c
|
||||||
|
|
||||||
[appclient.c]
|
[appclient.c]
|
||||||
depends=$(OBJDIR)../src/libApp.a
|
depends=$(OBJDIR)../src/libApp.a
|
||||||
|
|
||||||
|
|
|
@ -1,106 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
#$Id$
|
|
||||||
#Copyright (c) 2011-2016 Pierre Pronchery <khorben@defora.org>
|
|
||||||
#
|
|
||||||
#Redistribution and use in source and binary forms, with or without
|
|
||||||
#modification, are permitted provided that the following conditions are met:
|
|
||||||
#
|
|
||||||
# * Redistributions of source code must retain the above copyright notice, this
|
|
||||||
# list of conditions and the following disclaimer.
|
|
||||||
# * Redistributions in binary form must reproduce the above copyright notice,
|
|
||||||
# this list of conditions and the following disclaimer in the documentation
|
|
||||||
# and/or other materials provided with the distribution.
|
|
||||||
#
|
|
||||||
#THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
||||||
#AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
||||||
#IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
||||||
#DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
|
||||||
#FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
||||||
#DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
||||||
#SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
||||||
#CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
||||||
#OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
#OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#variables
|
|
||||||
PROGNAME="appbroker.sh"
|
|
||||||
#executables
|
|
||||||
APPBROKER=
|
|
||||||
DEBUG="_debug"
|
|
||||||
|
|
||||||
|
|
||||||
#functions
|
|
||||||
#appbroker
|
|
||||||
_appbroker()
|
|
||||||
{
|
|
||||||
target="$1"
|
|
||||||
appinterface="$2"
|
|
||||||
|
|
||||||
$DEBUG $APPBROKER -o "$target" "$appinterface"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#debug
|
|
||||||
_debug()
|
|
||||||
{
|
|
||||||
echo "$@" 1>&3
|
|
||||||
"$@"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#usage
|
|
||||||
_usage()
|
|
||||||
{
|
|
||||||
echo "Usage: $PROGNAME [-c] target..." 1>&2
|
|
||||||
return 1
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#main
|
|
||||||
clean=0
|
|
||||||
while getopts "cO:P:" name; do
|
|
||||||
case "$name" in
|
|
||||||
c)
|
|
||||||
clean=1
|
|
||||||
;;
|
|
||||||
O)
|
|
||||||
export "${OPTARG%%=*}"="${OPTARG#*=}"
|
|
||||||
;;
|
|
||||||
P)
|
|
||||||
#XXX ignored for compatibility
|
|
||||||
;;
|
|
||||||
?)
|
|
||||||
_usage
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
shift $((OPTIND - 1))
|
|
||||||
if [ $# -eq 0 ]; then
|
|
||||||
_usage
|
|
||||||
exit $?
|
|
||||||
fi
|
|
||||||
|
|
||||||
[ "$clean" -ne 0 ] && exit 0
|
|
||||||
|
|
||||||
if [ -n "$PKG_CONFIG_SYSROOT_DIR" ]; then
|
|
||||||
#XXX cross-compiling (requires AppBroker(1) installed)
|
|
||||||
APPBROKER="AppBroker$EXEEXT"
|
|
||||||
elif [ -z "$APPBROKER" ]; then
|
|
||||||
APPBROKER="$OBJDIR../tools/AppBroker$EXEEXT"
|
|
||||||
#XXX ugly workaround
|
|
||||||
export LD_LIBRARY_PATH="$OBJDIR../src"
|
|
||||||
fi
|
|
||||||
|
|
||||||
exec 3>&1
|
|
||||||
while [ $# -gt 0 ]; do
|
|
||||||
target="$1"
|
|
||||||
shift
|
|
||||||
|
|
||||||
source="${target#$OBJDIR}"
|
|
||||||
appinterface="${source##*/}"
|
|
||||||
appinterface="../data/${appinterface%%.h}.interface"
|
|
||||||
_appbroker "$target" "$appinterface" || exit 2
|
|
||||||
done
|
|
|
@ -5,8 +5,9 @@ cflags_force=`pkg-config --cflags libSystem libMarshall`
|
||||||
cflags=-W -Wall -g -O2 -fPIE -D_FORTIFY_SOURCE=2 -fstack-protector-all
|
cflags=-W -Wall -g -O2 -fPIE -D_FORTIFY_SOURCE=2 -fstack-protector-all
|
||||||
ldflags_force=-L$(OBJDIR)../src `pkg-config --libs libSystem libMarshall` -lApp
|
ldflags_force=-L$(OBJDIR)../src `pkg-config --libs libSystem libMarshall` -lApp
|
||||||
ldflags=-pie -Wl,-z,relro -Wl,-z,now
|
ldflags=-pie -Wl,-z,relro -Wl,-z,now
|
||||||
dist=Makefile,appbroker.sh
|
dist=Makefile
|
||||||
|
|
||||||
|
#targets
|
||||||
[AppBroker]
|
[AppBroker]
|
||||||
type=binary
|
type=binary
|
||||||
sources=appbroker.c
|
sources=appbroker.c
|
||||||
|
|
Loading…
Reference in New Issue
Block a user