Console Output
23:34:09 Started by upstream project "Krel_trigger-jobs" build number 47905 23:34:09 originally caused by: 23:34:09 Started by timer 23:34:09 Building remotely on build client 1 (slave buildslave indigo_devel_default) in workspace /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source 23:34:09 [ssh-agent] Looking for ssh-agent implementation... 23:34:09 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 23:34:09 $ ssh-agent 23:34:09 SSH_AUTH_SOCK=/tmp/ssh-vGiSZ0LwPjn6/agent.21520 23:34:09 SSH_AGENT_PID=21522 23:34:09 [ssh-agent] Started. 23:34:09 $ ssh-add /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source@tmp/private_key_599081737383525338.key 23:34:09 Identity added: /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source@tmp/private_key_599081737383525338.key (/home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source@tmp/private_key_599081737383525338.key) 23:34:09 [ssh-agent] Using credentials jenkins-slave23:34:09 [Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source] $ /bin/sh -xe /tmp/hudson3471277857885758813.sh 23:34:09 + echo # BEGIN SECTION: docker version1. Check free disk spaceHide Details
23:34:09 # BEGIN SECTION: Check free disk space 23:34:09 Usable disk space = 54805254144 bytes 23:34:09 Free space threshold = 5368709120 bytes 23:34:09 # END SECTION23:34:09 + echo # BEGIN SECTION: docker info2. docker versionHide Details
23:34:09 # BEGIN SECTION: docker version 23:34:09 + docker version 23:34:09 Client: 23:34:09 Version: 1.9.1 23:34:09 API version: 1.21 23:34:09 Go version: go1.4.2 23:34:09 Git commit: a34a1d5 23:34:09 Built: Fri Nov 20 13:12:04 UTC 2015 23:34:09 OS/Arch: linux/amd64 23:34:09 23:34:09 Server: 23:34:09 Version: 1.9.1 23:34:09 API version: 1.21 23:34:09 Go version: go1.4.2 23:34:09 Git commit: a34a1d5 23:34:09 Built: Fri Nov 20 13:12:04 UTC 2015 23:34:09 OS/Arch: linux/amd64 23:34:09 + echo # END SECTION 23:34:09 # END SECTION23:34:10 [Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source] $ /bin/sh -xe /tmp/hudson2806391627874953311.sh 23:34:10 + echo # BEGIN SECTION: Check docker status3. docker infoHide Details
23:34:09 # BEGIN SECTION: docker info 23:34:09 + docker info 23:34:10 Containers: 363 23:34:10 Images: 2275 23:34:10 Server Version: 1.9.1 23:34:10 Storage Driver: aufs 23:34:10 Root Dir: /var/lib/docker/aufs 23:34:10 Backing Filesystem: extfs 23:34:10 Dirs: 3473 23:34:10 Dirperm1 Supported: false 23:34:10 Execution Driver: native-0.2 23:34:10 Logging Driver: json-file 23:34:10 Kernel Version: 3.13.0-29-generic 23:34:10 Operating System: Ubuntu 14.04 LTS 23:34:10 CPUs: 2 23:34:10 Total Memory: 3.861 GiB 23:34:10 Name: lcas-buildfarm-slave-2 23:34:10 ID: LZSS:PF7G:CREH:TEQW:FH57:3M6D:KCSS:ODQY:SPHA:ND7A:FHYG:PNDE 23:34:10 WARNING: No swap limit support 23:34:10 + echo # END SECTION 23:34:10 # END SECTION23:34:11 [Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source] $ /bin/sh -xe /tmp/hudson1410809491959682653.sh 23:34:11 + echo # BEGIN SECTION: Embed wrapper scripts4. Check docker statusHide Details
23:34:10 # BEGIN SECTION: Check docker status 23:34:10 + echo Testing trivial docker invocation... 23:34:10 Testing trivial docker invocation... 23:34:10 + docker run --rm ubuntu:xenial true 23:34:11 + echo 'docker run' returned 0 23:34:11 'docker run' returned 0 23:34:11 docker seems operational, continuing 23:34:11 [Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source] $ /bin/sh -xe /tmp/hudson7300422665616752509.sh 23:34:11 + echo # END SECTION 23:34:11 # END SECTION23:34:11 [Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source] $ /bin/sh -xe /tmp/hudson871772485352169542.sh 23:34:11 + echo # BEGIN SECTION: Clone ros_buildfarm5. Embed wrapper scriptsHide Details
23:34:11 # BEGIN SECTION: Embed wrapper scripts 23:34:11 + rm -fr wrapper_scripts 23:34:11 + mkdir wrapper_scripts 23:34:11 + printf #!/usr/bin/env python3\n\n# Copyright 2016 Open Source Robotics Foundation, Inc.\n#\n# Licensed under the Apache License, Version 2.0 (the "License");\n# you may not use this file except in compliance with the License.\n# You may obtain a copy of the License at\n#\n# http://www.apache.org/licenses/LICENSE-2.0\n#\n# Unless required by applicable law or agreed to in writing, software\n# distributed under the License is distributed on an "AS IS" BASIS,\n# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n# See the License for the specific language governing permissions and\n# limitations under the License.\n\nimport subprocess\nimport sys\nfrom time import sleep\n\n\ndef main(argv=sys.argv[1:]):\n max_tries = 10\n known_error_strings = [\n 'Connection timed out',\n ]\n\n command = argv[0]\n if command == 'clone':\n rc, _, _ = call_git_repeatedly(\n argv, known_error_strings, max_tries)\n return rc\n else:\n assert "Command '%%s' not implemented" %% command\n\n\ndef call_git_repeatedly(argv, known_error_strings, max_tries):\n command = argv[0]\n for i in range(1, max_tries + 1):\n if i > 1:\n sleep_time = 5 + 2 * i\n print("Reinvoke 'git %%s' (%%d/%%d) after sleeping %%s seconds" %%\n (command, i, max_tries, sleep_time))\n sleep(sleep_time)\n rc, known_error_conditions = call_git(argv, known_error_strings)\n if rc == 0 or not known_error_conditions:\n break\n print('')\n print('Invocation failed due to the following known error conditions: '\n ', '.join(known_error_conditions))\n print('')\n # retry in case of failure with known error condition\n return rc, known_error_conditions, i\n\n\ndef call_git(argv, known_error_strings):\n known_error_conditions = []\n\n cmd = ['git'] + argv\n print("Invoking '%%s'" %% ' '.join(cmd))\n proc = subprocess.Popen(\n cmd, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)\n while True:\n line = proc.stdout.readline()\n if not line:\n break\n line = line.decode()\n sys.stdout.write(line)\n for known_error_string in known_error_strings:\n if known_error_string in line:\n if known_error_string not in known_error_conditions:\n known_error_conditions.append(known_error_string)\n proc.wait()\n rc = proc.returncode\n return rc, known_error_conditions\n\n\nif __name__ == '__main__':\n sys.exit(main()) 23:34:11 + echo # END SECTION 23:34:11 # END SECTION23:34:13 [Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source] $ /bin/sh -xe /tmp/hudson1528520269587054670.sh 23:34:13 + echo # BEGIN SECTION: Write PGP repository keys6. Clone ros_buildfarmHide Details
23:34:11 # BEGIN SECTION: Clone ros_buildfarm 23:34:11 + rm -fr ros_buildfarm 23:34:11 + python3 -u wrapper_scripts/git.py clone --depth 1 -b master https://github.com/lcas/ros_buildfarm.git ros_buildfarm 23:34:11 Invoking 'git clone --depth 1 -b master https://github.com/lcas/ros_buildfarm.git ros_buildfarm' 23:34:11 Cloning into 'ros_buildfarm'... 23:34:13 + git -C ros_buildfarm --no-pager log -n 1 23:34:13 commit aca918fa40d6391d4894b39d8d3477d2e6e0a390 23:34:13 Author: Marc Hanheide <marc@hanheide.de> 23:34:13 Date: Thu Aug 2 12:13:42 2018 +0100 23:34:13 23:34:13 added cleanup 23:34:13 + rm -fr ros_buildfarm/.git 23:34:13 + rm -fr ros_buildfarm/doc 23:34:13 + echo # END SECTION 23:34:13 # END SECTION23:34:13 [Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source] $ /bin/sh -xe /tmp/hudson451734664097818117.sh 23:34:13 + rm -fr /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/docker_sourcedeb 23:34:13 + mkdir -p /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/docker_sourcedeb 23:34:13 + sleep 1 23:34:13 + python3 -u /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/ros_buildfarm/scripts/subprocess_reaper.py 21714 --cid-file /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/docker_sourcedeb/docker.cid 23:34:14 + echo # BEGIN SECTION: Generate Dockerfile - sourcedeb task7. Write PGP repository keysHide Details
23:34:13 # BEGIN SECTION: Write PGP repository keys 23:34:13 + mkdir -p /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/keys 23:34:13 + rm -fr /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/keys/* 23:34:13 + echo -----BEGIN PGP PUBLIC KEY BLOCK----- 23:34:13 Version: GnuPG v1.4.11 (GNU/Linux) 23:34:13 23:34:13 mQENBFPzE4sBCAC9c8hzt+gqe6YqXAW9Yd10jx68M0q8IowAe182yVtIvYf5l+qn 23:34:13 MsXiDUz4l7c1TcRpdzZ1WwEQoNNjQKq51ip2Ln3Uhri/GsPBk+psIJPt5AeXYrSf 23:34:13 xcDs8k4FMWgJtYMlZLuNk1YPaS6Vf1+Ygbe0u+ssORWg3cWhgLWPDydXdlhinUgw 23:34:13 kPd9ZYi8aaAxi94DMuOnAjItfPbuX52NHmPR2cXuh3fZklhA6cCGRYkSVqijKhEv 23:34:13 /o8fTnjcTama8ml5jnaAhcZ/4UV3terLeXEQn3+WM+VbTsEr58zca5fOv8MjC+Uh 23:34:13 EBgDgnHb8/n7OgSUvv9efQgYXBRQ1mD//JaZABEBAAG0LE1hcmMgSGFuaGVpZGUg 23:34:13 KFJPU0J1aWxkKSA8bWFyY0BoYW5oZWlkZS5uZXQ+iQE4BBMBAgAiBQJT8xOLAhsD 23:34:13 BgsJCAcDAgYVCAIJCgsEFgIDAQIeAQIXgAAKCRDc10MYrtOYVB9cCACQwB9auPEX 23:34:13 yQdVwliJMLwVihKz0AU0UCG6qra2pdXx9l5kgkQCuDV5FQqMpk/MIJPn8Zj0l1MI 23:34:13 7Yn/EAqBhXjtO2BcTuUC/9epzt1p3C++vK7RSsBDXfKzZN22apIUT0njOkL9Vuoy 23:34:13 JjFetmLDaZVbmFU+4ZaX3CFtBL3ewlFiT7G6StKj40JI8QJOlDOziX2OUsqZaI2T 23:34:13 Yh681980od3f2OfV3LPVroz7xnyECDfBaPBPaDdb8XWSNVLhuyglb15eewK0hj++ 23:34:13 Cut3swWH02Y3yVhzFBnosqqjyzPLBQeDMOoHAPpJHRgprfIRDoUkWAXO5re3GIUQ 23:34:13 cvk0d1I1jh3luQENBFPzE4sBCACmSxiM1vpPI7BpgUNAhu0B8SWptULpiYOnDHfM 23:34:13 hU1u95Z5Lu/hy3sfm4BEKgLju7Y1I3jToWTwJJzgWZRr+iuuwj3fbfHCISYIK7f3 23:34:13 IWGL2iM2+kLIH6E9oqRgGbJmhiwbz6OokxG0W7atdqpBxOKqhaH0AH3qRicwnuPm 23:34:13 Z4/mNHYQ0vBffENewujn1bCAz4C1WB66/AXBYF8dpCP42qB5yK7FRNv4JubMmqhK 23:34:13 7fkD88uu7JVGRYU+temWuJHH4WDxiCmvK8nXacFaZT1NGdTL9/2EukKLguTtZumb 23:34:13 oRWgFqV6WFcEnh/V/Ma51D2+K9QbCWa8Bb6c/wKOd9Ii1aDZABEBAAGJAR8EGAEC 23:34:13 AAkFAlPzE4sCGwwACgkQ3NdDGK7TmFT2rwf+MzLFPn4Rkko38nctysbXm6qmk34U 23:34:13 NTtqirOlxg3mWeUCp7VQGU2Rg2msdo764SxCK12OhJqlXGMd2efCoQhYbMOqG6C0 23:34:13 ikBZPkd5BVFuTKsAUiuVoiQd8bDaZSpO2QdE0RdHE/yYfO66pceEKkGlcjkTRFFU 23:34:13 M7nTm7IQj4BBZclMLPr4fX520ZOVUepxAARMHW5A6EcHXvhXmblZOJM36fOv3T5N 23:34:13 l9L5tWdt/wybaRE4xuwVSs0n7MyMlWmkQxz8Z6OQscbKmuI4tcYSbvvB5tzjLBwZ 23:34:13 Chb0eEZA5ePvnGofu+3JH48FmCIPveD+4kI9GhtGkCL3Q2PiPiLcSnWQWQ== 23:34:13 =nFcN 23:34:13 -----END PGP PUBLIC KEY BLOCK----- 23:34:13 23:34:13 + echo -----BEGIN PGP PUBLIC KEY BLOCK----- 23:34:13 Version: GnuPG v1 23:34:13 23:34:13 mQGiBEsy5KkRBADJbDSISoamRM5AA20bfAeBuhhaI+VaiCVcxw90sq9AI5lIc42F 23:34:13 WzM2acm8yplqWiehAqOLKd+iIrqNGZ+VavZEPTx7o06UZUMRoPBiTFaCwrQ5avKz 23:34:13 lt7ij8PRMVWNrJ7A2lDYXfFQVV1o3Xo06qVnv0KLLUmiur0LBu4H/oTH3wCgt+/I 23:34:13 D3LUKaMJsc77KwFBTjHB0EsD/26Z2Ud12f3urSNyN6VMWnP3rz6xsmtY4Qsmkbnr 23:34:13 JuduxCQBZv6bX1Cr2ulXkv0fFOr+s5OyUv7zyCPbxiJFh3Br7fJGb0b5/M208KPe 23:34:13 giITY9hMh/aUbKjXCPoOXPxSL6SWOWV8taR6903EFyLBN0qno/kXIBKnVqBZobgn 23:34:13 jIEPA/0fTnxtZtE7EpirGQMF2caJfv7/LCgXmRs9xAhgbE0/caoa1tnc79uaHmLZ 23:34:13 FtbGFoAO31YNYM/IUHtmabbGdvZ4oYUwDhjBevVvC7aI+XhuNGK5mU8qCLLSEUOl 23:34:13 CUr6BJq/0iFmjwjmwk9idZEYhqSNy2OoYJbq45rbHfbdKLEVrbQeUk9TIEJ1aWxk 23:34:13 ZXIgPHJvc2J1aWxkQHJvcy5vcmc+iGAEExECACAFAksy5KkCGwMGCwkIBwMCBBUC 23:34:13 CAMEFgIDAQIeAQIXgAAKCRBVI7rusB+hFmk7AJ0XsLp05KA8l3YzAumZfjSN04MZ 23:34:13 jQCfQHfp4aQUXdOCUtetVo0QZUX3IuO5Ag0ESzLkrhAIAOCuSC83VXYWf8gOMSzd 23:34:13 xwpsH/uLV9Wze2LGnajsJLjEOhcsz2BHfxqNXhYaE9aQaodPCpbUAkPq8tLbpXy0 23:34:13 SWRCx0F5RcplXx5vIWbP6TlfPbRpK70w7IWd6vsNrjwEHjlhOLcNcj42sp5pgx4b 23:34:13 dceK06k5Ml2hYovPnD9o2TYgjOqg5FHZ2g1J0103n/66bN/hZnpLaZJYQiPWCyq6 23:34:13 K0565i1k2Y7hgWB/OXqwaqCehqmLTvpyQGzE1UJvKLuYU+T+4hBnSPbT3KIi5fCz 23:34:13 lIwvxijOMcfbkLhzYQXcU0Rd1VItcd5nmPL4z97jBxzuhkgxXpGR4WGKhvsA2Z9Y 23:34:13 UtsAAwYH/3Bf44bTpD9bVADUdab3e7zm8iHfh9K/a83mIgDB7mHV6WuemQVTf/1d 23:34:13 eu4mI5WtpbOCoucybGfjGIIAcSxwIx6VfC7HSp4J51bOpHhbdDffUEk6QVsZjwoF 23:34:13 yn3W9W3ZVeTI+ch/Qoo5a98SnmdjN8eXI/qCuiXOHc6rXDXc2R0iox/1EAS8xGVd 23:34:13 cYZe7IWBO2CjCknyhLrWxZHoy+i1GCZ9KvPF/Ef2dmLhCydT73ZlumsY8N5vm76Q 23:34:13 ul1G7f8LNbnMgXQafRkPffrAXSVhGY3Z2IiBwFNgxcKTq479l7yedYRGeU1A+SYI 23:34:13 YmRFWHXt3rTkMlQSpxCsB0fAYfrwEqqISQQYEQIACQUCSzLkrgIbDAAKCRBVI7ru 23:34:13 sB+hFpryAJ9qNz3h3ijt9TkAV0CHufsPT6Cl4gCglfg7tJn2lsSF3HTpoDDO1Fgg 23:34:13 x9o= 23:34:13 =AGYp 23:34:13 -----END PGP PUBLIC KEY BLOCK----- 23:34:13 23:34:13 + echo # END SECTION 23:34:13 # END SECTION23:34:14 + echo # BEGIN SECTION: Build Dockerfile - generate sourcedeb8. Generate Dockerfile - sourcedeb taskHide Details
23:34:14 # BEGIN SECTION: Generate Dockerfile - sourcedeb task 23:34:14 + export TZ=GMT+00 23:34:14 + export PYTHONPATH=/home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/ros_buildfarm: 23:34:14 + python3 -u /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/ros_buildfarm/scripts/release/run_sourcedeb_job.py --rosdistro-index-url https://raw.githubusercontent.com/LCAS/rosdistro/master/index.yaml kinetic vrep_ugv_plugin ubuntu xenial --distribution-repository-urls http://10.210.9.154/ubuntu/building http://packages.ros.org/ros/ubuntu --distribution-repository-key-files /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/keys/0.key /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/keys/1.key --source-dir /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/sourcedeb/source --dockerfile-dir /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/docker_sourcedeb 23:34:14 Using the following distribution repositories: 23:34:14 http://10.210.9.154/ubuntu/building (/home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/keys/0.key) 23:34:14 http://packages.ros.org/ros/ubuntu (/home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/keys/1.key) 23:34:14 Generating Dockerfile '/home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/docker_sourcedeb/Dockerfile': 23:34:14 # generated from release/sourcedeb_task.Dockerfile.em 23:34:14 23:34:14 FROM ubuntu:xenial 23:34:14 23:34:14 VOLUME ["/var/cache/apt/archives"] 23:34:14 23:34:14 ENV DEBIAN_FRONTEND noninteractive 23:34:14 23:34:14 RUN for i in 1 2 3; do apt-get update && apt-get install -q -y locales && apt-get clean && break || if [[ $i < 3 ]]; then sleep 5; else false; fi; done 23:34:14 RUN echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen 23:34:14 RUN locale-gen en_US.UTF-8 23:34:14 ENV LANG en_US.UTF-8 23:34:14 ENV TZ GMT+00 23:34:14 23:34:14 RUN useradd -u 1002 -m buildfarm 23:34:14 23:34:14 23:34:14 RUN mkdir /tmp/keys 23:34:14 RUN echo "-----BEGIN PGP PUBLIC KEY BLOCK-----\nVersion: GnuPG v1.4.11 (GNU/Linux)\n\nmQENBFPzE4sBCAC9c8hzt+gqe6YqXAW9Yd10jx68M0q8IowAe182yVtIvYf5l+qn\nMsXiDUz4l7c1TcRpdzZ1WwEQoNNjQKq51ip2Ln3Uhri/GsPBk+psIJPt5AeXYrSf\nxcDs8k4FMWgJtYMlZLuNk1YPaS6Vf1+Ygbe0u+ssORWg3cWhgLWPDydXdlhinUgw\nkPd9ZYi8aaAxi94DMuOnAjItfPbuX52NHmPR2cXuh3fZklhA6cCGRYkSVqijKhEv\n/o8fTnjcTama8ml5jnaAhcZ/4UV3terLeXEQn3+WM+VbTsEr58zca5fOv8MjC+Uh\nEBgDgnHb8/n7OgSUvv9efQgYXBRQ1mD//JaZABEBAAG0LE1hcmMgSGFuaGVpZGUg\nKFJPU0J1aWxkKSA8bWFyY0BoYW5oZWlkZS5uZXQ+iQE4BBMBAgAiBQJT8xOLAhsD\nBgsJCAcDAgYVCAIJCgsEFgIDAQIeAQIXgAAKCRDc10MYrtOYVB9cCACQwB9auPEX\nyQdVwliJMLwVihKz0AU0UCG6qra2pdXx9l5kgkQCuDV5FQqMpk/MIJPn8Zj0l1MI\n7Yn/EAqBhXjtO2BcTuUC/9epzt1p3C++vK7RSsBDXfKzZN22apIUT0njOkL9Vuoy\nJjFetmLDaZVbmFU+4ZaX3CFtBL3ewlFiT7G6StKj40JI8QJOlDOziX2OUsqZaI2T\nYh681980od3f2OfV3LPVroz7xnyECDfBaPBPaDdb8XWSNVLhuyglb15eewK0hj++\nCut3swWH02Y3yVhzFBnosqqjyzPLBQeDMOoHAPpJHRgprfIRDoUkWAXO5re3GIUQ\ncvk0d1I1jh3luQENBFPzE4sBCACmSxiM1vpPI7BpgUNAhu0B8SWptULpiYOnDHfM\nhU1u95Z5Lu/hy3sfm4BEKgLju7Y1I3jToWTwJJzgWZRr+iuuwj3fbfHCISYIK7f3\nIWGL2iM2+kLIH6E9oqRgGbJmhiwbz6OokxG0W7atdqpBxOKqhaH0AH3qRicwnuPm\nZ4/mNHYQ0vBffENewujn1bCAz4C1WB66/AXBYF8dpCP42qB5yK7FRNv4JubMmqhK\n7fkD88uu7JVGRYU+temWuJHH4WDxiCmvK8nXacFaZT1NGdTL9/2EukKLguTtZumb\noRWgFqV6WFcEnh/V/Ma51D2+K9QbCWa8Bb6c/wKOd9Ii1aDZABEBAAGJAR8EGAEC\nAAkFAlPzE4sCGwwACgkQ3NdDGK7TmFT2rwf+MzLFPn4Rkko38nctysbXm6qmk34U\nNTtqirOlxg3mWeUCp7VQGU2Rg2msdo764SxCK12OhJqlXGMd2efCoQhYbMOqG6C0\nikBZPkd5BVFuTKsAUiuVoiQd8bDaZSpO2QdE0RdHE/yYfO66pceEKkGlcjkTRFFU\nM7nTm7IQj4BBZclMLPr4fX520ZOVUepxAARMHW5A6EcHXvhXmblZOJM36fOv3T5N\nl9L5tWdt/wybaRE4xuwVSs0n7MyMlWmkQxz8Z6OQscbKmuI4tcYSbvvB5tzjLBwZ\nChb0eEZA5ePvnGofu+3JH48FmCIPveD+4kI9GhtGkCL3Q2PiPiLcSnWQWQ==\n=nFcN\n-----END PGP PUBLIC KEY BLOCK----- \n" > /tmp/keys/0.key && apt-key add /tmp/keys/0.key 23:34:14 RUN echo "-----BEGIN PGP PUBLIC KEY BLOCK-----\nVersion: GnuPG v1\n\nmQGiBEsy5KkRBADJbDSISoamRM5AA20bfAeBuhhaI+VaiCVcxw90sq9AI5lIc42F\nWzM2acm8yplqWiehAqOLKd+iIrqNGZ+VavZEPTx7o06UZUMRoPBiTFaCwrQ5avKz\nlt7ij8PRMVWNrJ7A2lDYXfFQVV1o3Xo06qVnv0KLLUmiur0LBu4H/oTH3wCgt+/I\nD3LUKaMJsc77KwFBTjHB0EsD/26Z2Ud12f3urSNyN6VMWnP3rz6xsmtY4Qsmkbnr\nJuduxCQBZv6bX1Cr2ulXkv0fFOr+s5OyUv7zyCPbxiJFh3Br7fJGb0b5/M208KPe\ngiITY9hMh/aUbKjXCPoOXPxSL6SWOWV8taR6903EFyLBN0qno/kXIBKnVqBZobgn\njIEPA/0fTnxtZtE7EpirGQMF2caJfv7/LCgXmRs9xAhgbE0/caoa1tnc79uaHmLZ\nFtbGFoAO31YNYM/IUHtmabbGdvZ4oYUwDhjBevVvC7aI+XhuNGK5mU8qCLLSEUOl\nCUr6BJq/0iFmjwjmwk9idZEYhqSNy2OoYJbq45rbHfbdKLEVrbQeUk9TIEJ1aWxk\nZXIgPHJvc2J1aWxkQHJvcy5vcmc+iGAEExECACAFAksy5KkCGwMGCwkIBwMCBBUC\nCAMEFgIDAQIeAQIXgAAKCRBVI7rusB+hFmk7AJ0XsLp05KA8l3YzAumZfjSN04MZ\njQCfQHfp4aQUXdOCUtetVo0QZUX3IuO5Ag0ESzLkrhAIAOCuSC83VXYWf8gOMSzd\nxwpsH/uLV9Wze2LGnajsJLjEOhcsz2BHfxqNXhYaE9aQaodPCpbUAkPq8tLbpXy0\nSWRCx0F5RcplXx5vIWbP6TlfPbRpK70w7IWd6vsNrjwEHjlhOLcNcj42sp5pgx4b\ndceK06k5Ml2hYovPnD9o2TYgjOqg5FHZ2g1J0103n/66bN/hZnpLaZJYQiPWCyq6\nK0565i1k2Y7hgWB/OXqwaqCehqmLTvpyQGzE1UJvKLuYU+T+4hBnSPbT3KIi5fCz\nlIwvxijOMcfbkLhzYQXcU0Rd1VItcd5nmPL4z97jBxzuhkgxXpGR4WGKhvsA2Z9Y\nUtsAAwYH/3Bf44bTpD9bVADUdab3e7zm8iHfh9K/a83mIgDB7mHV6WuemQVTf/1d\neu4mI5WtpbOCoucybGfjGIIAcSxwIx6VfC7HSp4J51bOpHhbdDffUEk6QVsZjwoF\nyn3W9W3ZVeTI+ch/Qoo5a98SnmdjN8eXI/qCuiXOHc6rXDXc2R0iox/1EAS8xGVd\ncYZe7IWBO2CjCknyhLrWxZHoy+i1GCZ9KvPF/Ef2dmLhCydT73ZlumsY8N5vm76Q\nul1G7f8LNbnMgXQafRkPffrAXSVhGY3Z2IiBwFNgxcKTq479l7yedYRGeU1A+SYI\nYmRFWHXt3rTkMlQSpxCsB0fAYfrwEqqISQQYEQIACQUCSzLkrgIbDAAKCRBVI7ru\nsB+hFpryAJ9qNz3h3ijt9TkAV0CHufsPT6Cl4gCglfg7tJn2lsSF3HTpoDDO1Fgg\nx9o=\n=AGYp\n-----END PGP PUBLIC KEY BLOCK-----\n" > /tmp/keys/1.key && apt-key add /tmp/keys/1.key 23:34:14 RUN echo deb http://10.210.9.154/ubuntu/building xenial main | tee -a /etc/apt/sources.list.d/buildfarm.list 23:34:14 RUN echo deb http://packages.ros.org/ros/ubuntu xenial main | tee -a /etc/apt/sources.list.d/buildfarm.list 23:34:14 23:34:14 RUN mkdir /tmp/wrapper_scripts 23:34:14 RUN echo "#!/usr/bin/env python3\n\n# Copyright 2014-2016 Open Source Robotics Foundation, Inc.\n#\n# Licensed under the Apache License, Version 2.0 (the \"License\");\n# you may not use this file except in compliance with the License.\n# You may obtain a copy of the License at\n#\n# http://www.apache.org/licenses/LICENSE-2.0\n#\n# Unless required by applicable law or agreed to in writing, software\n# distributed under the License is distributed on an \"AS IS\" BASIS,\n# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n# See the License for the specific language governing permissions and\n# limitations under the License.\n\nimport subprocess\nimport sys\nfrom time import sleep\n\n\ndef main(argv=sys.argv[1:]):\n max_tries = 10\n known_error_strings = [\n 'Failed to fetch',\n 'Hash Sum mismatch',\n 'Unable to locate package',\n 'is not what the server reported',\n ]\n\n command = argv[0]\n if command in ['update', 'source']:\n rc, _, _ = call_apt_repeatedly(\n argv, known_error_strings, max_tries)\n return rc\n elif command == 'update-install-clean':\n return call_apt_update_install_clean(\n argv[1:], known_error_strings, max_tries)\n else:\n assert \"Command '%s' not implemented\" % command\n\n\ndef call_apt_update_install_clean(\n install_argv, known_error_strings, max_tries):\n tries = 0\n command = 'update'\n while tries < max_tries:\n if command == 'update':\n rc, _, tries = call_apt_repeatedly(\n [command], known_error_strings, max_tries - tries,\n offset=tries)\n if rc != 0:\n # abort if update was unsuccessful even after retries\n break\n # move on to the install command if update was successful\n command = 'install'\n\n if command == 'install':\n # any call is considered a try\n tries += 1\n known_error_strings_redo_update = [\n 'Size mismatch',\n 'maybe run apt update',\n 'The following packages cannot be authenticated!',\n 'Unable to locate package',\n ]\n rc, known_error_conditions = \\\\\n call_apt(\n [command] + install_argv,\n known_error_strings + known_error_strings_redo_update)\n if not known_error_conditions:\n if rc != 0:\n # abort if install was unsuccessful\n break\n # move on to the clean command if install was successful\n command = 'clean'\n continue\n\n # known errors are always interpreted as a non-zero rc\n if rc == 0:\n rc = 1\n # check if update needs to be rerun\n if (\n set(known_error_conditions) &\n set(known_error_strings_redo_update)\n ):\n command = 'update'\n print(\"'apt install' failed and likely requires \" +\n \"'apt update' to run again\")\n # retry with update command\n continue\n\n print('Invocation failed due to the following known error '\n 'conditions: ' + ', '.join(known_error_conditions))\n if tries < max_tries:\n sleep_time = 5\n print(\"Reinvoke 'apt install' after sleeping %s seconds\" %\n sleep_time)\n sleep(sleep_time)\n # retry install command\n\n if command == 'clean':\n rc, _ = call_apt([command], [])\n break\n\n return rc\n\n\ndef call_apt_repeatedly(argv, known_error_strings, max_tries, offset=0):\n command = argv[0]\n for i in range(1, max_tries + 1):\n if i > 1:\n sleep_time = 5 + 2 * (i + offset)\n print(\"Reinvoke 'apt %s' (%d/%d) after sleeping %s seconds\" %\n (command, i + offset, max_tries + offset, sleep_time))\n sleep(sleep_time)\n rc, known_error_conditions = call_apt(argv, known_error_strings)\n if not known_error_conditions:\n # break the loop and return the reported rc\n break\n # known errors are always interpreted as a non-zero rc\n if rc == 0:\n rc = 1\n print('')\n print('Invocation failed due to the following known error conditions: '\n ', '.join(known_error_conditions))\n print('')\n # retry in case of failure with known error condition\n return rc, known_error_conditions, i + offset\n\n\ndef call_apt(argv, known_error_strings):\n known_error_conditions = []\n\n # some of the used options are not supported in older distros\n # e.g. Ubuntu Wily, Debian Jessie\n cmd = ['apt-get'] + argv\n print(\"Invoking '%s'\" % ' '.join(cmd))\n proc = subprocess.Popen(\n cmd, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)\n lines = []\n while True:\n line = proc.stdout.readline()\n if not line:\n break\n line = line.decode()\n lines.append(line)\n sys.stdout.write(line)\n for known_error_string in known_error_strings:\n if known_error_string in line:\n if known_error_string not in known_error_conditions:\n known_error_conditions.append(known_error_string)\n proc.wait()\n rc = proc.returncode\n if rc and not known_error_conditions:\n print('Invocation failed without any known error condition, '\n 'printing all lines to debug known error detection:')\n for index, line in enumerate(lines):\n print(' ', index + 1, \"'%s'\" % line.rstrip('\\\\n\\\\r'))\n print('None of the following known errors were detected:')\n for index, known_error_string in enumerate(known_error_strings):\n print(' ', index + 1, \"'%s'\" % known_error_string)\n return rc, known_error_conditions\n\n\nif __name__ == '__main__':\n sys.exit(main())" > /tmp/wrapper_scripts/apt.py 23:34:14 RUN echo "#!/usr/bin/env python3\n\n# Copyright 2016 Open Source Robotics Foundation, Inc.\n#\n# Licensed under the Apache License, Version 2.0 (the \"License\");\n# you may not use this file except in compliance with the License.\n# You may obtain a copy of the License at\n#\n# http://www.apache.org/licenses/LICENSE-2.0\n#\n# Unless required by applicable law or agreed to in writing, software\n# distributed under the License is distributed on an \"AS IS\" BASIS,\n# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n# See the License for the specific language governing permissions and\n# limitations under the License.\n\nimport subprocess\nimport sys\nfrom time import sleep\n\n\ndef main(argv=sys.argv[1:]):\n max_tries = 10\n known_error_strings = [\n 'Connection timed out',\n ]\n\n command = argv[0]\n if command == 'clone':\n rc, _, _ = call_git_repeatedly(\n argv, known_error_strings, max_tries)\n return rc\n else:\n assert \"Command '%s' not implemented\" % command\n\n\ndef call_git_repeatedly(argv, known_error_strings, max_tries):\n command = argv[0]\n for i in range(1, max_tries + 1):\n if i > 1:\n sleep_time = 5 + 2 * i\n print(\"Reinvoke 'git %s' (%d/%d) after sleeping %s seconds\" %\n (command, i, max_tries, sleep_time))\n sleep(sleep_time)\n rc, known_error_conditions = call_git(argv, known_error_strings)\n if rc == 0 or not known_error_conditions:\n break\n print('')\n print('Invocation failed due to the following known error conditions: '\n ', '.join(known_error_conditions))\n print('')\n # retry in case of failure with known error condition\n return rc, known_error_conditions, i\n\n\ndef call_git(argv, known_error_strings):\n known_error_conditions = []\n\n cmd = ['git'] + argv\n print(\"Invoking '%s'\" % ' '.join(cmd))\n proc = subprocess.Popen(\n cmd, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)\n while True:\n line = proc.stdout.readline()\n if not line:\n break\n line = line.decode()\n sys.stdout.write(line)\n for known_error_string in known_error_strings:\n if known_error_string in line:\n if known_error_string not in known_error_conditions:\n known_error_conditions.append(known_error_string)\n proc.wait()\n rc = proc.returncode\n return rc, known_error_conditions\n\n\nif __name__ == '__main__':\n sys.exit(main())" > /tmp/wrapper_scripts/git.py 23:34:14 23:34:14 # automatic invalidation once every day 23:34:14 RUN echo "2018-10-30 (+0000)" 23:34:14 23:34:14 RUN for i in 1 2 3; do apt-get update && apt-get install -q -y python3 && apt-get clean && break || if [[ $i < 3 ]]; then sleep 5; else false; fi; done 23:34:14 23:34:14 RUN python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y debhelper dpkg dpkg-dev git git-buildpackage python3-catkin-pkg-modules python3-rosdistro-modules python3-yaml 23:34:14 23:34:14 COPY .git-credentials /home/buildfarm/.git-credentials 23:34:14 RUN chmod 600 /home/buildfarm/.git-credentials 23:34:14 RUN chown buildfarm /home/buildfarm/.git-credentials 23:34:14 23:34:14 USER buildfarm 23:34:14 RUN git config --global credential.helper 'store' 23:34:14 RUN git config --global http.sslVerify false 23:34:14 23:34:14 ENTRYPOINT ["sh", "-c"] 23:34:14 CMD ["PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH python3 -u /tmp/ros_buildfarm/scripts/release/get_sources.py --rosdistro-index-url https://raw.githubusercontent.com/LCAS/rosdistro/master/index.yaml kinetic vrep_ugv_plugin ubuntu xenial http://10.210.9.154/ubuntu/building http://packages.ros.org/ros/ubuntu --source-dir /tmp/sourcedeb/source && PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH python3 -u /tmp/ros_buildfarm/scripts/release/build_sourcedeb.py ubuntu xenial --source-dir /tmp/sourcedeb/source"] 23:34:14 + echo # END SECTION 23:34:14 # END SECTION23:34:40 + echo # BEGIN SECTION: Run Dockerfile - generate sourcedeb9. Build Dockerfile - generate sourcedebHide Details
23:34:14 # BEGIN SECTION: Build Dockerfile - generate sourcedeb 23:34:14 + cd /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/docker_sourcedeb 23:34:14 + cp -L **** /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/docker_sourcedeb/.git-credentials 23:34:14 + python3 -u /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/ros_buildfarm/scripts/misc/docker_pull_baseimage.py 23:34:14 Get base image name from Dockerfile 'Dockerfile': ubuntu:xenial 23:34:14 Check docker base image for updates: docker pull ubuntu:xenial 23:34:15 xenial: Pulling from library/ubuntu 23:34:15 Digest: sha256:c958482ef7f32fbd887f1aeec29e883b42e2c9543abdcf78cec89cb58a2c7a83 23:34:15 Status: Image is up to date for ubuntu:xenial 23:34:15 + docker build --force-rm -t sourcedeb.kinetic_ubuntu_xenial_vrep_ugv_plugin . 23:34:15 Sending build context to Docker daemon 18.43 kB Sending build context to Docker daemon 18.43 kB 23:34:15 Step 1 : FROM ubuntu:xenial 23:34:15 ---> bfe0ddf9c09e 23:34:15 Step 2 : VOLUME /var/cache/apt/archives 23:34:16 ---> Using cache 23:34:16 ---> 6fae3bf9e661 23:34:16 Step 3 : ENV DEBIAN_FRONTEND noninteractive 23:34:17 ---> Using cache 23:34:17 ---> 620ae73f5df7 23:34:17 Step 4 : RUN for i in 1 2 3; do apt-get update && apt-get install -q -y locales && apt-get clean && break || if [[ $i < 3 ]]; then sleep 5; else false; fi; done 23:34:17 ---> Using cache 23:34:17 ---> 21cd30677db9 23:34:17 Step 5 : RUN echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen 23:34:18 ---> Using cache 23:34:18 ---> b8600fe9bbee 23:34:18 Step 6 : RUN locale-gen en_US.UTF-8 23:34:19 ---> Using cache 23:34:19 ---> 7e0e5b74e1c3 23:34:19 Step 7 : ENV LANG en_US.UTF-8 23:34:20 ---> Using cache 23:34:20 ---> 8149642c7468 23:34:20 Step 8 : ENV TZ GMT+00 23:34:21 ---> Using cache 23:34:21 ---> ee0547a0a050 23:34:21 Step 9 : RUN useradd -u 1002 -m buildfarm 23:34:22 ---> Using cache 23:34:22 ---> a8e5ca117f0b 23:34:22 Step 10 : RUN mkdir /tmp/keys 23:34:22 ---> Using cache 23:34:22 ---> e1ef4e091209 23:34:22 Step 11 : RUN echo "-----BEGIN PGP PUBLIC KEY BLOCK-----\nVersion: GnuPG v1.4.11 (GNU/Linux)\n\nmQENBFPzE4sBCAC9c8hzt+gqe6YqXAW9Yd10jx68M0q8IowAe182yVtIvYf5l+qn\nMsXiDUz4l7c1TcRpdzZ1WwEQoNNjQKq51ip2Ln3Uhri/GsPBk+psIJPt5AeXYrSf\nxcDs8k4FMWgJtYMlZLuNk1YPaS6Vf1+Ygbe0u+ssORWg3cWhgLWPDydXdlhinUgw\nkPd9ZYi8aaAxi94DMuOnAjItfPbuX52NHmPR2cXuh3fZklhA6cCGRYkSVqijKhEv\n/o8fTnjcTama8ml5jnaAhcZ/4UV3terLeXEQn3+WM+VbTsEr58zca5fOv8MjC+Uh\nEBgDgnHb8/n7OgSUvv9efQgYXBRQ1mD//JaZABEBAAG0LE1hcmMgSGFuaGVpZGUg\nKFJPU0J1aWxkKSA8bWFyY0BoYW5oZWlkZS5uZXQ+iQE4BBMBAgAiBQJT8xOLAhsD\nBgsJCAcDAgYVCAIJCgsEFgIDAQIeAQIXgAAKCRDc10MYrtOYVB9cCACQwB9auPEX\nyQdVwliJMLwVihKz0AU0UCG6qra2pdXx9l5kgkQCuDV5FQqMpk/MIJPn8Zj0l1MI\n7Yn/EAqBhXjtO2BcTuUC/9epzt1p3C++vK7RSsBDXfKzZN22apIUT0njOkL9Vuoy\nJjFetmLDaZVbmFU+4ZaX3CFtBL3ewlFiT7G6StKj40JI8QJOlDOziX2OUsqZaI2T\nYh681980od3f2OfV3LPVroz7xnyECDfBaPBPaDdb8XWSNVLhuyglb15eewK0hj++\nCut3swWH02Y3yVhzFBnosqqjyzPLBQeDMOoHAPpJHRgprfIRDoUkWAXO5re3GIUQ\ncvk0d1I1jh3luQENBFPzE4sBCACmSxiM1vpPI7BpgUNAhu0B8SWptULpiYOnDHfM\nhU1u95Z5Lu/hy3sfm4BEKgLju7Y1I3jToWTwJJzgWZRr+iuuwj3fbfHCISYIK7f3\nIWGL2iM2+kLIH6E9oqRgGbJmhiwbz6OokxG0W7atdqpBxOKqhaH0AH3qRicwnuPm\nZ4/mNHYQ0vBffENewujn1bCAz4C1WB66/AXBYF8dpCP42qB5yK7FRNv4JubMmqhK\n7fkD88uu7JVGRYU+temWuJHH4WDxiCmvK8nXacFaZT1NGdTL9/2EukKLguTtZumb\noRWgFqV6WFcEnh/V/Ma51D2+K9QbCWa8Bb6c/wKOd9Ii1aDZABEBAAGJAR8EGAEC\nAAkFAlPzE4sCGwwACgkQ3NdDGK7TmFT2rwf+MzLFPn4Rkko38nctysbXm6qmk34U\nNTtqirOlxg3mWeUCp7VQGU2Rg2msdo764SxCK12OhJqlXGMd2efCoQhYbMOqG6C0\nikBZPkd5BVFuTKsAUiuVoiQd8bDaZSpO2QdE0RdHE/yYfO66pceEKkGlcjkTRFFU\nM7nTm7IQj4BBZclMLPr4fX520ZOVUepxAARMHW5A6EcHXvhXmblZOJM36fOv3T5N\nl9L5tWdt/wybaRE4xuwVSs0n7MyMlWmkQxz8Z6OQscbKmuI4tcYSbvvB5tzjLBwZ\nChb0eEZA5ePvnGofu+3JH48FmCIPveD+4kI9GhtGkCL3Q2PiPiLcSnWQWQ==\n=nFcN\n-----END PGP PUBLIC KEY BLOCK----- \n" > /tmp/keys/0.key && apt-key add /tmp/keys/0.key 23:34:23 ---> Using cache 23:34:23 ---> ad3bf9bab2e1 23:34:23 Step 12 : RUN echo "-----BEGIN PGP PUBLIC KEY BLOCK-----\nVersion: GnuPG v1\n\nmQGiBEsy5KkRBADJbDSISoamRM5AA20bfAeBuhhaI+VaiCVcxw90sq9AI5lIc42F\nWzM2acm8yplqWiehAqOLKd+iIrqNGZ+VavZEPTx7o06UZUMRoPBiTFaCwrQ5avKz\nlt7ij8PRMVWNrJ7A2lDYXfFQVV1o3Xo06qVnv0KLLUmiur0LBu4H/oTH3wCgt+/I\nD3LUKaMJsc77KwFBTjHB0EsD/26Z2Ud12f3urSNyN6VMWnP3rz6xsmtY4Qsmkbnr\nJuduxCQBZv6bX1Cr2ulXkv0fFOr+s5OyUv7zyCPbxiJFh3Br7fJGb0b5/M208KPe\ngiITY9hMh/aUbKjXCPoOXPxSL6SWOWV8taR6903EFyLBN0qno/kXIBKnVqBZobgn\njIEPA/0fTnxtZtE7EpirGQMF2caJfv7/LCgXmRs9xAhgbE0/caoa1tnc79uaHmLZ\nFtbGFoAO31YNYM/IUHtmabbGdvZ4oYUwDhjBevVvC7aI+XhuNGK5mU8qCLLSEUOl\nCUr6BJq/0iFmjwjmwk9idZEYhqSNy2OoYJbq45rbHfbdKLEVrbQeUk9TIEJ1aWxk\nZXIgPHJvc2J1aWxkQHJvcy5vcmc+iGAEExECACAFAksy5KkCGwMGCwkIBwMCBBUC\nCAMEFgIDAQIeAQIXgAAKCRBVI7rusB+hFmk7AJ0XsLp05KA8l3YzAumZfjSN04MZ\njQCfQHfp4aQUXdOCUtetVo0QZUX3IuO5Ag0ESzLkrhAIAOCuSC83VXYWf8gOMSzd\nxwpsH/uLV9Wze2LGnajsJLjEOhcsz2BHfxqNXhYaE9aQaodPCpbUAkPq8tLbpXy0\nSWRCx0F5RcplXx5vIWbP6TlfPbRpK70w7IWd6vsNrjwEHjlhOLcNcj42sp5pgx4b\ndceK06k5Ml2hYovPnD9o2TYgjOqg5FHZ2g1J0103n/66bN/hZnpLaZJYQiPWCyq6\nK0565i1k2Y7hgWB/OXqwaqCehqmLTvpyQGzE1UJvKLuYU+T+4hBnSPbT3KIi5fCz\nlIwvxijOMcfbkLhzYQXcU0Rd1VItcd5nmPL4z97jBxzuhkgxXpGR4WGKhvsA2Z9Y\nUtsAAwYH/3Bf44bTpD9bVADUdab3e7zm8iHfh9K/a83mIgDB7mHV6WuemQVTf/1d\neu4mI5WtpbOCoucybGfjGIIAcSxwIx6VfC7HSp4J51bOpHhbdDffUEk6QVsZjwoF\nyn3W9W3ZVeTI+ch/Qoo5a98SnmdjN8eXI/qCuiXOHc6rXDXc2R0iox/1EAS8xGVd\ncYZe7IWBO2CjCknyhLrWxZHoy+i1GCZ9KvPF/Ef2dmLhCydT73ZlumsY8N5vm76Q\nul1G7f8LNbnMgXQafRkPffrAXSVhGY3Z2IiBwFNgxcKTq479l7yedYRGeU1A+SYI\nYmRFWHXt3rTkMlQSpxCsB0fAYfrwEqqISQQYEQIACQUCSzLkrgIbDAAKCRBVI7ru\nsB+hFpryAJ9qNz3h3ijt9TkAV0CHufsPT6Cl4gCglfg7tJn2lsSF3HTpoDDO1Fgg\nx9o=\n=AGYp\n-----END PGP PUBLIC KEY BLOCK-----\n" > /tmp/keys/1.key && apt-key add /tmp/keys/1.key 23:34:24 ---> Using cache 23:34:24 ---> b4c4aba664e0 23:34:24 Step 13 : RUN echo deb http://10.210.9.154/ubuntu/building xenial main | tee -a /etc/apt/sources.list.d/buildfarm.list 23:34:25 ---> Using cache 23:34:25 ---> d8cb5a24890b 23:34:25 Step 14 : RUN echo deb http://packages.ros.org/ros/ubuntu xenial main | tee -a /etc/apt/sources.list.d/buildfarm.list 23:34:26 ---> Using cache 23:34:26 ---> a5a61a04b0e6 23:34:26 Step 15 : RUN mkdir /tmp/wrapper_scripts 23:34:27 ---> Using cache 23:34:27 ---> 97d1c23b68e3 23:34:27 Step 16 : RUN echo "#!/usr/bin/env python3\n\n# Copyright 2014-2016 Open Source Robotics Foundation, Inc.\n#\n# Licensed under the Apache License, Version 2.0 (the \"License\");\n# you may not use this file except in compliance with the License.\n# You may obtain a copy of the License at\n#\n# http://www.apache.org/licenses/LICENSE-2.0\n#\n# Unless required by applicable law or agreed to in writing, software\n# distributed under the License is distributed on an \"AS IS\" BASIS,\n# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n# See the License for the specific language governing permissions and\n# limitations under the License.\n\nimport subprocess\nimport sys\nfrom time import sleep\n\n\ndef main(argv=sys.argv[1:]):\n max_tries = 10\n known_error_strings = [\n 'Failed to fetch',\n 'Hash Sum mismatch',\n 'Unable to locate package',\n 'is not what the server reported',\n ]\n\n command = argv[0]\n if command in ['update', 'source']:\n rc, _, _ = call_apt_repeatedly(\n argv, known_error_strings, max_tries)\n return rc\n elif command == 'update-install-clean':\n return call_apt_update_install_clean(\n argv[1:], known_error_strings, max_tries)\n else:\n assert \"Command '%s' not implemented\" % command\n\n\ndef call_apt_update_install_clean(\n install_argv, known_error_strings, max_tries):\n tries = 0\n command = 'update'\n while tries < max_tries:\n if command == 'update':\n rc, _, tries = call_apt_repeatedly(\n [command], known_error_strings, max_tries - tries,\n offset=tries)\n if rc != 0:\n # abort if update was unsuccessful even after retries\n break\n # move on to the install command if update was successful\n command = 'install'\n\n if command == 'install':\n # any call is considered a try\n tries += 1\n known_error_strings_redo_update = [\n 'Size mismatch',\n 'maybe run apt update',\n 'The following packages cannot be authenticated!',\n 'Unable to locate package',\n ]\n rc, known_error_conditions = \\\\\n call_apt(\n [command] + install_argv,\n known_error_strings + known_error_strings_redo_update)\n if not known_error_conditions:\n if rc != 0:\n # abort if install was unsuccessful\n break\n # move on to the clean command if install was successful\n command = 'clean'\n continue\n\n # known errors are always interpreted as a non-zero rc\n if rc == 0:\n rc = 1\n # check if update needs to be rerun\n if (\n set(known_error_conditions) &\n set(known_error_strings_redo_update)\n ):\n command = 'update'\n print(\"'apt install' failed and likely requires \" +\n \"'apt update' to run again\")\n # retry with update command\n continue\n\n print('Invocation failed due to the following known error '\n 'conditions: ' + ', '.join(known_error_conditions))\n if tries < max_tries:\n sleep_time = 5\n print(\"Reinvoke 'apt install' after sleeping %s seconds\" %\n sleep_time)\n sleep(sleep_time)\n # retry install command\n\n if command == 'clean':\n rc, _ = call_apt([command], [])\n break\n\n return rc\n\n\ndef call_apt_repeatedly(argv, known_error_strings, max_tries, offset=0):\n command = argv[0]\n for i in range(1, max_tries + 1):\n if i > 1:\n sleep_time = 5 + 2 * (i + offset)\n print(\"Reinvoke 'apt %s' (%d/%d) after sleeping %s seconds\" %\n (command, i + offset, max_tries + offset, sleep_time))\n sleep(sleep_time)\n rc, known_error_conditions = call_apt(argv, known_error_strings)\n if not known_error_conditions:\n # break the loop and return the reported rc\n break\n # known errors are always interpreted as a non-zero rc\n if rc == 0:\n rc = 1\n print('')\n print('Invocation failed due to the following known error conditions: '\n ', '.join(known_error_conditions))\n print('')\n # retry in case of failure with known error condition\n return rc, known_error_conditions, i + offset\n\n\ndef call_apt(argv, known_error_strings):\n known_error_conditions = []\n\n # some of the used options are not supported in older distros\n # e.g. Ubuntu Wily, Debian Jessie\n cmd = ['apt-get'] + argv\n print(\"Invoking '%s'\" % ' '.join(cmd))\n proc = subprocess.Popen(\n cmd, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)\n lines = []\n while True:\n line = proc.stdout.readline()\n if not line:\n break\n line = line.decode()\n lines.append(line)\n sys.stdout.write(line)\n for known_error_string in known_error_strings:\n if known_error_string in line:\n if known_error_string not in known_error_conditions:\n known_error_conditions.append(known_error_string)\n proc.wait()\n rc = proc.returncode\n if rc and not known_error_conditions:\n print('Invocation failed without any known error condition, '\n 'printing all lines to debug known error detection:')\n for index, line in enumerate(lines):\n print(' ', index + 1, \"'%s'\" % line.rstrip('\\\\n\\\\r'))\n print('None of the following known errors were detected:')\n for index, known_error_string in enumerate(known_error_strings):\n print(' ', index + 1, \"'%s'\" % known_error_string)\n return rc, known_error_conditions\n\n\nif __name__ == '__main__':\n sys.exit(main())" > /tmp/wrapper_scripts/apt.py 23:34:28 ---> Using cache 23:34:28 ---> 80f2a51affed 23:34:28 Step 17 : RUN echo "#!/usr/bin/env python3\n\n# Copyright 2016 Open Source Robotics Foundation, Inc.\n#\n# Licensed under the Apache License, Version 2.0 (the \"License\");\n# you may not use this file except in compliance with the License.\n# You may obtain a copy of the License at\n#\n# http://www.apache.org/licenses/LICENSE-2.0\n#\n# Unless required by applicable law or agreed to in writing, software\n# distributed under the License is distributed on an \"AS IS\" BASIS,\n# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n# See the License for the specific language governing permissions and\n# limitations under the License.\n\nimport subprocess\nimport sys\nfrom time import sleep\n\n\ndef main(argv=sys.argv[1:]):\n max_tries = 10\n known_error_strings = [\n 'Connection timed out',\n ]\n\n command = argv[0]\n if command == 'clone':\n rc, _, _ = call_git_repeatedly(\n argv, known_error_strings, max_tries)\n return rc\n else:\n assert \"Command '%s' not implemented\" % command\n\n\ndef call_git_repeatedly(argv, known_error_strings, max_tries):\n command = argv[0]\n for i in range(1, max_tries + 1):\n if i > 1:\n sleep_time = 5 + 2 * i\n print(\"Reinvoke 'git %s' (%d/%d) after sleeping %s seconds\" %\n (command, i, max_tries, sleep_time))\n sleep(sleep_time)\n rc, known_error_conditions = call_git(argv, known_error_strings)\n if rc == 0 or not known_error_conditions:\n break\n print('')\n print('Invocation failed due to the following known error conditions: '\n ', '.join(known_error_conditions))\n print('')\n # retry in case of failure with known error condition\n return rc, known_error_conditions, i\n\n\ndef call_git(argv, known_error_strings):\n known_error_conditions = []\n\n cmd = ['git'] + argv\n print(\"Invoking '%s'\" % ' '.join(cmd))\n proc = subprocess.Popen(\n cmd, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)\n while True:\n line = proc.stdout.readline()\n if not line:\n break\n line = line.decode()\n sys.stdout.write(line)\n for known_error_string in known_error_strings:\n if known_error_string in line:\n if known_error_string not in known_error_conditions:\n known_error_conditions.append(known_error_string)\n proc.wait()\n rc = proc.returncode\n return rc, known_error_conditions\n\n\nif __name__ == '__main__':\n sys.exit(main())" > /tmp/wrapper_scripts/git.py 23:34:29 ---> Using cache 23:34:29 ---> b23ae5edbb97 23:34:29 Step 18 : RUN echo "2018-10-30 (+0000)" 23:34:30 ---> Using cache 23:34:30 ---> d9aa180debb1 23:34:30 Step 19 : RUN for i in 1 2 3; do apt-get update && apt-get install -q -y python3 && apt-get clean && break || if [[ $i < 3 ]]; then sleep 5; else false; fi; done 23:34:31 ---> Using cache 23:34:31 ---> 0b04be3ad400 23:34:31 Step 20 : RUN python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y debhelper dpkg dpkg-dev git git-buildpackage python3-catkin-pkg-modules python3-rosdistro-modules python3-yaml 23:34:32 ---> Using cache 23:34:32 ---> ae19849f6fb4 23:34:32 Step 21 : COPY .git-credentials /home/buildfarm/.git-credentials 23:34:33 ---> Using cache 23:34:33 ---> 2f954b3cefbd 23:34:33 Step 22 : RUN chmod 600 /home/buildfarm/.git-credentials 23:34:34 ---> Using cache 23:34:34 ---> f709e975391b 23:34:34 Step 23 : RUN chown buildfarm /home/buildfarm/.git-credentials 23:34:35 ---> Using cache 23:34:35 ---> 027e32874024 23:34:35 Step 24 : USER buildfarm 23:34:36 ---> Using cache 23:34:36 ---> 0c35c64ce3e1 23:34:36 Step 25 : RUN git config --global credential.helper 'store' 23:34:37 ---> Using cache 23:34:37 ---> 5ec5a87591d9 23:34:37 Step 26 : RUN git config --global http.sslVerify false 23:34:37 ---> Using cache 23:34:37 ---> c987503b0279 23:34:37 Step 27 : ENTRYPOINT sh -c 23:34:38 ---> Using cache 23:34:38 ---> 86fb77c32e69 23:34:38 Step 28 : CMD PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH python3 -u /tmp/ros_buildfarm/scripts/release/get_sources.py --rosdistro-index-url https://raw.githubusercontent.com/LCAS/rosdistro/master/index.yaml kinetic vrep_ugv_plugin ubuntu xenial http://10.210.9.154/ubuntu/building http://packages.ros.org/ros/ubuntu --source-dir /tmp/sourcedeb/source && PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH python3 -u /tmp/ros_buildfarm/scripts/release/build_sourcedeb.py ubuntu xenial --source-dir /tmp/sourcedeb/source 23:34:40 ---> Running in 7ff84e3a2446 23:34:40 ---> e926e188846c 23:34:40 Removing intermediate container 7ff84e3a2446 23:34:40 Successfully built e926e188846c 23:34:40 + echo # END SECTION 23:34:40 # END SECTION23:35:09 [Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source] $ /bin/sh -xe /tmp/hudson1578007841636227267.sh 23:35:09 + [ false = false ] 23:35:09 + echo # BEGIN SECTION: Clean up to save disk space on slaves10. Run Dockerfile - generate sourcedebHide Details
23:34:40 # BEGIN SECTION: Run Dockerfile - generate sourcedeb 23:34:40 + rm -fr /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/sourcedeb 23:34:40 + mkdir -p /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/sourcedeb/source 23:34:40 + docker run --rm --cidfile=/home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/docker_sourcedeb/docker.cid -e=TRAVIS= --net=host -v /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/ros_buildfarm:/tmp/ros_buildfarm:ro -v /home/jenkins-slave/workspace/Ksrc_uX__vrep_ugv_plugin__ubuntu_xenial__source/sourcedeb:/tmp/sourcedeb sourcedeb.kinetic_ubuntu_xenial_vrep_ugv_plugin10.1. get sourcesHide Details
23:34:41 # BEGIN SUBSECTION: get sources 23:34:51 Invoking 'git clone --branch debian/ros-kinetic-vrep-ugv-plugin_1.0.6-0_xenial --depth 1 --no-single-branch https://github.com/lcas-releases/tradr_uol.git /tmp/sourcedeb/source' 23:34:51 Cloning into '/tmp/sourcedeb/source'... 23:34:59 Note: checking out '4ed9c476312d980fea59fc13ceaeab8076bf9080'. 23:34:59 23:34:59 You are in 'detached HEAD' state. You can look around, make experimental 23:34:59 changes and commit them, and you can discard any commits you make in this 23:34:59 state without impacting any branches by performing another checkout. 23:34:59 23:34:59 If you want to create a new branch to retain commits you create, you may 23:34:59 do so (now or later) by using -b with the checkout command again. Example: 23:34:59 23:34:59 git checkout -b <new-branch-name> 23:34:59 23:35:00 dpkg-parsechangelog: warning: debian/changelog(l5): found trailer where expected start of change data 23:35:00 LINE: -- Riccardo Polvara <rpolvara@lincoln.ac.uk> Tue, 30 Oct 2018 00:00:00 -0000 23:35:00 No tarball found at 'http://10.210.9.154/ubuntu/building/pool/main/r/ros-kinetic-vrep-ugv-plugin/ros-kinetic-vrep-ugv-plugin_1.0.6.orig.tar.gz' 23:35:00 No tarball found at 'http://packages.ros.org/ros/ubuntu/pool/main/r/ros-kinetic-vrep-ugv-plugin/ros-kinetic-vrep-ugv-plugin_1.0.6.orig.tar.gz' 23:35:00 Package 'vrep_ugv_plugin' version: 1.0.6-0xenial 23:35:00 Package maintainer emails: mario.gianni@plymouth.ac.uk mhanheide@lincoln.ac.uk rpolvara@lincoln.ac.uk 23:35:00 # END SUBSECTION23:35:09 + echo # END SECTION 23:35:09 # END SECTION10.2. build sourcedebHide Details
23:35:00 # BEGIN SUBSECTION: build sourcedeb 23:35:00 Invoking 'gbp buildpackage --git-ignore-new --git-ignore-branch -S -us -uc --lintian-opts --suppress-tags newer-standards-version' in '/tmp/sourcedeb/source' 23:35:01 gbp:warning: Old style config section [git-buildpackage] found please rename to [buildpackage] 23:35:04 gbp:info: ros-kinetic-vrep-ugv-plugin_1.0.6.orig.tar.gz does not exist, creating from 'release/kinetic/vrep_ugv_plugin/1.0.6-0' 23:35:04 debuild: warning: debian/changelog(l5): found trailer where expected start of change data 23:35:04 LINE: -- Riccardo Polvara <rpolvara@lincoln.ac.uk> Tue, 30 Oct 2018 00:00:00 -0000 23:35:04 dpkg-buildpackage -rfakeroot -d -us -uc -i -I -S 23:35:04 dpkg-buildpackage: warning: debian/changelog(l5): found trailer where expected start of change data 23:35:04 LINE: -- Riccardo Polvara <rpolvara@lincoln.ac.uk> Tue, 30 Oct 2018 00:00:00 -0000 23:35:04 dpkg-buildpackage: source package ros-kinetic-vrep-ugv-plugin 23:35:04 dpkg-buildpackage: source version 1.0.6-0xenial 23:35:04 dpkg-buildpackage: source distribution xenial 23:35:04 dpkg-buildpackage: source changed by Riccardo Polvara <rpolvara@lincoln.ac.uk> 23:35:04 dpkg-source -i -I --before-build source 23:35:04 dpkg-source: info: using options from source/debian/source/options: --auto-commit 23:35:04 dpkg-source: warning: source/debian/changelog(l5): found trailer where expected start of change data 23:35:04 LINE: -- Riccardo Polvara <rpolvara@lincoln.ac.uk> Tue, 30 Oct 2018 00:00:00 -0000 23:35:04 fakeroot debian/rules clean 23:35:05 dh clean -v --buildsystem=cmake 23:35:06 dh_testdir -O-v -O--buildsystem=cmake 23:35:06 dh_auto_clean -O-v -O--buildsystem=cmake 23:35:06 dh_clean -O-v -O--buildsystem=cmake 23:35:06 rm -f debian/debhelper-build-stamp 23:35:06 rm -f debian/ros-kinetic-vrep-ugv-plugin.substvars 23:35:06 rm -f debian/ros-kinetic-vrep-ugv-plugin.*.debhelper 23:35:06 rm -rf debian/ros-kinetic-vrep-ugv-plugin/ 23:35:06 rm -rf debian/.debhelper/ 23:35:06 rm -f debian/*.debhelper.log 23:35:06 rm -f debian/files 23:35:06 find . \( \( \ 23:35:06 \( -path .\*/.git -o -path .\*/.svn -o -path .\*/.bzr -o -path .\*/.hg -o -path .\*/CVS \) -prune -o -type f -a \ 23:35:06 \( -name '#*#' -o -name '.*~' -o -name '*~' -o -name DEADJOE \ 23:35:06 -o -name '*.orig' -o -name '*.rej' -o -name '*.bak' \ 23:35:06 -o -name '.*.orig' -o -name .*.rej -o -name '.SUMS' \ 23:35:06 -o -name TAGS -o \( -path '*/.deps/*' -a -name '*.P' \) \ 23:35:06 \) -exec rm -f {} + \) -o \ 23:35:06 \( -type d -a -name autom4te.cache -prune -exec rm -rf {} + \) \) 23:35:06 rm -f *-stamp 23:35:06 dpkg-source -i -I -b source 23:35:06 dpkg-source: info: using options from source/debian/source/options: --auto-commit 23:35:06 dpkg-source: warning: source/debian/changelog(l5): found trailer where expected start of change data 23:35:06 LINE: -- Riccardo Polvara <rpolvara@lincoln.ac.uk> Tue, 30 Oct 2018 00:00:00 -0000 23:35:06 dpkg-source: info: using source format '3.0 (quilt)' 23:35:06 dpkg-source: info: building ros-kinetic-vrep-ugv-plugin using existing ./ros-kinetic-vrep-ugv-plugin_1.0.6.orig.tar.gz 23:35:06 dpkg-source: warning: source/debian/changelog(l5): found trailer where expected start of change data 23:35:06 LINE: -- Riccardo Polvara <rpolvara@lincoln.ac.uk> Tue, 30 Oct 2018 00:00:00 -0000 23:35:06 dpkg-source: info: building ros-kinetic-vrep-ugv-plugin in ros-kinetic-vrep-ugv-plugin_1.0.6-0xenial.debian.tar.xz 23:35:06 dpkg-source: info: building ros-kinetic-vrep-ugv-plugin in ros-kinetic-vrep-ugv-plugin_1.0.6-0xenial.dsc 23:35:06 dpkg-genchanges -S >../ros-kinetic-vrep-ugv-plugin_1.0.6-0xenial_source.changes 23:35:06 dpkg-genchanges: warning: debian/changelog(l5): found trailer where expected start of change data 23:35:06 LINE: -- Riccardo Polvara <rpolvara@lincoln.ac.uk> Tue, 30 Oct 2018 00:00:00 -0000 23:35:06 dpkg-genchanges: warning: debian/changelog(l5): found trailer where expected start of change data 23:35:06 LINE: -- Riccardo Polvara <rpolvara@lincoln.ac.uk> Tue, 30 Oct 2018 00:00:00 -0000 23:35:06 dpkg-genchanges: warning: debian/changelog(l11): found trailer where expected start of change data 23:35:06 LINE: -- Riccardo Polvara <rpolvara@lincoln.ac.uk> Tue, 30 Oct 2018 00:00:00 -0000 23:35:07 dpkg-genchanges: including full source code in upload 23:35:07 dpkg-source -i -I --after-build source 23:35:07 dpkg-source: info: using options from source/debian/source/options: --auto-commit 23:35:07 dpkg-source: warning: source/debian/changelog(l5): found trailer where expected start of change data 23:35:07 LINE: -- Riccardo Polvara <rpolvara@lincoln.ac.uk> Tue, 30 Oct 2018 00:00:00 -0000 23:35:07 dpkg-buildpackage: full upload (original source is included) 23:35:07 Now running lintian... 23:35:09 W: ros-kinetic-vrep-ugv-plugin source: pear-package-without-pkg-php-tools-builddep 23:35:09 W: ros-kinetic-vrep-ugv-plugin source: no-debian-copyright 23:35:09 W: ros-kinetic-vrep-ugv-plugin source: ancient-standards-version 3.9.2 (current is 3.9.7) 23:35:09 Finished running lintian. 23:35:09 # END SUBSECTION23:35:09 SSH: Connecting from host [lcas-buildfarm-slave-2] 23:35:09 SSH: Connecting with configuration [repo] ... 23:35:10 SSH: Disconnecting configuration [repo] ... 23:35:10 SSH: Transferred 4 file(s) 23:35:10 Build step 'Send files or execute commands over SSH' changed build result to SUCCESS 23:35:10 Waiting for the completion of Krel_import-package 23:35:11 Krel_import-package #3966 completed. Result was SUCCESS11. Clean up to save disk space on slavesHide Details
23:35:09 # BEGIN SECTION: Clean up to save disk space on slaves 23:35:09 + rm -fr sourcedeb/source 23:35:09 + echo # END SECTION 23:35:09 # END SECTION23:35:12 $ ssh-agent -k 23:35:12 unset SSH_AUTH_SOCK; 23:35:12 unset SSH_AGENT_PID; 23:35:12 echo Agent pid 21522 killed; 23:35:12 [ssh-agent] Stopped. 23:35:12 [description-setter] Description set: 1.0.6-0xenial 23:35:12 Warning: you have no plugins providing access control for builds, so falling back to legacy behavior of permitting any downstream builds to be triggered 23:35:12 Triggering a new build of Kbin_uX64__vrep_ugv_plugin__ubuntu_xenial_amd64__binary 23:35:12 Finished: SUCCESS12. Check if triggered build failedHide Details
23:35:11 # BEGIN SECTION: Check if triggered build failed 23:35:11 Pattern not found in build log, continuing... 23:35:11 # END SECTION