See
<
https://jenkins.ovirt.org/job/system-sync_mirrors-centos-qemu-ev-testing-...
Changes:
[Evgeny Slutsky] Add eslutsky(a)redhat.com to jenkins Recipient lists.
------------------------------------------
[...truncated 1.84 KB...]
+
REPOQUERY_HTTP_BASE=http://mirrors.phx.ovirt.org/repos/yum/
+ MAX_LOCK_ATTEMPTS=120
+ LOCK_WAIT_INTERVAL=5
+ LOCK_BASE=/home/jenkins
+ OLD_MD_TO_KEEP=100
+ MAX_AGE=14
+ HTTP_SELINUX_TYPE=httpd_sys_content_t
+ HTTP_FILE_MODE=644
+ main resync_yum_mirror centos-qemu-ev-testing-el7 x86_64
jenkins/data/mirrors-reposync.conf
+ local command=resync_yum_mirror
+ command_args=("${@:2}")
+ local command_args
+ cmd_resync_yum_mirror centos-qemu-ev-testing-el7 x86_64
jenkins/data/mirrors-reposync.conf
+ local repo_name=centos-qemu-ev-testing-el7
+ local repo_archs=x86_64
+ local reposync_conf=jenkins/data/mirrors-reposync.conf
+ local sync_needed
+ mkdir -p /home/jenkins/mirrors_cache
+ verify_repo_fs centos-qemu-ev-testing-el7 yum
+ local repo_name=centos-qemu-ev-testing-el7
+ local repo_type=yum
+ sudo install -o jenkins -d /var/www/html/repos/yum
/var/www/html/repos/yum/centos-qemu-ev-testing-el7
/var/www/html/repos/yum/centos-qemu-ev-testing-el7/base
+ check_yum_sync_needed centos-qemu-ev-testing-el7 x86_64
jenkins/data/mirrors-reposync.conf sync_needed
+ local repo_name=centos-qemu-ev-testing-el7
+ local repo_archs=x86_64
+ local reposync_conf=jenkins/data/mirrors-reposync.conf
+ local p_sync_needed=sync_needed
+ local reposync_out
+ echo 'Checking if mirror needs a resync'
Checking if mirror needs a resync
+ rm -rf /home/jenkins/mirrors_cache/centos-qemu-ev-testing-el7
++ IFS=,
++ echo x86_64
+ for arch in '$(IFS=,; echo $repo_archs)'
++ run_reposync centos-qemu-ev-testing-el7 x86_64 jenkins/data/mirrors-reposync.conf
--urls --quiet
++ local repo_name=centos-qemu-ev-testing-el7
++ local repo_arch=x86_64
++ local reposync_conf=jenkins/data/mirrors-reposync.conf
++ extra_args=("${@:4}")
++ local extra_args
++ reposync --config=jenkins/data/mirrors-reposync.conf
--repoid=centos-qemu-ev-testing-el7 --arch=x86_64 --cachedir=/home/jenkins/mirrors_cache
--download_path=/var/www/html/repos/yum/centos-qemu-ev-testing-el7/base --norepopath
--newest-only --urls --quiet
+
reposync_out='https://buildlogs.centos.org/centos/7/virt/x86_64/kvm-c...
https://buildlogs.centos.org/centos/7/virt/x86_64/kvm-common/Packages/q/q...
+ [[ -n
https://buildlogs.centos.org/centos/7/virt/x86_64/kvm-common/Packages/l/l...
https://buildlogs.centos.org/centos/7/virt/x86_64/kvm-common/Packages/q/q...
]]
+ eval sync_needed=true
++ sync_needed=true
+ return
+ [[ -n true ]]
+ mirror_cleanup centos-qemu-ev-testing-el7
+ local repo=centos-qemu-ev-testing-el7
+ local pkgs_file=referenced_pkgs.txt
++ find_recent_snapshots /var/www/html/repos/yum/centos-qemu-ev-testing-el7
++ local repo=/var/www/html/repos/yum/centos-qemu-ev-testing-el7
+++ find /var/www/html/repos/yum/centos-qemu-ev-testing-el7 -mindepth 1 -maxdepth 1 -type
d -mtime -14 '!' '(' -name base -o -name '.*' ')'
++ local fresh_snapshots=
++ [[ -z '' ]]
++ all_snapshots=($(find ${repo} -mindepth 1 -maxdepth 1 -type d ! \( -name
"base" -o -name ".*" \)))
+++ find /var/www/html/repos/yum/centos-qemu-ev-testing-el7 -mindepth 1 -maxdepth 1 -type
d '!' '(' -name base -o -name '.*' ')'
++ local all_snapshots
++ IFS='
'
++ sorted=($(sort <<<"${all_snapshots[*]}"))
+++ sort
++ unset IFS
++ fresh_snapshots=/var/www/html/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09
++ echo /var/www/html/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09
+ recent_snapshots=/var/www/html/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09
++ get_repo_slaves_snapshots centos-qemu-ev-testing-el7
++ local repo_name=centos-qemu-ev-testing-el7
+++ git --git-dir=jenkins/.git --work-tree=jenkins/ grep
http://mirrors.phx.ovirt.org/repos/yum/
++ git_grep_output='data/slave-repos/centos7.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/centos-base-el7/2019-09-17-13-16
data/slave-repos/centos7.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/centos-updates-el7/2020-02-06-00-45
data/slave-repos/centos7.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/centos-extras-el7/2020-01-29-02-32
data/slave-repos/centos7.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/epel-el7/2020-02-08-04-48
data/slave-repos/centos7.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/centos-qemu-ev-release-el7/2019-11...
data/slave-repos/fedora26.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/fedora-base-fc26/2017-10-09-15-06
data/slave-repos/fedora26.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/fedora-updates-fc26/2018-01-18-09-56
data/slave-repos/fedora28.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/fedora-base-fc28/2018-05-14-05-03
data/slave-repos/fedora28.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/fedora-updates-fc28/2019-03-12-04-20
data/slave-repos/fedora28.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/mock-copr-fc28/2019-05-14-06-55
data/slave-repos/fedora29.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/fedora-base-fc29/2020-03-07-12-32
data/slave-repos/fedora29.conf:baseurl =
http://mirrors.phx.ovirt.org/repos/yum/fedora-updates-fc29/2019-11-24-09-51
playbooks/roles/jenkins_master_config/templates/stdci_global_vars.yaml.j2: value:
"http://mirrors.phx.ovirt.org/repos/yum/all_latest.json"
stdci_libs/mirror_client.py:
url='\''http://mirrors.phx.ovirt.org/repos/yum/all_latest.jso...
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/centos7.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/centos-base-el7/2019-09-17-13-16 ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/centos7.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/centos-updates-el7/2020-02-06-00-45 ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/centos7.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/centos-extras-el7/2020-01-29-02-32 ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/centos7.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/epel-el7/2020-02-08-04-48 ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/centos7.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/centos-qemu-ev-release-el7/2019-11...
== *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/fedora26.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/fedora-base-fc26/2017-10-09-15-06 ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/fedora26.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/fedora-updates-fc26/2018-01-18-09-56 ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/fedora28.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/fedora-base-fc28/2018-05-14-05-03 ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/fedora28.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/fedora-updates-fc28/2019-03-12-04-20 ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/fedora28.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/mock-copr-fc28/2019-05-14-06-55 ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/fedora29.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/fedora-base-fc29/2020-03-07-12-32 ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ data/slave-repos/fedora29.conf:baseurl ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ = == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
http://mirrors.phx.ovirt.org/repos/yum/fedora-updates-fc29/2019-11-24-09-51 ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ playbooks/roles/jenkins_master_config/templates/stdci_global_vars.yaml.j2: ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ value: == *\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ "http://mirrors.phx.ovirt.org/repos/yum/all_latest.json" ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[ stdci_libs/mirror_client.py: ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ for line in '${git_grep_output}'
++ [[
url='http://mirrors.phx.ovirt.org/repos/yum/all_latest.json';, ==
*\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7* ]]
++ echo '
'
+ hardcoded_snapshot=
+ [[ ! /var/www/html/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09 == ** ]]
+ '[' -z /var/www/html/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09
']'
+ find_referenced_pkgs /var/www/html/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09
referenced_pkgs.txt
+ local
recent_snapshots_list=/var/www/html/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09
+ local ref_pkgs=referenced_pkgs.txt
+ local repoquery_result=repoquery_result.txt
+ local exists=1
+ for snapshot in '${recent_snapshots_list}'
+ local snapshot_suffix=centos-qemu-ev-testing-el7/2019-11-13-18-09
+ local 'repoquery_cmd=repoquery
--repofrompath=this,http://mirrors.phx.ovirt.org/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09
--repoid=this -a --qf %{relativepath}
--archlist=s390x,s390,ppc64le,ppc64,x86_64,i686,noarch'
+ repoquery
--repofrompath=this,http://mirrors.phx.ovirt.org/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09
--repoid=this -a --qf '%{relativepath}'
--archlist=s390x,s390,ppc64le,ppc64,x86_64,i686,noarch
+ cat repoquery_result.txt
+ sort -u
+ xargs -n1
+ rm repoquery_result.txt
+ rm_unreferenced_pkgs /var/www/html/repos/yum/centos-qemu-ev-testing-el7
referenced_pkgs.txt
+ local repo_dir=/var/www/html/repos/yum/centos-qemu-ev-testing-el7
+ local rpms_file=referenced_pkgs.txt
+ local all_rpms_file=all_pkgs.txt
+ local for_removal=pkgs_for_removal.txt
+ find /var/www/html/repos/yum/centos-qemu-ev-testing-el7/base -name '*.rpm'
+ grep -F -w -v -f /dev/fd/63 /dev/fd/62
++ cat referenced_pkgs.txt
++ cat all_pkgs.txt
+ cat pkgs_for_removal.txt
+ xargs rm
+ rm all_pkgs.txt pkgs_for_removal.txt
+ rm_old_snapshots /var/www/html/repos/yum/centos-qemu-ev-testing-el7
/var/www/html/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09
+ local repo_dir=/var/www/html/repos/yum/centos-qemu-ev-testing-el7
+ local
p_recent_snapshots=/var/www/html/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09
+ all_snapshots=($(find ${repo_dir} -mindepth 1 -maxdepth 1 -type d ! \( -name
"base" -o -name ".*" \)))
++ find /var/www/html/repos/yum/centos-qemu-ev-testing-el7 -mindepth 1 -maxdepth 1 -type d
'!' '(' -name base -o -name '.*' ')'
+ local all_snapshots
+ for snapshot in '"${all_snapshots[@]}"'
+ [[ ! /var/www/html/repos/yum/centos-qemu-ev-testing-el7/2019-11-13-18-09 ==
*\/\v\a\r\/\w\w\w\/\h\t\m\l\/\r\e\p\o\s\/\y\u\m\/\c\e\n\t\o\s\-\q\e\m\u\-\e\v\-\t\e\s\t\i\n\g\-\e\l\7\/\2\0\1\9\-\1\1\-\1\3\-\1\8\-\0\9*
]]
+ rm referenced_pkgs.txt
+ install_repo_pubkey centos-qemu-ev-testing-el7 jenkins/data/mirrors-reposync.conf
+ local repo_name=centos-qemu-ev-testing-el7
+ local reposync_conf=jenkins/data/mirrors-reposync.conf
+ local gpg_key_file
++ sed -nr -e '/\[centos-qemu-ev-testing-el7]/{
:loop;
s#^gpgkey\s*=\s*file://(.*)$#\1#p;
n;
/^\[.*\]$/q ;
b loop
}' jenkins/data/mirrors-reposync.conf
+ gpg_key_file=
+ [[ -n '' ]]
+ echo 'Resyncing repo: centos-qemu-ev-testing-el7'
Resyncing repo: centos-qemu-ev-testing-el7
+ perform_yum_sync centos-qemu-ev-testing-el7 x86_64 jenkins/data/mirrors-reposync.conf
+ local repo_name=centos-qemu-ev-testing-el7
+ local repo_archs=x86_64
+ local reposync_conf=jenkins/data/mirrors-reposync.conf
+ local repo_mp
+ local repo_comps
+ repo_mp=/var/www/html/repos/yum/centos-qemu-ev-testing-el7/base
++ IFS=,
++ echo x86_64
+ for arch in '$(IFS=,; echo $repo_archs)'
+ echo 'Syncing yum repo centos-qemu-ev-testing-el7 for arch: x86_64'
Syncing yum repo centos-qemu-ev-testing-el7 for arch: x86_64
+ run_reposync centos-qemu-ev-testing-el7 x86_64 jenkins/data/mirrors-reposync.conf
--downloadcomps --gpgcheck --download-metadata
+ local repo_name=centos-qemu-ev-testing-el7
+ local repo_arch=x86_64
+ local reposync_conf=jenkins/data/mirrors-reposync.conf
+ extra_args=("${@:4}")
+ local extra_args
+ reposync --config=jenkins/data/mirrors-reposync.conf --repoid=centos-qemu-ev-testing-el7
--arch=x86_64 --cachedir=/home/jenkins/mirrors_cache
--download_path=/var/www/html/repos/yum/centos-qemu-ev-testing-el7/base --norepopath
--newest-only --downloadcomps --gpgcheck --download-metadata
(2/6): qemu-img-ev-2.12.0- 0% [ ] 0.0 B/s | 0 B --:-- ETA (1/6):
qemu-img-ev-2.12.0-44.1.el7_8.1.x86_64.rpm | 1.4 MB 00:00
(2/6): qemu-kvm-common-ev-2.12.0-44.1.el7_8.1.x86_64.rpm | 1.2 MB 00:00
libcacard-debuginfo-2.5.2-2.1. FAILED
(4/6): qemu-kvm-ev-2.12.0- 0% [ ] 0.0 B/s | 0 B --:-- ETA (3/6):
qemu-kvm-ev-2.12.0-44.1.el7_8.1.x86_64.rpm | 3.6 MB 00:00
qemu-kvm-ev-debuginfo-2.12.0-4 FAILED
(4/6): qemu-kvm-ev-debugin 0% [ ] 0.0 B/s | 0 B --:-- ETA (4/6):
qemu-kvm-tools-ev-2.12.0-44.1.el7_8.1.x86_64.rpm | 557 kB 00:00
10:qemu-kvm-ev-debuginfo-2.12.0-44.1.el7_8.1.x86_64: [Errno 256] No more mirrors to try.
40:libcacard-debuginfo-2.5.2-2.1.el7.x86_64: [Errno 256] No more mirrors to try.
Build step 'Execute shell' marked build as failure