From 22614a1efdcb36e06eadf7a8c01c0a22d8671755 Mon Sep 17 00:00:00 2001 From: Jan Chaloupka Date: Jul 29 2015 17:25:04 +0000 Subject: Update of spec file to spec-2.0 - resolves: #1248138 --- diff --git a/golang-gopkg-check.spec b/golang-gopkg-check.spec index b8d741b..5371cc9 100644 --- a/golang-gopkg-check.spec +++ b/golang-gopkg-check.spec @@ -1,13 +1,41 @@ +%if 0%{?fedora} || 0%{?rhel} == 6 +%global with_devel 1 +%global with_bundled 0 +%global with_debug 0 +# test fails +%global with_check 0 +%global with_unit_test 1 +%else +%global with_devel 0 +%global with_bundled 0 +%global with_debug 0 +%global with_check 0 +%global with_unit_test 0 +%endif + +%if 0%{?with_debug} +%global _dwz_low_mem_die_limit 0 +%else %global debug_package %{nil} -%global commit 91ae5f88a67b14891cfd43895b01164f6c120420 -%global shortcommit %(c=%{commit}; echo ${c:0:7}) +%endif + +%define copying() \ +%if 0%{?fedora} >= 21 || 0%{?rhel} >= 7 \ +%license %{*} \ +%else \ +%doc %{*} \ +%endif -%global provider gopkg -%global provider_tld in +%global provider github +%global provider_tld com +%global project go-check %global repo check -%global version v1 -%global import_path %{provider}.%{provider_tld}/%{repo}.%{version} +# https://github.com/go-check/check +%global provider_prefix %{provider}.%{provider_tld}/%{project}/%{repo} +%global import_path gopkg.in/check.v1 %global import_path_sec launchpad.net/gocheck +%global commit 91ae5f88a67b14891cfd43895b01164f6c120420 +%global shortcommit %(c=%{commit}; echo ${c:0:7}) # github.com/motain/gocheck, cloned from github.com/go-check/check on Oct 23, 2013 %global mcommit 10bfe0586b48cbca10fe6c43d6e18136f25f8c0c @@ -16,37 +44,82 @@ Name: golang-gopkg-%{repo} Version: 0 -Release: 5%{?dist} +Release: 6%{?dist} Summary: Rich testing for the Go language License: BSD -# gopkg.in/check.v1 -URL: http://%{import_path} -Source0: https://github.com/go-%{repo}/%{repo}/archive/%{mcommit}/%{repo}-%{mscommit}.tar.gz -Source1: https://github.com/go-%{repo}/%{repo}/archive/%{commit}/%{repo}-%{shortcommit}.tar.gz -Obsoletes: golang-launchpad-gocheck -%if 0%{?fedora} >= 19 || 0%{?rhel} >= 7 -BuildArch: noarch +URL: https://%{provider_prefix} +Source0: https://%{provider_prefix}/archive/%{mcommit}/%{repo}-%{mscommit}.tar.gz +Source1: https://%{provider_prefix}/archive/%{commit}/%{repo}-%{shortcommit}.tar.gz +Obsoletes: golang-launchpad-gocheck + +# If go_arches not defined fall through to implicit golang archs +%if 0%{?go_arches:1} +ExclusiveArch: %{go_arches} %else -ExclusiveArch: %{ix86} x86_64 %{arm} +ExclusiveArch: %{ix86} x86_64 %{arm} +%endif +# If gccgo_arches does not fit or is not defined fall through to golang +%ifarch 0%{?gccgo_arches} +BuildRequires: gcc-go >= %{gccgo_min_vers} +%else +BuildRequires: golang %endif %description %{summary} +%if 0%{?with_devel} %package devel -BuildRequires: golang >= 1.2.1-3 -Requires: golang >= 1.2.1-3 -Summary: %{summary} -Provides: golang(%{import_path}) = %{version}-%{release} -Provides: golang(%{import_path_sec}) = %{version}-%{release} -Provides: golang(%{mimport_path}) = %{version}-%{release} -Obsoletes: golang-launchpad-gocheck-devel +Summary: %{summary} +BuildArch: noarch + +%if 0%{?with_check} +%endif + + +Provides: golang(%{import_path}) = %{version}-%{release} +Provides: golang(%{import_path_sec}) = %{version}-%{release} +Provides: golang(%{mimport_path}) = %{version}-%{release} +Obsoletes: golang-launchpad-gocheck-devel %description devel %{summary} -This package contains library source intended for -building other packages which use %{import_path}. +This package contains library source intended for +building other packages which use import path with +%{import_path} prefix. +%endif + +%if 0%{?with_unit_test} +%package unit-test +Summary: Unit tests for %{name} package +# If go_arches not defined fall through to implicit golang archs +%if 0%{?go_arches:1} +ExclusiveArch: %{go_arches} +%else +ExclusiveArch: %{ix86} x86_64 %{arm} +%endif +# If gccgo_arches does not fit or is not defined fall through to golang +%ifarch 0%{?gccgo_arches} +BuildRequires: gcc-go >= %{gccgo_min_vers} +%else +BuildRequires: golang +%endif + +%if 0%{?with_check} +#Here comes all BuildRequires: PACKAGE the unit tests +#in %%check section need for running +%endif + +# test subpackage tests code from devel subpackage +Requires: %{name}-devel = %{version}-%{release} + +%description unit-test +%{summary} + +This package contains unit tests for project +providing packages with %{import_path} prefix. +%endif %prep %setup -n %{repo}-%{mcommit} -q @@ -55,27 +128,77 @@ building other packages which use %{import_path}. %build %install +# source codes for building projects +%if 0%{?with_devel} install -d -p %{buildroot}/%{gopath}/src/%{import_path}/ -cp -pav *.go %{buildroot}/%{gopath}/src/%{import_path}/ install -d -p %{buildroot}/%{gopath}/src/%{import_path_sec}/ -cp -pav *.go %{buildroot}/%{gopath}/src/%{import_path_sec}/ +# find all *.go but no *_test.go files and generate devel.file-list +for file in $(find . -iname "*.go" \! -iname "*_test.go") ; do + install -d -p %{buildroot}/%{gopath}/src/%{import_path}/$(dirname $file) + cp $file %{buildroot}/%{gopath}/src/%{import_path}/$file + echo "%%{gopath}/src/%%{import_path}/$file" >> devel.file-list + install -d -p %{buildroot}/%{gopath}/src/%{import_path_sec}/$(dirname $file) + cp $file %{buildroot}/%{gopath}/src/%{import_path_sec}/$file + echo "%%{gopath}/src/%%{import_path_sec}/$file" >> devel.file-list +done pushd ../%{repo}-%{mcommit} install -d -p %{buildroot}/%{gopath}/src/%{mimport_path}/ -cp -pav *.go %{buildroot}/%{gopath}/src/%{mimport_path}/ +# find all *.go but no *_test.go files and generate devel.file-list +for file in $(find . -iname "*.go" \! -iname "*_test.go") ; do + install -d -p %{buildroot}/%{gopath}/src/%{mimport_path}/$(dirname $file) + cp $file %{buildroot}/%{gopath}/src/%{mimport_path}/$file + echo "%%{gopath}/src/%%{mimport_path}/$file" >> ../%{repo}-%{commit}/devel.file-list +done +popd +%endif + +# testing files for this project +%if 0%{?with_unit_test} +install -d -p %{buildroot}/%{gopath}/src/%{import_path}/ +# find all *_test.go files and generate unit-test.file-list +for file in $(find . -iname "*_test.go"); do + install -d -p %{buildroot}/%{gopath}/src/%{import_path}/$(dirname $file) + cp $file %{buildroot}/%{gopath}/src/%{import_path}/$file + echo "%%{gopath}/src/%%{import_path}/$file" >> unit-test.file-list +done +%endif %check -#GOPATH={buildroot}{gopath}:{gopath} go test {import_path} +%if 0%{?with_check} && 0%{?with_unit_test} && 0%{?with_devel} +%ifarch 0%{?gccgo_arches} +function gotest { %{gcc_go_test} "$@"; } +%else +%if 0%{?golang_test:1} +function gotest { %{golang_test} "$@"; } +%else +function gotest { go test "$@"; } +%endif +%endif -%files devel -%doc LICENSE README.md -# once src/gopkg.in gets into golang package, remove the line bellow -%{gopath}/src/%{import_path} -%dir %{gopath}/src/launchpad.net -%{gopath}/src/%{import_path_sec} -%dir %{gopath}/src/github.com/motain -%{gopath}/src/github.com/motain/gocheck +export GOPATH=%{buildroot}/%{gopath}:%{gopath} +gotest %{import_path} +%endif + +%if 0%{?with_devel} +%files devel -f devel.file-list +%copying LICENSE +%doc README.md +%dir %{gopath}/src/%{import_path} +%dir %{gopath}/src/%{import_path_sec} +%dir %{gopath}/src/%{mimport_path} +%endif + +%if 0%{?with_unit_test} +%files unit-test -f unit-test.file-list +%copying LICENSE +%doc README.md +%endif %changelog +* Wed Jul 29 2015 jchaloup - 0-6 +- Update of spec file to spec-2.0 + resolves: #1248138 + * Wed Jun 17 2015 Fedora Release Engineering - 0-5 - Rebuilt for https://fedoraproject.org/wiki/Fedora_23_Mass_Rebuild