00:00:00.000 Started by upstream project "autotest-spdk-master-vs-dpdk-v22.11" build number 2380 00:00:00.000 originally caused by: 00:00:00.000 Started by upstream project "nightly-trigger" build number 3645 00:00:00.000 originally caused by: 00:00:00.000 Started by timer 00:00:00.010 Checking out git https://review.spdk.io/gerrit/a/build_pool/jenkins_build_pool into /var/jenkins_home/workspace/check-format-docker-autotest_script/33b20b30f0a51e6b52980845e0f6aa336787973ad45e341fbbf98d1b65b265d4 to read jbp/jenkins/jjb-config/jobs/autotest-downstream/autotest-docker.groovy 00:00:00.011 The recommended git tool is: git 00:00:00.011 using credential 00000000-0000-0000-0000-000000000002 00:00:00.013 > git rev-parse --resolve-git-dir /var/jenkins_home/workspace/check-format-docker-autotest_script/33b20b30f0a51e6b52980845e0f6aa336787973ad45e341fbbf98d1b65b265d4/jbp/.git # timeout=10 00:00:00.029 Fetching changes from the remote Git repository 00:00:00.033 > git config remote.origin.url https://review.spdk.io/gerrit/a/build_pool/jenkins_build_pool # timeout=10 00:00:00.055 Using shallow fetch with depth 1 00:00:00.055 Fetching upstream changes from https://review.spdk.io/gerrit/a/build_pool/jenkins_build_pool 00:00:00.055 > git --version # timeout=10 00:00:00.076 > git --version # 'git version 2.39.2' 00:00:00.076 using GIT_ASKPASS to set credentials SPDKCI HTTPS Credentials 00:00:00.108 Setting http proxy: proxy-dmz.intel.com:911 00:00:00.108 > git fetch --tags --force --progress --depth=1 -- https://review.spdk.io/gerrit/a/build_pool/jenkins_build_pool refs/heads/master # timeout=5 00:00:02.251 > git rev-parse origin/FETCH_HEAD^{commit} # timeout=10 00:00:02.264 > git rev-parse FETCH_HEAD^{commit} # timeout=10 00:00:02.322 Checking out Revision db4637e8b949f278f369ec13f70585206ccd9507 (FETCH_HEAD) 00:00:02.322 > git config core.sparsecheckout # timeout=10 00:00:02.339 > git read-tree -mu HEAD # timeout=10 00:00:02.357 > git checkout -f db4637e8b949f278f369ec13f70585206ccd9507 # timeout=5 00:00:02.381 Commit message: "jenkins/jjb-config: Add missing SPDK_TEST_NVME_INTERRUPT flag" 00:00:02.382 > git rev-list --no-walk cfa3b8b20295fad8bbdf1ec61de6f7d828e66f18 # timeout=10 00:00:02.481 [Pipeline] Start of Pipeline 00:00:02.493 [Pipeline] library 00:00:02.495 Loading library shm_lib@master 00:00:02.495 Library shm_lib@master is cached. Copying from home. 00:00:02.508 [Pipeline] retry 00:00:02.510 [Pipeline] { 00:00:02.518 [Pipeline] timeout 00:00:02.519 Timeout set to expire after 10 min without activity 00:00:02.520 [Pipeline] { 00:00:02.533 [Pipeline] node 00:00:05.674 Running on agt-_autotest_36223-16911 in /var/jenkins/workspace/check-format-docker-autotest 00:00:05.676 [Pipeline] { 00:00:05.686 [Pipeline] wrap 00:00:05.693 [Pipeline] { 00:00:05.701 [Pipeline] stage 00:00:05.702 [Pipeline] { (Prologue) 00:00:05.721 [Pipeline] echo 00:00:05.724 Node: agt-_autotest_36223-16911 00:00:05.912 [Pipeline] setCustomBuildProperty 00:00:05.932 [Pipeline] sh 00:00:06.791 + sudo git config --global --replace-all safe.directory '*' 00:00:06.868 [Pipeline] httpRequest 00:00:08.774 [Pipeline] echo 00:00:08.776 Sorcerer 10.211.164.20 is alive 00:00:08.785 [Pipeline] retry 00:00:08.787 [Pipeline] { 00:00:08.801 [Pipeline] httpRequest 00:00:08.806 HttpMethod: GET 00:00:08.807 URL: http://10.211.164.20/packages/jbp_db4637e8b949f278f369ec13f70585206ccd9507.tar.gz 00:00:08.808 Sending request to url: http://10.211.164.20/packages/jbp_db4637e8b949f278f369ec13f70585206ccd9507.tar.gz 00:00:08.836 Response Code: HTTP/1.1 200 OK 00:00:08.836 Success: Status code 200 is in the accepted range: 200,404 00:00:08.837 Saving response body to /var/jenkins/workspace/check-format-docker-autotest/jbp_db4637e8b949f278f369ec13f70585206ccd9507.tar.gz 00:00:30.980 [Pipeline] } 00:00:30.998 [Pipeline] // retry 00:00:31.005 [Pipeline] sh 00:00:31.298 + tar --no-same-owner -xf jbp_db4637e8b949f278f369ec13f70585206ccd9507.tar.gz 00:00:31.311 [Pipeline] httpRequest 00:00:31.748 [Pipeline] echo 00:00:31.750 Sorcerer 10.211.164.20 is alive 00:00:31.758 [Pipeline] retry 00:00:31.760 [Pipeline] { 00:00:31.774 [Pipeline] httpRequest 00:00:31.779 HttpMethod: GET 00:00:31.780 URL: http://10.211.164.20/packages/spdk_d47eb51c960b88a8c704cc184fd594dbc3abad70.tar.gz 00:00:31.782 Sending request to url: http://10.211.164.20/packages/spdk_d47eb51c960b88a8c704cc184fd594dbc3abad70.tar.gz 00:00:31.789 Response Code: HTTP/1.1 200 OK 00:00:31.789 Success: Status code 200 is in the accepted range: 200,404 00:00:31.790 Saving response body to /var/jenkins/workspace/check-format-docker-autotest/spdk_d47eb51c960b88a8c704cc184fd594dbc3abad70.tar.gz 00:01:45.007 [Pipeline] } 00:01:45.026 [Pipeline] // retry 00:01:45.034 [Pipeline] sh 00:01:45.323 + tar --no-same-owner -xf spdk_d47eb51c960b88a8c704cc184fd594dbc3abad70.tar.gz 00:01:48.631 [Pipeline] sh 00:01:48.930 + git -C spdk log --oneline -n5 00:01:48.930 d47eb51c9 bdev: fix a race between reset start and complete 00:01:48.930 83e8405e4 nvmf/fc: Qpair disconnect callback: Serialize FC delete connection & close qpair process 00:01:48.930 0eab4c6fb nvmf/fc: Validate the ctrlr pointer inside nvmf_fc_req_bdev_abort() 00:01:48.930 4bcab9fb9 correct kick for CQ full case 00:01:48.930 8531656d3 test/nvmf: Interrupt test for local pcie nvme device 00:01:48.950 [Pipeline] withCredentials 00:01:48.981 > git --version # timeout=10 00:01:48.996 > git --version # 'git version 2.39.2' 00:01:49.026 Masking supported pattern matches of $GIT_PASSWORD or $GIT_ASKPASS 00:01:49.028 [Pipeline] { 00:01:49.037 [Pipeline] retry 00:01:49.039 [Pipeline] { 00:01:49.055 [Pipeline] sh 00:01:49.596 + git ls-remote http://dpdk.org/git/dpdk-stable v22.11.4 00:01:49.628 [Pipeline] } 00:01:49.645 [Pipeline] // retry 00:01:49.650 [Pipeline] } 00:01:49.669 [Pipeline] // withCredentials 00:01:49.678 [Pipeline] httpRequest 00:01:50.045 [Pipeline] echo 00:01:50.047 Sorcerer 10.211.164.20 is alive 00:01:50.057 [Pipeline] retry 00:01:50.060 [Pipeline] { 00:01:50.074 [Pipeline] httpRequest 00:01:50.080 HttpMethod: GET 00:01:50.081 URL: http://10.211.164.20/packages/dpdk_fee0f13c213d0584f0c42a51d0e0625d99a0b2f1.tar.gz 00:01:50.083 Sending request to url: http://10.211.164.20/packages/dpdk_fee0f13c213d0584f0c42a51d0e0625d99a0b2f1.tar.gz 00:01:50.092 Response Code: HTTP/1.1 200 OK 00:01:50.093 Success: Status code 200 is in the accepted range: 200,404 00:01:50.093 Saving response body to /var/jenkins/workspace/check-format-docker-autotest/dpdk_fee0f13c213d0584f0c42a51d0e0625d99a0b2f1.tar.gz 00:02:01.872 [Pipeline] } 00:02:01.892 [Pipeline] // retry 00:02:01.899 [Pipeline] sh 00:02:02.186 + tar --no-same-owner -xf dpdk_fee0f13c213d0584f0c42a51d0e0625d99a0b2f1.tar.gz 00:02:04.107 [Pipeline] sh 00:02:04.402 + git -C dpdk log --oneline -n5 00:02:04.403 caf0f5d395 version: 22.11.4 00:02:04.403 7d6f1cc05f Revert "net/iavf: fix abnormal disable HW interrupt" 00:02:04.403 dc9c799c7d vhost: fix missing spinlock unlock 00:02:04.403 4307659a90 net/mlx5: fix LACP redirection in Rx domain 00:02:04.403 6ef77f2a5e net/gve: fix RX buffer size alignment 00:02:04.424 [Pipeline] writeFile 00:02:04.442 [Pipeline] sh 00:02:04.732 + cat autorun-spdk.conf 00:02:04.732 : 00:02:04.732 00:02:04.732 RUN_NIGHTLY=1 00:02:04.732 SPDK_TEST_NATIVE_DPDK=v22.11.4 00:02:04.739 SPDK_RUN_EXTERNAL_DPDK=/var/jenkins/workspace/check-format-docker-autotest/dpdk/build 00:02:04.741 [Pipeline] } 00:02:04.755 [Pipeline] // stage 00:02:04.766 [Pipeline] catchError 00:02:04.768 [Pipeline] { 00:02:04.784 [Pipeline] timeout 00:02:04.785 Timeout set to expire in 5 min 0 sec 00:02:04.787 [Pipeline] { 00:02:04.800 [Pipeline] stage 00:02:04.802 [Pipeline] { (Tests) 00:02:04.817 [Pipeline] sh 00:02:05.106 + jbp/jenkins/jjb-config/jobs/scripts/docker-autoruner.sh check-format-docker-autotest autorun-spdk.conf 00:02:05.106 08:23:26 -- common/autotest_common.sh@1692 -- # [[ n == y ]] 00:02:05.106 08:23:26 -- common/autobuild_common.sh@15 -- # source /var/jenkins/workspace/check-format-docker-autotest/spdk/scripts/common.sh 00:02:05.106 08:23:26 -- scripts/common.sh@15 -- # shopt -s extglob 00:02:05.106 08:23:26 -- scripts/common.sh@544 -- # [[ -e /bin/wpdk_common.sh ]] 00:02:05.106 08:23:26 -- scripts/common.sh@552 -- # [[ -e /etc/opt/spdk-pkgdep/paths/export.sh ]] 00:02:05.106 08:23:26 -- scripts/common.sh@553 -- # source /etc/opt/spdk-pkgdep/paths/export.sh 00:02:05.106 08:23:26 -- paths/export.sh@2 -- # PATH=/opt/golangci/1.54.2/bin:/opt/protoc/21.7/bin:/opt/go/1.21.1/bin:/opt/golangci/1.54.2/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin 00:02:05.106 08:23:26 -- paths/export.sh@3 -- # PATH=/opt/go/1.21.1/bin:/opt/golangci/1.54.2/bin:/opt/protoc/21.7/bin:/opt/go/1.21.1/bin:/opt/golangci/1.54.2/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin 00:02:05.106 08:23:26 -- paths/export.sh@4 -- # PATH=/opt/protoc/21.7/bin:/opt/go/1.21.1/bin:/opt/golangci/1.54.2/bin:/opt/protoc/21.7/bin:/opt/go/1.21.1/bin:/opt/golangci/1.54.2/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin 00:02:05.106 08:23:26 -- paths/export.sh@5 -- # export PATH 00:02:05.106 08:23:26 -- paths/export.sh@6 -- # echo /opt/protoc/21.7/bin:/opt/go/1.21.1/bin:/opt/golangci/1.54.2/bin:/opt/protoc/21.7/bin:/opt/go/1.21.1/bin:/opt/golangci/1.54.2/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin 00:02:05.106 08:23:26 -- common/autobuild_common.sh@485 -- # out=/var/jenkins/workspace/check-format-docker-autotest/spdk/../output 00:02:05.106 08:23:26 -- common/autobuild_common.sh@486 -- # date +%s 00:02:05.106 08:23:26 -- common/autobuild_common.sh@486 -- # mktemp -dt spdk_1732004606.XXXXXX 00:02:05.106 08:23:26 -- common/autobuild_common.sh@486 -- # SPDK_WORKSPACE=/tmp/spdk_1732004606.ZNWLdW 00:02:05.106 08:23:26 -- common/autobuild_common.sh@488 -- # [[ -n '' ]] 00:02:05.106 08:23:26 -- common/autobuild_common.sh@492 -- # '[' -n v22.11.4 ']' 00:02:05.106 08:23:26 -- common/autobuild_common.sh@493 -- # dirname /var/jenkins/workspace/check-format-docker-autotest/dpdk/build 00:02:05.106 08:23:26 -- common/autobuild_common.sh@493 -- # scanbuild_exclude=' --exclude /var/jenkins/workspace/check-format-docker-autotest/dpdk' 00:02:05.106 08:23:26 -- common/autobuild_common.sh@499 -- # scanbuild_exclude+=' --exclude /var/jenkins/workspace/check-format-docker-autotest/spdk/xnvme --exclude /tmp' 00:02:05.106 08:23:26 -- common/autobuild_common.sh@501 -- # scanbuild='scan-build -o /var/jenkins/workspace/check-format-docker-autotest/spdk/../output/scan-build-tmp --exclude /var/jenkins/workspace/check-format-docker-autotest/dpdk --exclude /var/jenkins/workspace/check-format-docker-autotest/spdk/xnvme --exclude /tmp --status-bugs' 00:02:05.106 08:23:26 -- common/autobuild_common.sh@502 -- # get_config_params 00:02:05.106 08:23:26 -- common/autotest_common.sh@409 -- # xtrace_disable 00:02:05.106 08:23:26 -- common/autotest_common.sh@10 -- # set +x 00:02:05.106 08:23:26 -- common/autobuild_common.sh@502 -- # config_params='--enable-debug --enable-werror --with-rdma --with-idxd --with-fio=/usr/src/fio --with-iscsi-initiator --disable-unit-tests --enable-coverage --with-ublk --with-dpdk=/var/jenkins/workspace/check-format-docker-autotest/dpdk/build' 00:02:05.106 08:23:26 -- common/autobuild_common.sh@504 -- # start_monitor_resources 00:02:05.106 08:23:26 -- pm/common@17 -- # local monitor 00:02:05.106 08:23:26 -- pm/common@19 -- # for monitor in "${MONITOR_RESOURCES[@]}" 00:02:05.106 08:23:26 -- pm/common@19 -- # for monitor in "${MONITOR_RESOURCES[@]}" 00:02:05.106 08:23:26 -- pm/common@25 -- # sleep 1 00:02:05.106 08:23:26 -- pm/common@21 -- # date +%s 00:02:05.106 08:23:26 -- pm/common@21 -- # date +%s 00:02:05.106 08:23:26 -- pm/common@21 -- # /var/jenkins/workspace/check-format-docker-autotest/spdk/scripts/perf/pm/collect-cpu-load -d /var/jenkins/workspace/check-format-docker-autotest/spdk/../output/power -l -p monitor.docker-autoruner.sh.1732004606 00:02:05.107 08:23:26 -- pm/common@21 -- # /var/jenkins/workspace/check-format-docker-autotest/spdk/scripts/perf/pm/collect-vmstat -d /var/jenkins/workspace/check-format-docker-autotest/spdk/../output/power -l -p monitor.docker-autoruner.sh.1732004606 00:02:05.107 Redirecting to /var/jenkins/workspace/check-format-docker-autotest/spdk/../output/power/monitor.docker-autoruner.sh.1732004606_collect-cpu-load.pm.log 00:02:05.107 Redirecting to /var/jenkins/workspace/check-format-docker-autotest/spdk/../output/power/monitor.docker-autoruner.sh.1732004606_collect-vmstat.pm.log 00:02:06.043 08:23:27 -- common/autobuild_common.sh@505 -- # trap stop_monitor_resources EXIT 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@11 -- # cd /var/jenkins/workspace/check-format-docker-autotest/spdk 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@13 -- # cp /var/spdk/build-repo-manifest.txt /var/jenkins/workspace/check-format-docker-autotest/output 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@21 -- # [[ check-format-docker-autotest == unittest-valgrind-docker-autotest ]] 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@26 -- # cpus_limit=26 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@27 -- # nproc 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@27 -- # nproc 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@27 -- # export 'MAKEFLAGS=-j 26' 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@27 -- # MAKEFLAGS='-j 26' 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@29 -- # [[ -n v22.11.4 ]] 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@33 -- # case "$job_name" in 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@39 -- # case "$job_name" in 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@45 -- # CHECK_FORMAT_ONLY_DIFF=yes 00:02:06.043 08:23:27 -- scripts/docker-autoruner.sh@45 -- # check_format 00:02:06.043 08:23:27 -- common/autobuild_common.sh@361 -- # run_test autobuild_check_format /var/jenkins/workspace/check-format-docker-autotest/spdk/scripts/check_format.sh 00:02:06.043 08:23:27 -- common/autotest_common.sh@1105 -- # '[' 2 -le 1 ']' 00:02:06.043 08:23:27 -- common/autotest_common.sh@1111 -- # xtrace_disable 00:02:06.043 08:23:27 -- common/autotest_common.sh@10 -- # set +x 00:02:06.043 ************************************ 00:02:06.043 START TEST autobuild_check_format 00:02:06.043 ************************************ 00:02:06.043 08:23:27 autobuild_check_format -- common/autotest_common.sh@1129 -- # /var/jenkins/workspace/check-format-docker-autotest/spdk/scripts/check_format.sh 00:02:07.418 Checking file permissions... OK 00:02:07.418 Checking coding style... OK 00:02:07.677 Checking comment style... OK 00:02:09.051 Checking markdown files format... OK 00:02:09.051 Checking for spaces before tabs... OK 00:02:09.051 Checking trailing whitespace in output strings... OK 00:02:09.051 Checking for use of forbidden library functions... OK 00:02:09.051 Checking for use of forbidden CUnit macros... OK 00:02:09.982 Checking blank lines at end of file... OK 00:02:10.546 Checking for POSIX includes... OK 00:02:10.803 Checking for proper function naming conventions... OK 00:02:10.803 Checking #include style... OK 00:02:11.369 Checking Python style... OK 00:02:11.628 Checking whether CHANGELOG.md should be updated... 00:02:11.628 include/spdk/bdev_module.h was modified. Consider updating CHANGELOG.md. 00:02:12.193 Checking that all RPCs are documented... OK 00:02:12.193 Checking rpc.py argument option names... OK 00:02:12.193 Checking SPDX-license...OK 00:02:24.384 Checking Golang style...OK 00:02:24.384 Checking extern "C"... OK 00:02:24.384 00:02:24.384 real 0m16.408s 00:02:24.384 user 1m20.618s 00:02:24.384 sys 0m33.833s 00:02:24.384 08:23:44 autobuild_check_format -- common/autotest_common.sh@1130 -- # xtrace_disable 00:02:24.384 08:23:44 autobuild_check_format -- common/autotest_common.sh@10 -- # set +x 00:02:24.384 ************************************ 00:02:24.384 END TEST autobuild_check_format 00:02:24.384 ************************************ 00:02:24.384 08:23:44 -- scripts/docker-autoruner.sh@78 -- # timing_finish 00:02:24.384 08:23:44 -- common/autotest_common.sh@738 -- # [[ -e /var/jenkins/workspace/check-format-docker-autotest/spdk/../output/timing.txt ]] 00:02:24.384 08:23:44 -- common/autotest_common.sh@740 -- # flamegraph=/usr/local/FlameGraph/flamegraph.pl 00:02:24.384 08:23:44 -- common/autotest_common.sh@741 -- # [[ -x /usr/local/FlameGraph/flamegraph.pl ]] 00:02:24.384 08:23:44 -- common/autotest_common.sh@744 -- # /usr/local/FlameGraph/flamegraph.pl --title 'Build Timing' --nametype Step: --countname seconds /var/jenkins/workspace/check-format-docker-autotest/spdk/../output/timing.txt 00:02:24.384 08:23:44 -- scripts/docker-autoruner.sh@1 -- # stop_monitor_resources 00:02:24.384 08:23:44 -- pm/common@29 -- # signal_monitor_resources TERM 00:02:24.384 08:23:44 -- pm/common@40 -- # local monitor pid pids signal=TERM 00:02:24.384 08:23:44 -- pm/common@42 -- # for monitor in "${MONITOR_RESOURCES[@]}" 00:02:24.385 08:23:44 -- pm/common@43 -- # [[ -e /var/jenkins/workspace/check-format-docker-autotest/spdk/../output/power/collect-cpu-load.pid ]] 00:02:24.385 08:23:44 -- pm/common@44 -- # pid=241 00:02:24.385 08:23:44 -- pm/common@50 -- # kill -TERM 241 00:02:24.385 08:23:44 -- pm/common@42 -- # for monitor in "${MONITOR_RESOURCES[@]}" 00:02:24.385 08:23:44 -- pm/common@43 -- # [[ -e /var/jenkins/workspace/check-format-docker-autotest/spdk/../output/power/collect-vmstat.pid ]] 00:02:24.385 08:23:44 -- pm/common@44 -- # pid=242 00:02:24.385 08:23:44 -- pm/common@50 -- # kill -TERM 242 00:02:24.394 [Pipeline] } 00:02:24.410 [Pipeline] // stage 00:02:24.416 [Pipeline] } 00:02:24.432 [Pipeline] // timeout 00:02:24.437 [Pipeline] } 00:02:24.454 [Pipeline] // catchError 00:02:24.464 [Pipeline] stage 00:02:24.467 [Pipeline] { (Epilogue) 00:02:24.482 [Pipeline] sh 00:02:24.783 [Pipeline] setCustomBuildProperty 00:02:24.793 [Pipeline] catchError 00:02:24.795 [Pipeline] { 00:02:24.808 [Pipeline] sh 00:02:25.095 + jbp/jenkins/jjb-config/jobs/scripts/check_artifacts_size.sh 00:02:25.095 Artifacts sizes are good 00:02:25.102 [Pipeline] } 00:02:25.117 [Pipeline] // catchError 00:02:25.125 [Pipeline] sh 00:02:25.413 + jbp/jenkins/jjb-config/jobs/scripts/compress_artifacts.sh 00:02:25.429 [Pipeline] archiveArtifacts 00:02:25.437 Archiving artifacts 00:02:25.704 [Pipeline] } 00:02:25.719 [Pipeline] // stage 00:02:25.722 [Pipeline] } 00:02:25.734 [Pipeline] // wrap 00:02:25.738 [Pipeline] } 00:02:25.752 [Pipeline] // node 00:02:25.756 [Pipeline] } 00:02:25.766 [Pipeline] // timeout 00:02:25.771 [Pipeline] } 00:02:25.781 [Pipeline] // retry 00:02:25.786 [Pipeline] End of Pipeline 00:02:25.825 Finished: SUCCESS