Hello community, here is the log from the commit of package translate-toolkit for openSUSE:Factory checked in at 2020-05-20 18:37:43 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Comparing /work/SRC/openSUSE:Factory/translate-toolkit (Old) and /work/SRC/openSUSE:Factory/.translate-toolkit.new.2738 (New) ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "translate-toolkit" Wed May 20 18:37:43 2020 rev:38 rq:807150 version:2.5.0 Changes: -------- --- /work/SRC/openSUSE:Factory/translate-toolkit/translate-toolkit.changes 2020-03-25 23:42:04.479969624 +0100 +++ /work/SRC/openSUSE:Factory/.translate-toolkit.new.2738/translate-toolkit.changes 2020-05-20 18:37:46.776270599 +0200 @@ -1,0 +2,13 @@ +Wed May 13 07:38:17 UTC 2020 - Matej Cepl <mc...@suse.com> + +- Clean up, rewrite to single-spec style, and use %pytest macro. +- We have to install, but remove afterwards, when in the test phase. +- Add versioned_executables.patch to use partially installed + versioned executables. + +------------------------------------------------------------------- +Fri May 1 12:33:28 UTC 2020 - Matej Cepl <mc...@suse.com> + +- Swtich to multibuild to separate tests + +------------------------------------------------------------------- New: ---- _multibuild versioned_executables.patch ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Other differences: ------------------ ++++++ translate-toolkit.spec ++++++ --- /var/tmp/diff_new_pack.RHfP6K/_old 2020-05-20 18:37:48.316273826 +0200 +++ /var/tmp/diff_new_pack.RHfP6K/_new 2020-05-20 18:37:48.320273835 +0200 @@ -1,7 +1,7 @@ # # spec file for package translate-toolkit # -# Copyright (c) 2019 SUSE LINUX GmbH, Nuernberg, Germany. +# Copyright (c) 2020 SUSE LLC # # All modifications and additions to the file contributed by third parties # remain the property of their copyright owners, unless otherwise agreed @@ -16,62 +16,88 @@ # -Name: translate-toolkit +%global flavor @BUILD_FLAVOR@%{nil} +%if "%{flavor}" == "test" +%define psuffix -test +%bcond_without test +%else +%define psuffix %{nil} +%bcond_with test +%endif +%define modname translate-toolkit +%define skip_python2 1 +%{?!python_module:%define python_module() python-%{**} python3-%{**}} +%define binaries pocompile build_firefox.sh build_tmdb buildxpi.py csv2po csv2tbx flatxml2po get_moz_enUS.py html2po ical2po idml2po ini2po json2po junitmsgfmt l20n2po moz2po mozlang2po odf2xliff oo2po oo2xliff php2po phppo2pypo po2csv po2flatxml po2html po2ical po2idml po2ini po2json po2l20n po2moz po2mozlang po2oo po2php po2prop po2rc po2resx po2sub po2symb po2tiki po2tmx po2ts po2txt po2web2py po2wordfast po2xliff po2yaml poclean pocommentclean pocompendium poconflicts pocount podebug pofilter pogrep pomerge pomigrate2 popuretext poreencode porestructure posegment posplit poswap pot2po poterminology pretranslate prop2po pydiff pypo2phppo rc2po resx2po sub2po symb2po tbx2po tiki2po tmserver ts2po txt2po web2py2po xliff2odf xliff2oo xliff2po yaml2po +%define manpages pocompile build_firefox.sh csv2po csv2tbx flatxml2po html2po idml2po ini2po json2po junitmsgfmt moz2po mozlang2po odf2xliff oo2po oo2xliff phppo2pypo po2csv po2flatxml po2html po2idml po2ini po2json po2moz po2mozlang po2oo po2prop po2rc po2resx po2sub po2symb po2tiki po2tmx po2ts po2txt po2web2py po2wordfast po2xliff poclean poconflicts podebug pofilter pogrep pomerge porestructure posegment poswap pot2po poterminology pretranslate prop2po pypo2phppo rc2po resx2po sub2po symb2po tbx2po tiki2po translatetoolkit ts2po txt2po web2py2po xliff2odf xliff2oo xliff2po +Name: translate-toolkit%{psuffix} Version: 2.5.0 Release: 0 Summary: Tools and API to assist with translation and software localization License: GPL-2.0-or-later Group: Development/Tools/Other -URL: http://toolkit.translatehouse.org/ -Source: https://github.com/translate/translate/releases/download/%{version}/%{name}-%{version}.tar.gz +URL: https://toolkit.translatehouse.org/ +Source: https://github.com/translate/translate/releases/download/%{version}/%{modname}-%{version}.tar.gz # Repacked https://github.com/translate/sphinx-themes ; no commits since 2013 # Often not included in the release tag so just ship it Source1: sphinx-themes.tar.xz Patch0: sphinx-intersphinx.patch Patch2: xliff-xsd-no-network.patch Patch3: test-mo-endian.patch +# PATCH-FIX-UPSTREAM versioned_executables.patch mc...@suse.com +# Use versioned partially installed executables +Patch4: versioned_executables.patch +BuildRequires: %{python_module Levenshtein >= 0.12} +BuildRequires: %{python_module Sphinx} +BuildRequires: %{python_module iniparse} +BuildRequires: %{python_module l20n} +BuildRequires: %{python_module lxml >= 3.5.0} +BuildRequires: %{python_module setuptools} +BuildRequires: %{python_module six >= 1.11.0} +BuildRequires: %{python_module vobject} +BuildRequires: dos2unix BuildRequires: fdupes BuildRequires: gettext-runtime BuildRequires: git-core BuildRequires: iso-codes -BuildRequires: python3-Babel -BuildRequires: python3-Levenshtein -BuildRequires: python3-Sphinx -BuildRequires: python3-beautifulsoup4 -BuildRequires: python3-cheroot -BuildRequires: python3-iniparse -BuildRequires: python3-l20n -BuildRequires: python3-lxml >= 3.5.0 -BuildRequires: python3-phply -BuildRequires: python3-pycountry >= 18.12.8 -BuildRequires: python3-pyenchant -BuildRequires: python3-pytest -BuildRequires: python3-ruamel.yaml -BuildRequires: python3-six >= 1.11.0 -BuildRequires: python3-vobject -BuildRequires: python3-xml -BuildRequires: subversion +BuildRequires: python-rpm-macros Requires: gettext-runtime -Requires: python3-lxml -Requires: python3-pycountry >= 18.12.8 -Requires: python3-pyenchant -Requires: python3-setuptools -Requires: python3-six >= 1.11.0 +Requires: python-lxml +Requires: python-pycountry >= 18.12.8 +Requires: python-pyenchant +Requires: python-setuptools +Requires: python-six >= 1.11.0 +Requires(post): update-alternatives +Requires(postun): update-alternatives # The following are for the full experience of translate-toolkit Recommends: gaupol Recommends: iso-codes -Recommends: python3-Levenshtein -Recommends: python3-aeidon -Recommends: python3-chardet -Recommends: python3-cheroot -Recommends: python3-iniparse -Recommends: python3-l20n -Recommends: python3-phply -Recommends: python3-pycountry -Recommends: python3-ruamel.yaml -Recommends: python3-vobject -Provides: python3-translate-toolkit = %{version} +Recommends: python-Levenshtein +Recommends: python-aeidon +Recommends: python-chardet +Recommends: python-cheroot +Recommends: python-iniparse +Recommends: python-l20n +Recommends: python-phply +Recommends: python-pycountry +Recommends: python-ruamel.yaml +Recommends: python-vobject +Provides: translate-toolkit = %{version}-%{release} +Obsoletes: translate-toolkit < %{version}-%{release} BuildArch: noarch +%if %{with test} +BuildRequires: %{python_module Babel} +BuildRequires: %{python_module chardet} +BuildRequires: %{python_module iniparse} +BuildRequires: %{python_module pycountry >= 18.12.8} +BuildRequires: %{python_module pyenchant} +BuildRequires: %{python_module pytest} +BuildRequires: %{python_module xml} +BuildRequires: subversion +%if "%{python_flavor}" == "python2" +BuildRequires: python2-backports.csv +%endif +%endif +%python_subpackages %description The Translate Toolkit is a set of software and documentation designed to help @@ -105,7 +131,7 @@ toolkit or to use the libraries in other localization tools. %prep -%setup -q +%setup -q -n %{modname}-%{version} %autopatch -p1 pushd docs/_themes @@ -119,61 +145,119 @@ sed -i '\|%{_bindir}/env |d' $lib done +find . -name jquery.js -exec dos2unix '{}' \; + %build -python3 setup.py build +%python_build pushd docs # Can't use parallel build here! -make -j1 html man +%make_build -j1 html man #no hidden files find _build -name '.?*' -delete popd %install -python3 setup.py install --prefix=%{_prefix} --root=%{buildroot} +%python_install # create manpages -mkdir -p %{buildroot}/%{_mandir}/man1 -for program in %{buildroot}/%{_bindir}/*; do +mkdir -p %{buildroot}%{_mandir}/man1 +for program in %{buildroot}%{_bindir}/*; do case $(basename $program) in pocompendium|poen|pomigrate2|popuretext|poreencode|posplit|pocount|poglossary|lookupclient.py|tmserver|build_tmdb) ;; *) - LC_ALL=C PYTHONPATH=. $program --manpage \ - > %{buildroot}/%{_mandir}/man1/$(basename $program).1 \ - || rm -f %{buildroot}/%{_mandir}/man1/$(basename $program).1 + MPAGE="%{buildroot}%{_mandir}/man1/$(basename $program).1" + LC_ALL=C PYTHONPATH=. $program --manpage > "$MPAGE" || rm -f "$MPAGE" ;; esac done -install -m 644 docs/_build/man/* %{buildroot}/%{_mandir}/man1/ +install -m 644 docs/_build/man/* %{buildroot}%{_mandir}/man1/ # move documentation files to datadir -install -d -m 755 %{buildroot}%{_defaultdocdir}/%{name} -mv %{buildroot}%{python3_sitelib}/translate/docs/_build/html %{buildroot}%{_defaultdocdir}/%{name} -rm -rf %{buildroot}%{python3_sitelib}/translate/docs -rm -rf %{buildroot}/home/abuild/.local/lib/python%{python3_version}/site-packages/ +%{python_expand install -d -m 755 %{buildroot}%{_defaultdocdir}/%{modname} +mv %{buildroot}%{$python_sitelib}/translate/docs/_build/html %{buildroot}%{_defaultdocdir}/%{modname} +rm -rf %{buildroot}%{$python_sitelib}/translate/docs +rm -rf %{buildroot}home/abuild/.local/lib/python%{$python_version}/site-packages/ +} # create symlinks for man pages -%fdupes -s %{buildroot}/%{_mandir} +%fdupes -s %{buildroot}%{_mandir} # create hardlinks for the rest -%fdupes %{buildroot} +%python_expand %fdupes %{buildroot}%{$python_sitelib} + +# Prepare alternatives +for mpage in %{manpages} ; do +%python_clone -a %{buildroot}%{_mandir}/man1/$mpage.1 +done +for binary in %{binaries} ; do +%python_clone -a %{buildroot}%{_bindir}/$binary +done %check +%if %{with test} +export PYTHONDONTWRITEBYTECODE=1 export PATH=$PATH:%{buildroot}%{_bindir} -PYTHONPATH=%{buildroot}%{python3_sitelib} python3 -m pytest -v -k 'not test_empty_key' - -%files -%{_defaultdocdir}/%{name}/html/ -%exclude %{_defaultdocdir}/%{name}/html/api -%exclude %{_defaultdocdir}/%{name}/html/_sources +%pytest tests +rm -rf %{buildroot} +%endif + +%post +%define my_install_alternatives() %{lua:\ + function file_exists(path) \ + local f = io.open(path) \ + if f == nil then return false \ + else f:close() return true \ + end \ + end \ + local t={} \ + local manpath = "" \ + for str in string.gmatch(rpm.expand("%**"), "([^%s]+)") do \ + table.insert(t, str) \ + end \ + local bindir = rpm.expand("%{_bindir}") \ + local mandir = rpm.expand("%{_mandir}") .. "/man1" \ + local ver_ext = "-" .. t[1] \ + local man_ext = ".1" .. rpm.expand("%{?ext_man}") \ + local man_ext_ver = ver_ext .. man_ext \ + \ + local ua_cmd = "update-alternatives --install " .. mandir .. "/translatetoolkit" .. man_ext .. " translatetoolkit.1 " .. \ + mandir .. "/translatetoolkit" .. man_ext_ver .. " 20 \\\\\\n" \ + local elems = table.pack(table.unpack(t, 2)) \ + for arg, name in ipairs(elems) do \ + ua_cmd = ua_cmd .. " --slave " .. bindir .. "/" .. name .. " " .. name .. " " .. bindir .. "/" .. name .. ver_ext .. " \\\\\\n" \ + manpath = mandir .. "/" .. name .. man_ext_ver \ + if file_exists(manpath) then \ + ua_cmd = ua_cmd .. " --slave " .. mandir .. "/" .. name .. man_ext .. " " .. name .. ".1 " .. manpath .. " \\\\\\n" \ + end \ + end\ + -- we need to remove the last backslash and EOL \ + print(ua_cmd:sub(1, -3)) \ +} +%my_install_alternatives %{_rec_macro_helper}%{lua:expand_macro("version")} %binaries + + +%postun +if [ ! -f %{_mandir}/man1/translatetoolkit-%{_rec_macro_helper}%{lua:expand_macro("version")}.1%{?ext_man} ] ; then + update-alternatives --remove translatetoolkit %{_mandir}/man1/translatetoolkit-%{_rec_macro_helper}%{lua:expand_macro("version")}.1%{?ext_man} +fi + +%if !%{with test} +%files %{python_files} +%dir %{_defaultdocdir}/%{modname} +%{_defaultdocdir}/%{modname}/html/ +%exclude %{_defaultdocdir}/%{modname}/html/api +%exclude %{_defaultdocdir}/%{modname}/html/_sources %license COPYING %doc README.rst +%ghost %{_sysconfdir}/alternatives/* %{_bindir}/* %{_mandir}/man1/* -%{python3_sitelib}/translate -%{python3_sitelib}/translate_toolkit-%{version}-*.egg-info +%{python_sitelib}/translate +%{python_sitelib}/translate_toolkit-%{version}-*.egg-info %files devel-doc -%doc %{_defaultdocdir}/%{name}/html/api -%doc %{_defaultdocdir}/%{name}/html/_sources +%doc %{_defaultdocdir}/%{modname}/html/api +%doc %{_defaultdocdir}/%{modname}/html/_sources +%endif %changelog ++++++ _multibuild ++++++ <multibuild> <package>test</package> </multibuild> ++++++ versioned_executables.patch ++++++ --- a/tests/xliff_conformance/test_xliff_conformance.py +++ b/tests/xliff_conformance/test_xliff_conformance.py @@ -48,7 +48,7 @@ def find_files(base, check_ext): def test_open_office_to_xliff(): - assert call(['oo2xliff', 'en-US.sdf', '-l', 'fr', 'fr']) == 0 + assert call(['oo2xliff-{}'.format('.'.join((str(x) for x in sys.version_info[:2]))), 'en-US.sdf', '-l', 'fr', 'fr']) == 0 for filepath in find_files('fr', '.xlf'): assert xmllint(filepath) cleardir('fr') @@ -56,7 +56,7 @@ def test_open_office_to_xliff(): def test_po_to_xliff(): OUTPUT = 'af-pootle.xlf' - assert call(['po2xliff', 'af-pootle.po', OUTPUT]) == 0 + assert call(['po2xliff-{}'.format('.'.join((str(x) for x in sys.version_info[:2]))), 'af-pootle.po', OUTPUT]) == 0 assert xmllint(OUTPUT)