Apply gcov automation 47/276047/2 accepted/tizen/unified/20220614.134747 submit/tizen/20220610.003743
authorSeonah Moon <seonah1.moon@samsung.com>
Thu, 9 Jun 2022 04:06:49 +0000 (13:06 +0900)
committerSeonah Moon <seonah1.moon@samsung.com>
Thu, 9 Jun 2022 04:09:54 +0000 (13:09 +0900)
Change-Id: I3a349c5f1c2476bd96c37b4cc379eb6ddd691067

CMakeLists.txt
packaging/capi-vpn-service.spec
tests/CMakeLists.txt

index dff581b..ea89ef9 100755 (executable)
@@ -64,6 +64,4 @@ CONFIGURE_FILE(
 INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/${PACKAGE_NAME}.pc DESTINATION ${LIBDIR}/pkgconfig)
 
 ADD_SUBDIRECTORY(tools)
-IF(BUILD_GTESTS)
-       ADD_SUBDIRECTORY(tests)
-ENDIF(BUILD_GTESTS)
+ADD_SUBDIRECTORY(tests)
index 671c280..17c4b96 100755 (executable)
@@ -16,7 +16,9 @@ BuildRequires:  pkgconfig(capi-appfw-package-manager)
 BuildRequires:  pkgconfig(capi-appfw-app-manager)
 BuildRequires: pkgconfig(capi-system-info)
 BuildRequires: pkgconfig(gmock)
+
 %if 0%{?gcov:1}
+BuildRequires: gtest-devel
 BuildRequires: lcov
 BuildRequires: tar
 %endif
@@ -45,12 +47,18 @@ capi-vpnsvc CAPI devel package
 
 %if 0%{?gcov:1}
 %package gcov
-Summary:  VPN service library(gcov)
-Group:    Network/Testing
+Summary: %{name} gcov data
+
 %description gcov
 gcov objects for coverage test
 %endif
 
+%package unittests
+Summary: %{name} unittests binary
+
+%description unittests
+unittests binary
+
 %prep
 %setup -q
 
@@ -59,7 +67,6 @@ gcov objects for coverage test
 export CFLAGS+=" -fprofile-arcs -ftest-coverage"
 export CXXFLAGS+=" -fprofile-arcs -ftest-coverage"
 export FFLAGS+=" -fprofile-arcs -ftest-coverage"
-export LDFLAGS+=" -lgcov"
 %endif
 
 export LDFLAGS+=" -Wl,--rpath=%{_libdir}"
@@ -70,29 +77,51 @@ MAJORVER=`echo %{version} | awk 'BEGIN {FS="."}{print $1}'`
        -DMAJORVER=${MAJORVER} \
        -DCMAKE_BUILD_TYPE=%{?build_type:%build_type}%{!?build_type:RELEASE} \
        -DCMAKE_VERBOSE_MAKEFILE=ON \
-       -DLIB_INSTALL_DIR=%{_libdir} \
-       -DBUILD_GTESTS=%{?gcov:1}%{!?gcov:0}
+       -DLIB_INSTALL_DIR=%{_libdir}
 
 make %{?jobs:-j%jobs}
 
-%if 0%{?gcov:1}
-mkdir -p gcov-obj
-find . -name '*.gcno' -exec cp '{}' gcov-obj ';'
-%endif
-
 %install
 %make_install
 
 %if 0%{?gcov:1}
-find .. -name '*.gcno' | tar cf %{name}-gcov.tar -T -
-install -d -m 755 %{buildroot}%{_datadir}/gcov/obj/%{name}
-tar xf %{name}-gcov.tar -C %{buildroot}%{_datadir}/gcov/obj/%{name}
+builddir=$(basename $PWD)
+gcno_obj_dir=%{buildroot}%{_datadir}/gcov/obj/%{name}/"$builddir"
+mkdir -p "$gcno_obj_dir"
+find . -name '*.gcno' -not -path '*/tools/*' -exec cp --parents '{}' "$gcno_obj_dir" ';'
 %endif
 
+cat << EOF > run-unittest.sh
+#!/bin/bash
+setup() {
+    echo "setup start"
+}
+
+test_main() {
+    echo "test_main start"
+    /usr/bin/vpn-service-gtest
+}
+
+teardown() {
+    echo "teardown start"
+}
+
+main() {
+    setup
+    test_main
+    teardown
+}
+
+main "$@"
+EOF
+
+mkdir -p %{buildroot}%{_bindir}/tizen-unittests/%{name}
+install -m 0755 run-unittest.sh %{buildroot}%{_bindir}/tizen-unittests/%{name}
+
+
 %check
 %if 0%{?gcov:1}
-tests/vpn-service-gtest
-
+LD_LIBRARY_PATH=. tests/vpn-service-gtest
 lcov -c --ignore-errors graph --no-external -b . -d . -o %{name}.info
 genhtml %{name}.info -o out --legend --show-details
 %endif
@@ -114,5 +143,9 @@ genhtml %{name}.info -o out --legend --show-details
 
 %if 0%{?gcov:1}
 %files gcov
-%{_datadir}/gcov/obj/%{name}/*
+%{_datadir}/gcov/obj/*
 %endif
+
+%files unittests
+%{_bindir}/vpn-service-gtest
+%{_bindir}/tizen-unittests/%{name}/run-unittest.sh
index 223386f..be44be1 100644 (file)
@@ -26,3 +26,5 @@ SET_TARGET_PROPERTIES(${VPN_SERVICE_GTEST} PROPERTIES
 --wrap=select,\
 --wrap=system_info_get_platform_bool,\
 --wrap=write")
+
+INSTALL(TARGETS ${VPN_SERVICE_GTEST} DESTINATION bin/)