Merge branch 'master' of github.sec.samsung.net:appfw/pkgmgr-info into tizen
[platform/core/appfw/pkgmgr-info.git] / packaging / pkgmgr-info.spec
old mode 100644 (file)
new mode 100755 (executable)
index 1de3e16..1668c7d
@@ -1,15 +1,18 @@
 Name:       pkgmgr-info
 Summary:    Packager Manager infomation api for package
-Version:    0.17.3
+Version:    0.20.4
 Release:    1
 Group:      Application Framework/Package Management
 License:    Apache-2.0
 Source0:    %{name}-%{version}.tar.gz
+Source1:    %{name}.service
+Source2:    %{name}.socket
 Source1001: pkgmgr-info.manifest
 BuildRequires: cmake
 BuildRequires: pkgconfig(dlog)
 BuildRequires: pkgconfig(glib-2.0)
 BuildRequires: pkgconfig(gio-2.0)
+BuildRequires: pkgconfig(gio-unix-2.0)
 BuildRequires: pkgconfig(vconf)
 BuildRequires: pkgconfig(sqlite3)
 BuildRequires: pkgconfig(libxml-2.0)
@@ -18,6 +21,14 @@ BuildRequires: pkgconfig(libsmack)
 BuildRequires: pkgconfig(bundle)
 BuildRequires: pkgconfig(capi-system-info)
 BuildRequires: pkgconfig(minizip)
+BuildRequires: pkgconfig(libsystemd)
+BuildRequires: pkgconfig(gmock)
+BuildRequires: pkgconfig(parcel)
+
+%if 0%{?gcov:1}
+BuildRequires:  lcov
+BuildRequires:  zip
+%endif
 
 %description
 Packager Manager infomation api for packaging
@@ -43,23 +54,71 @@ Requires:   pkgconfig(libtzplatform-config)
 %description parser-devel
 Dev package for libpkgmgr-parser
 
+%package common
+Summary:    Library for pkgmgr-info-server
+Requires:   %{name} = %{version}-%{release}
+Requires:   pkgconfig(libsystemd)
+
+%description common
+Library for pkgmgr-info-server
+
+%package common-devel
+Summary:    Dev package for libpkgmgr_common
+Requires:   %{name}-common = %{version}-%{release}
+
+%description common-devel
+Dev package for libpkgmgr_common
 
 %prep
 %setup -q
 cp %{SOURCE1001} .
 
 %build
+%if 0%{?gcov:1}
+export CFLAGS+=" -fprofile-arcs -ftest-coverage"
+export CXXFLAGS+=" -fprofile-arcs -ftest-coverage"
+export FFLAGS+=" -fprofile-arcs -ftest-coverage"
+export LDFLAGS+=" -lgcov"
+%endif
+
 MAJORVER=`echo %{version} | awk 'BEGIN {FS="."}{print $1}'`
 %cmake . -DFULLVER=%{version} -DMAJORVER=${MAJORVER} -DUNITDIR=%{_unitdir}
 
 %__make %{?jobs:-j%jobs}
 
+%if 0%{?gcov:1}
+mkdir -p gcov-obj
+find . -name '*.gcno' ! -path './gcov-obj/*' -exec cp '{}' gcov-obj ';'
+%endif
+
+%check
+export LD_LIBRARY_PATH=../../src/:../../src/server:../../parser
+ctest -V
+%if 0%{?gcov:1}
+lcov -c --ignore-errors graph --no-external -q -d . -o pkgmgr-info.info
+genhtml pkgmgr-info.info -o pkgmgr-info.out
+zip -r pkgmgr-info.zip pkgmgr-info.out
+install -m 0644 pkgmgr-info.zip %{buildroot}%{_datadir}/gcov/
+%endif
+
 %install
 %make_install
 
 mkdir -p %{buildroot}%{_unitdir}/basic.target.wants
 ln -sf ../pkg-db-recovery.service %{buildroot}%{_unitdir}/basic.target.wants/pkg-db-recovery.service
 
+mkdir -p %{buildroot}%{_unitdir}/default.target.wants
+mkdir -p %{buildroot}%{_unitdir}/sockets.target.wants
+install -m 0644 %SOURCE1 %{buildroot}%{_unitdir}/%{name}.service
+install -m 0644 %SOURCE2 %{buildroot}%{_unitdir}/%{name}.socket
+ln -s ../%{name}.service %{buildroot}%{_unitdir}/default.target.wants/%{name}.service
+ln -sf ../%{name}.socket %{buildroot}%{_unitdir}/sockets.target.wants/%{name}.socket
+
+%if 0%{?gcov:1}
+mkdir -p %{buildroot}%{_datadir}/gcov/obj
+install -m 0644 gcov-obj/* %{buildroot}%{_datadir}/gcov/obj
+%endif
+
 %post
 /sbin/ldconfig
 
@@ -74,10 +133,17 @@ ln -sf ../pkg-db-recovery.service %{buildroot}%{_unitdir}/basic.target.wants/pkg
 %license LICENSE
 %defattr(-,root,root,-)
 %{_libdir}/libpkgmgr-info.so.*
+%{_libdir}/libpkgmgr-info-server.so.*
 %{_bindir}/pkg-db-recovery
 %{_bindir}/pkg-db-creator
+%{_bindir}/pkginfo-server
 %{_unitdir}/pkg-db-recovery.service
 %{_unitdir}/basic.target.wants/pkg-db-recovery.service
+%{_includedir}/pkgmgr-client/*.hh
+%{_unitdir}/default.target.wants/%{name}.service
+%{_unitdir}/sockets.target.wants/%{name}.socket
+%attr(0644,root,root) /usr/lib/systemd/system/%{name}.service
+%attr(0644,root,root) /usr/lib/systemd/system/%{name}.socket
 
 %files devel
 %manifest %{name}.manifest
@@ -85,6 +151,9 @@ ln -sf ../pkg-db-recovery.service %{buildroot}%{_unitdir}/basic.target.wants/pkg
 %{_includedir}/*.h
 %{_libdir}/pkgconfig/pkgmgr-info.pc
 %{_libdir}/libpkgmgr-info.so
+%{_libdir}/libpkgmgr-info-server.so
+%{_includedir}/pkgmgr-client/*.hh
+%{_includedir}/pkgmgr-common/*.hh
 
 %files parser
 %manifest %{name}.manifest
@@ -93,7 +162,6 @@ ln -sf ../pkg-db-recovery.service %{buildroot}%{_unitdir}/basic.target.wants/pkg
 %{_libdir}/libpkgmgr_parser.so.*
 %config %{_sysconfdir}/package-manager/preload/manifest.xsd
 %config %{_sysconfdir}/package-manager/preload/xml.xsd
-%config %{_sysconfdir}/package-manager/parser_path.conf
 %config %{_sysconfdir}/package-manager/parserlib/metadata/mdparser_list.txt
 %config %{_sysconfdir}/package-manager/parserlib/category/category_parser_list.txt
 %config %{_sysconfdir}/package-manager/parserlib/tag_parser_list.txt
@@ -105,3 +173,21 @@ ln -sf ../pkg-db-recovery.service %{buildroot}%{_unitdir}/basic.target.wants/pkg
 %{_includedir}/pkgmgr/*.h
 %{_libdir}/pkgconfig/pkgmgr-parser.pc
 %{_libdir}/libpkgmgr_parser.so
+
+#################################################
+# pkgmgr-info-gcov
+#################################################
+%if 0%{?gcov:1}
+%package gcov
+Summary:    Packager Manager information api (gcov)
+Group:      Application Framework/Testing
+
+%description gcov
+Packager Manager information api gcov objects
+%endif
+
+%if 0%{?gcov:1}
+%files gcov
+%defattr(-,root,root,-)
+%{_datadir}/gcov/*
+%endif