Console Output
20:45:34 Started by upstream project "Mrel_trigger-jobs" build number 14028 20:45:34 originally caused by: 20:45:34 Started by timer 20:45:34 Running as SYSTEM 20:45:34 Building remotely on build client 2 (slave buildslave indigo_devel_default buildagent) in workspace /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source 20:45:34 [ssh-agent] Looking for ssh-agent implementation... 20:45:34 [ssh-agent] Exec ssh-agent (binary ssh-agent on a remote machine) 20:45:34 $ ssh-agent 20:45:34 SSH_AUTH_SOCK=/tmp/ssh-j5CPyGlkKOId/agent.10324 20:45:34 SSH_AGENT_PID=10326 20:45:34 [ssh-agent] Started. 20:45:34 Running ssh-add (command line suppressed) 20:45:34 Identity added: /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source@tmp/private_key_8949917234160318408.key (/home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source@tmp/private_key_8949917234160318408.key) 20:45:34 [ssh-agent] Using credentials jenkins-slave20:45:34 [Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source] $ /bin/sh -xe /tmp/jenkins3676776403519997366.sh 20:45:34 + echo # BEGIN SECTION: docker version1. Check free disk spaceHide Details
20:45:34 # BEGIN SECTION: Check free disk space 20:45:34 Usable disk space = 88992288768 bytes 20:45:34 Free space threshold = 5368709120 bytes 20:45:34 # END SECTION20:45:34 + echo # BEGIN SECTION: docker info2. docker versionHide Details
20:45:34 # BEGIN SECTION: docker version 20:45:34 + docker version 20:45:34 Client: 20:45:34 Version: 17.05.0-ce 20:45:34 API version: 1.29 20:45:34 Go version: go1.7.5 20:45:34 Git commit: 89658be 20:45:34 Built: Thu May 4 22:06:06 2017 20:45:34 OS/Arch: linux/amd64 20:45:34 20:45:34 Server: 20:45:34 Version: 17.05.0-ce 20:45:34 API version: 1.29 (minimum version 1.12) 20:45:34 Go version: go1.7.5 20:45:34 Git commit: 89658be 20:45:34 Built: Thu May 4 22:06:06 2017 20:45:34 OS/Arch: linux/amd64 20:45:34 Experimental: false 20:45:34 + echo # END SECTION 20:45:34 # END SECTION20:45:36 [Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source] $ /bin/sh -xe /tmp/jenkins5256421547803762709.sh 20:45:36 + echo # BEGIN SECTION: Check docker status3. docker infoHide Details
20:45:34 # BEGIN SECTION: docker info 20:45:34 + docker info 20:45:35 Containers: 0 20:45:35 Running: 0 20:45:35 Paused: 0 20:45:35 Stopped: 0 20:45:35 Images: 739 20:45:35 Server Version: 17.05.0-ce 20:45:35 Storage Driver: aufs 20:45:35 Root Dir: /var/lib/docker/aufs 20:45:35 Backing Filesystem: extfs 20:45:35 Dirs: 473 20:45:35 Dirperm1 Supported: false 20:45:35 Logging Driver: json-file 20:45:35 Cgroup Driver: cgroupfs 20:45:35 Plugins: 20:45:35 Volume: local 20:45:35 Network: bridge host macvlan null overlay 20:45:35 Swarm: inactive 20:45:35 Runtimes: runc 20:45:35 Default Runtime: runc 20:45:35 Init Binary: docker-init 20:45:35 containerd version: 9048e5e50717ea4497b757314bad98ea3763c145 20:45:35 runc version: 9c2d8d184e5da67c95d601382adf14862e4f2228 20:45:35 init version: 949e6fa 20:45:35 Security Options: 20:45:35 apparmor 20:45:35 Kernel Version: 3.13.0-29-generic 20:45:35 Operating System: Ubuntu 14.04 LTS 20:45:35 OSType: linux 20:45:35 Architecture: x86_64 20:45:35 CPUs: 2 20:45:35 Total Memory: 3.861GiB 20:45:35 Name: lcas-buildfarm-slave-1 20:45:35 ID: LZSS:PF7G:CREH:TEQW:FH57:3M6D:KCSS:ODQY:SPHA:ND7A:FHYG:PNDE 20:45:35 Docker Root Dir: /var/lib/docker 20:45:35 Debug Mode (client): false 20:45:35 Debug Mode (server): false 20:45:35 Registry: https://index.docker.io/v1/ 20:45:35 Experimental: false 20:45:35 Insecure Registries: 20:45:35 127.0.0.0/8 20:45:35 Live Restore Enabled: false 20:45:35 20:45:35 WARNING: No swap limit support 20:45:35 + echo # END SECTION 20:45:35 # END SECTION20:45:37 [Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source] $ /bin/sh -xe /tmp/jenkins7764835285807545871.sh 20:45:37 + echo # BEGIN SECTION: Embed wrapper scripts4. Check docker statusHide Details
20:45:36 # BEGIN SECTION: Check docker status 20:45:36 + echo Testing trivial docker invocation... 20:45:36 Testing trivial docker invocation... 20:45:36 + docker run --rm ubuntu:bionic true 20:45:36 + echo 'docker run' returned 0 20:45:36 'docker run' returned 0 20:45:37 docker seems operational, continuing 20:45:37 [Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source] $ /bin/sh -xe /tmp/jenkins6561591809070683017.sh 20:45:37 + echo # END SECTION 20:45:37 # END SECTION20:45:37 [Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source] $ /bin/sh -xe /tmp/jenkins3001563236134899307.sh 20:45:37 + echo # BEGIN SECTION: Clone ros_buildfarm5. Embed wrapper scriptsHide Details
20:45:37 # BEGIN SECTION: Embed wrapper scripts 20:45:37 + rm -fr wrapper_scripts 20:45:37 + mkdir wrapper_scripts 20:45:37 + 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()) 20:45:37 + echo # END SECTION 20:45:37 # END SECTION20:45:39 [Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source] $ /bin/sh -xe /tmp/jenkins2963570946034656480.sh 20:45:39 + echo # BEGIN SECTION: Write PGP repository keys6. Clone ros_buildfarmHide Details
20:45:37 # BEGIN SECTION: Clone ros_buildfarm 20:45:37 + rm -fr ros_buildfarm 20:45:37 + python3 -u wrapper_scripts/git.py clone --depth 1 -b pull_upstream https://github.com/lcas/ros_buildfarm.git ros_buildfarm 20:45:37 Invoking 'git clone --depth 1 -b pull_upstream https://github.com/lcas/ros_buildfarm.git ros_buildfarm' 20:45:37 Cloning into 'ros_buildfarm'... 20:45:39 + git -C ros_buildfarm --no-pager log -n 1 20:45:39 commit d123759755a1211d96b32ba87781c29d9b3a6f3f 20:45:39 Author: Marc Hanheide <marc@hanheide.net> 20:45:39 Date: Mon Mar 9 21:12:45 2020 +0000 20:45:39 20:45:39 Merge pull request #3 from LCAS/lcas_new 20:45:39 20:45:39 many required fixed 20:45:39 + rm -fr ros_buildfarm/.git 20:45:39 + rm -fr ros_buildfarm/doc 20:45:39 + echo # END SECTION 20:45:39 # END SECTION20:45:39 [Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source] $ /bin/sh -xe /tmp/jenkins6701242294100363227.sh 20:45:39 + rm -fr /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/docker_sourcedeb 20:45:39 + mkdir -p /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/docker_sourcedeb 20:45:39 + sleep 1 20:45:39 + python3 -u /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/ros_buildfarm/scripts/subprocess_reaper.py 10763 --cid-file /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/docker_sourcedeb/docker.cid 20:45:40 + echo # BEGIN SECTION: Generate Dockerfile - sourcedeb task7. Write PGP repository keysHide Details
20:45:39 # BEGIN SECTION: Write PGP repository keys 20:45:39 + mkdir -p /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/keys 20:45:39 + rm -fr /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/keys/0.key /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/keys/1.key 20:45:39 + echo -----BEGIN PGP PUBLIC KEY BLOCK----- 20:45:39 Version: GnuPG v1.4.11 (GNU/Linux) 20:45:39 20:45:39 mQENBFPzE4sBCAC9c8hzt+gqe6YqXAW9Yd10jx68M0q8IowAe182yVtIvYf5l+qn 20:45:39 MsXiDUz4l7c1TcRpdzZ1WwEQoNNjQKq51ip2Ln3Uhri/GsPBk+psIJPt5AeXYrSf 20:45:39 xcDs8k4FMWgJtYMlZLuNk1YPaS6Vf1+Ygbe0u+ssORWg3cWhgLWPDydXdlhinUgw 20:45:39 kPd9ZYi8aaAxi94DMuOnAjItfPbuX52NHmPR2cXuh3fZklhA6cCGRYkSVqijKhEv 20:45:39 /o8fTnjcTama8ml5jnaAhcZ/4UV3terLeXEQn3+WM+VbTsEr58zca5fOv8MjC+Uh 20:45:39 EBgDgnHb8/n7OgSUvv9efQgYXBRQ1mD//JaZABEBAAG0LE1hcmMgSGFuaGVpZGUg 20:45:39 KFJPU0J1aWxkKSA8bWFyY0BoYW5oZWlkZS5uZXQ+iQE4BBMBAgAiBQJT8xOLAhsD 20:45:39 BgsJCAcDAgYVCAIJCgsEFgIDAQIeAQIXgAAKCRDc10MYrtOYVB9cCACQwB9auPEX 20:45:39 yQdVwliJMLwVihKz0AU0UCG6qra2pdXx9l5kgkQCuDV5FQqMpk/MIJPn8Zj0l1MI 20:45:39 7Yn/EAqBhXjtO2BcTuUC/9epzt1p3C++vK7RSsBDXfKzZN22apIUT0njOkL9Vuoy 20:45:39 JjFetmLDaZVbmFU+4ZaX3CFtBL3ewlFiT7G6StKj40JI8QJOlDOziX2OUsqZaI2T 20:45:39 Yh681980od3f2OfV3LPVroz7xnyECDfBaPBPaDdb8XWSNVLhuyglb15eewK0hj++ 20:45:39 Cut3swWH02Y3yVhzFBnosqqjyzPLBQeDMOoHAPpJHRgprfIRDoUkWAXO5re3GIUQ 20:45:39 cvk0d1I1jh3luQENBFPzE4sBCACmSxiM1vpPI7BpgUNAhu0B8SWptULpiYOnDHfM 20:45:39 hU1u95Z5Lu/hy3sfm4BEKgLju7Y1I3jToWTwJJzgWZRr+iuuwj3fbfHCISYIK7f3 20:45:39 IWGL2iM2+kLIH6E9oqRgGbJmhiwbz6OokxG0W7atdqpBxOKqhaH0AH3qRicwnuPm 20:45:39 Z4/mNHYQ0vBffENewujn1bCAz4C1WB66/AXBYF8dpCP42qB5yK7FRNv4JubMmqhK 20:45:39 7fkD88uu7JVGRYU+temWuJHH4WDxiCmvK8nXacFaZT1NGdTL9/2EukKLguTtZumb 20:45:39 oRWgFqV6WFcEnh/V/Ma51D2+K9QbCWa8Bb6c/wKOd9Ii1aDZABEBAAGJAR8EGAEC 20:45:39 AAkFAlPzE4sCGwwACgkQ3NdDGK7TmFT2rwf+MzLFPn4Rkko38nctysbXm6qmk34U 20:45:39 NTtqirOlxg3mWeUCp7VQGU2Rg2msdo764SxCK12OhJqlXGMd2efCoQhYbMOqG6C0 20:45:39 ikBZPkd5BVFuTKsAUiuVoiQd8bDaZSpO2QdE0RdHE/yYfO66pceEKkGlcjkTRFFU 20:45:39 M7nTm7IQj4BBZclMLPr4fX520ZOVUepxAARMHW5A6EcHXvhXmblZOJM36fOv3T5N 20:45:39 l9L5tWdt/wybaRE4xuwVSs0n7MyMlWmkQxz8Z6OQscbKmuI4tcYSbvvB5tzjLBwZ 20:45:39 Chb0eEZA5ePvnGofu+3JH48FmCIPveD+4kI9GhtGkCL3Q2PiPiLcSnWQWQ== 20:45:39 =nFcN 20:45:39 -----END PGP PUBLIC KEY BLOCK----- 20:45:39 20:45:39 + echo -----BEGIN PGP PUBLIC KEY BLOCK----- 20:45:39 Version: SKS 1.1.6 20:45:39 Comment: Hostname: keyserver.ubuntu.com 20:45:39 20:45:39 mQINBFzvJpYBEADY8l1YvO7iYW5gUESyzsTGnMvVUmlV3XarBaJz9bGRmgPXh7jcVFrQhE0L 20:45:39 /HV7LOfoLI9H2GWYyHBqN5ERBlcA8XxG3ZvX7t9nAZPQT2Xxe3GT3trou5oCR+SyHN9xPnUw 20:45:39 DuqUSvJ2eqMYb9B/Hph3OmtjG30jSNq9kOF5bBTk1hOTGPH4K/AY0jzT6OpHfXU6ytlFsI47 20:45:39 ZKsnTUhipGsKucQ1CXlyirndZ3V3k70YaooZ55rGaIoAWlx2H0J7sAHmqS29N9jV9mo135d+ 20:45:39 d+TdLBXI0PXtiHzE9IPaX+ctdSUrPnp+TwR99lxglpIG6hLuvOMAaxiqFBB/Jf3XJ8OBakfS 20:45:39 6nHrWH2WqQxRbiITl0irkQozpwNEF2Bv0+Jvs1UFEdVGz5a8xexQHst/RmKrtHLct3iOCvBN 20:45:39 qoAQRbvWvBhPjO/pV5cYeUljZ5wpHyFkaEViClaVWqa6PIsyLqmyjsruPCWlURLsQoQxABcL 20:45:39 8bwxX7UThM6CtH6tGlYZ85RIzRifIm2oudzV5l+8oRgFr9yVcwyOFT6JCioqkwldW52P1pk/ 20:45:39 /SnuexC6LYqqDuHUs5NnokzzpfS6QaWfTY5P5tz4KHJfsjDIktly3mKVfY0fSPVVokdGpcUz 20:45:39 vz2hq1fqjxB6MlB/1vtk0bImfcsoxBmF7H+4E9ZN1sX/tSb0KQARAQABtCZPcGVuIFJvYm90 20:45:39 aWNzIDxpbmZvQG9zcmZvdW5kYXRpb24ub3JnPokCVAQTAQoAPhYhBMHPbjHmut6IaLFytPQu 20:45:39 1vurF8ZUBQJc7yaWAhsDBQkDwmcABQsJCAcCBhUKCQgLAgQWAgMBAh4BAheAAAoJEPQu1vur 20:45:39 F8ZUkhIP/RbZY1ErvCEUy8iLJm9aSpLQnDZl5xILOxyZlzpg+Ml5bb0EkQDr92foCgcvLeAN 20:45:39 KARNCaGLyNIWkuyDovPV0xZJrEy0kgBrDNb3++NmdI/+GA92pkedMXXioQvqdsxUagXAIB/s 20:45:39 NGByJEhs37F05AnFvZbjUhceq3xTlvAMcrBWrgB4NwBivZY6IgLvl/CRQpVYwANShIQdbvHv 20:45:39 ZSxRonWhNXr6v/Wcf8rsp7g2VqJ2N2AcWT84aa9BLQ3Oe/SgrNx4QEhA1y7rc3oaqPVu5ZXO 20:45:39 K+4O14JrpbEZ3Xs9YEjrcOuEDEpYktA8qqUDTdFyZrxb9S6BquUKrA6jZgT913kjJ4e7YAZo 20:45:39 bC4rH0w4u0PrqDgYOkXA9Mo7L601/7ZaDJob80UcK+Z12ZSw73IgBix6DiJVfXuWkk5PM2zs 20:45:39 Fn6UOQXUNlZlDAOj5NC01V0fJ8P0v6GO9YOSSQx0j5UtkUbRfp/4W7uCPFvwAatWEHJhlM3s 20:45:39 QNiMNStJFegr56xQu1a/cbJH7GdbseMhG/f0BaKQqXCI3ffB5y5AOLc9Hw7PYiTFQsuY1ePR 20:45:39 hE+J9mejgWRZxkjAH/FlAubqXkDgterCh+sLkzGf+my2IbsMCuc+3aeNMJ5Ej/vlXefCH/Mp 20:45:39 PWAHCqpQhe2DET/jRSaM53USAHNx8kw4MPUkxExgI7Sd 20:45:39 =4Ofr 20:45:39 -----END PGP PUBLIC KEY BLOCK----- 20:45:39 20:45:39 + echo # END SECTION 20:45:39 # END SECTION20:45:41 + echo # BEGIN SECTION: Build Dockerfile - generate sourcedeb8. Generate Dockerfile - sourcedeb taskHide Details
20:45:40 # BEGIN SECTION: Generate Dockerfile - sourcedeb task 20:45:40 + export TZ=GMT+00 20:45:40 + export PYTHONPATH=/home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/ros_buildfarm: 20:45:40 + python3 -u /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/ros_buildfarm/scripts/release/run_sourcedeb_job.py --rosdistro-index-url https://raw.githubusercontent.com/LCAS/rosdistro/master/index.yaml melodic image_to_v4l2loopback ubuntu bionic --distribution-repository-urls http://10.210.9.154/ubuntu/building http://packages.ros.org/ros/ubuntu --distribution-repository-key-files /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/keys/0.key /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/keys/1.key --source-dir /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/sourcedeb/source --dockerfile-dir /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/docker_sourcedeb 20:45:41 Using the following distribution repositories: 20:45:41 http://10.210.9.154/ubuntu/building (/home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/keys/0.key) 20:45:41 http://packages.ros.org/ros/ubuntu (/home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/keys/1.key) 20:45:41 Generating Dockerfile '/home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/docker_sourcedeb/Dockerfile': 20:45:41 # generated from release/sourcedeb_task.Dockerfile.em 20:45:41 20:45:41 FROM ubuntu:bionic 20:45:41 20:45:41 VOLUME ["/var/cache/apt/archives"] 20:45:41 20:45:41 ENV DEBIAN_FRONTEND noninteractive 20:45:41 20:45:41 20:45:41 RUN for i in 1 2 3; do apt-get update && apt-get install -q -y locales && apt-get clean && break || if [ $i -lt 3 ]; then sleep 5; else false; fi; done 20:45:41 RUN echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen 20:45:41 RUN locale-gen en_US.UTF-8 20:45:41 ENV LANG en_US.UTF-8 20:45:41 ENV TZ GMT+00 20:45:41 20:45:41 RUN useradd -u 1002 -l -m buildfarm 20:45:41 20:45:41 RUN mkdir /tmp/keys 20:45:41 RUN for i in 1 2 3; do apt-get update && apt-get install -q -y gnupg && apt-get clean && break || if [ $i -lt 3 ]; then sleep 5; else false; fi; done 20:45:41 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 20:45:41 RUN echo "-----BEGIN PGP PUBLIC KEY BLOCK-----\nVersion: SKS 1.1.6\nComment: Hostname: keyserver.ubuntu.com\n\nmQINBFzvJpYBEADY8l1YvO7iYW5gUESyzsTGnMvVUmlV3XarBaJz9bGRmgPXh7jcVFrQhE0L\n/HV7LOfoLI9H2GWYyHBqN5ERBlcA8XxG3ZvX7t9nAZPQT2Xxe3GT3trou5oCR+SyHN9xPnUw\nDuqUSvJ2eqMYb9B/Hph3OmtjG30jSNq9kOF5bBTk1hOTGPH4K/AY0jzT6OpHfXU6ytlFsI47\nZKsnTUhipGsKucQ1CXlyirndZ3V3k70YaooZ55rGaIoAWlx2H0J7sAHmqS29N9jV9mo135d+\nd+TdLBXI0PXtiHzE9IPaX+ctdSUrPnp+TwR99lxglpIG6hLuvOMAaxiqFBB/Jf3XJ8OBakfS\n6nHrWH2WqQxRbiITl0irkQozpwNEF2Bv0+Jvs1UFEdVGz5a8xexQHst/RmKrtHLct3iOCvBN\nqoAQRbvWvBhPjO/pV5cYeUljZ5wpHyFkaEViClaVWqa6PIsyLqmyjsruPCWlURLsQoQxABcL\n8bwxX7UThM6CtH6tGlYZ85RIzRifIm2oudzV5l+8oRgFr9yVcwyOFT6JCioqkwldW52P1pk/\n/SnuexC6LYqqDuHUs5NnokzzpfS6QaWfTY5P5tz4KHJfsjDIktly3mKVfY0fSPVVokdGpcUz\nvz2hq1fqjxB6MlB/1vtk0bImfcsoxBmF7H+4E9ZN1sX/tSb0KQARAQABtCZPcGVuIFJvYm90\naWNzIDxpbmZvQG9zcmZvdW5kYXRpb24ub3JnPokCVAQTAQoAPhYhBMHPbjHmut6IaLFytPQu\n1vurF8ZUBQJc7yaWAhsDBQkDwmcABQsJCAcCBhUKCQgLAgQWAgMBAh4BAheAAAoJEPQu1vur\nF8ZUkhIP/RbZY1ErvCEUy8iLJm9aSpLQnDZl5xILOxyZlzpg+Ml5bb0EkQDr92foCgcvLeAN\nKARNCaGLyNIWkuyDovPV0xZJrEy0kgBrDNb3++NmdI/+GA92pkedMXXioQvqdsxUagXAIB/s\nNGByJEhs37F05AnFvZbjUhceq3xTlvAMcrBWrgB4NwBivZY6IgLvl/CRQpVYwANShIQdbvHv\nZSxRonWhNXr6v/Wcf8rsp7g2VqJ2N2AcWT84aa9BLQ3Oe/SgrNx4QEhA1y7rc3oaqPVu5ZXO\nK+4O14JrpbEZ3Xs9YEjrcOuEDEpYktA8qqUDTdFyZrxb9S6BquUKrA6jZgT913kjJ4e7YAZo\nbC4rH0w4u0PrqDgYOkXA9Mo7L601/7ZaDJob80UcK+Z12ZSw73IgBix6DiJVfXuWkk5PM2zs\nFn6UOQXUNlZlDAOj5NC01V0fJ8P0v6GO9YOSSQx0j5UtkUbRfp/4W7uCPFvwAatWEHJhlM3s\nQNiMNStJFegr56xQu1a/cbJH7GdbseMhG/f0BaKQqXCI3ffB5y5AOLc9Hw7PYiTFQsuY1ePR\nhE+J9mejgWRZxkjAH/FlAubqXkDgterCh+sLkzGf+my2IbsMCuc+3aeNMJ5Ej/vlXefCH/Mp\nPWAHCqpQhe2DET/jRSaM53USAHNx8kw4MPUkxExgI7Sd\n=4Ofr\n-----END PGP PUBLIC KEY BLOCK-----\n" > /tmp/keys/1.key && apt-key add /tmp/keys/1.key 20:45:41 RUN echo deb http://10.210.9.154/ubuntu/building bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list 20:45:41 RUN echo deb http://packages.ros.org/ros/ubuntu bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list 20:45:41 20:45:41 RUN mkdir /tmp/wrapper_scripts 20:45:41 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 'Failed to stat',\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 'has no installation candidate',\n 'corrupted package archive',\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('')\n print('Invocation failed due to the following known error '\n 'conditions: ' + ', '.join(known_error_conditions))\n print('')\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 20:45:41 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 20:45:41 20:45:41 # automatic invalidation once every day 20:45:41 RUN echo "2020-04-02 (+0000)" 20:45:41 20:45:41 RUN for i in 1 2 3; do apt-get update && apt-get install -q -y python3 && apt-get clean && break || if [ $i -lt 3 ]; then sleep 5; else false; fi; done 20:45:41 20:45:41 RUN python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y dh-python 20:45:41 20:45:41 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 20:45:41 20:45:41 COPY .git-credentials /home/buildfarm/.git-credentials 20:45:41 RUN chmod 600 /home/buildfarm/.git-credentials 20:45:41 RUN chown buildfarm /home/buildfarm/.git-credentials 20:45:41 20:45:41 USER buildfarm 20:45:41 RUN git config --global credential.helper 'store' 20:45:41 RUN git config --global http.sslVerify false 20:45:41 20:45:41 ENTRYPOINT ["sh", "-c"] 20:45:41 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 melodic image_to_v4l2loopback ubuntu bionic 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 bionic --source-dir /tmp/sourcedeb/source"] 20:45:41 + echo # END SECTION 20:45:41 # END SECTION20:45:43 + echo # BEGIN SECTION: Run Dockerfile - generate sourcedeb9. Build Dockerfile - generate sourcedebHide Details
20:45:41 # BEGIN SECTION: Build Dockerfile - generate sourcedeb 20:45:41 + cd /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/docker_sourcedeb 20:45:41 + cp -L **** /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/docker_sourcedeb/.git-credentials 20:45:41 + python3 -u /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/ros_buildfarm/scripts/misc/docker_pull_baseimage.py 20:45:41 Get base image name from Dockerfile 'Dockerfile': ubuntu:bionic 20:45:41 Check docker base image for updates: docker pull ubuntu:bionic 20:45:43 bionic: Pulling from library/ubuntu 20:45:43 Digest: sha256:bec5a2727be7fff3d308193cfde3491f8fba1a2ba392b7546b43a051853a341d 20:45:43 Status: Image is up to date for ubuntu:bionic 20:45:43 + docker build --force-rm -t sourcedeb.melodic_ubuntu_bionic_image_to_v4l2loopback . 20:45:43 Sending build context to Docker daemon 18.94kB 20:45:43 Step 1/30 : FROM ubuntu:bionic 20:45:43 ---> 4e5021d210f6 20:45:43 Step 2/30 : VOLUME /var/cache/apt/archives 20:45:43 ---> Using cache 20:45:43 ---> df7c84159595 20:45:43 Step 3/30 : ENV DEBIAN_FRONTEND noninteractive 20:45:43 ---> Using cache 20:45:43 ---> 59b0c94a00fe 20:45:43 Step 4/30 : RUN for i in 1 2 3; do apt-get update && apt-get install -q -y locales && apt-get clean && break || if [ $i -lt 3 ]; then sleep 5; else false; fi; done 20:45:43 ---> Using cache 20:45:43 ---> c27f478e278a 20:45:43 Step 5/30 : RUN echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen 20:45:43 ---> Using cache 20:45:43 ---> caf2d8a00919 20:45:43 Step 6/30 : RUN locale-gen en_US.UTF-8 20:45:43 ---> Using cache 20:45:43 ---> f0ee70252c6d 20:45:43 Step 7/30 : ENV LANG en_US.UTF-8 20:45:43 ---> Using cache 20:45:43 ---> e5a97b0611bb 20:45:43 Step 8/30 : ENV TZ GMT+00 20:45:43 ---> Using cache 20:45:43 ---> 5c14d75cad4c 20:45:43 Step 9/30 : RUN useradd -u 1002 -l -m buildfarm 20:45:43 ---> Using cache 20:45:43 ---> c8fbf7adaa18 20:45:43 Step 10/30 : RUN mkdir /tmp/keys 20:45:43 ---> Using cache 20:45:43 ---> 1849328c7675 20:45:43 Step 11/30 : RUN for i in 1 2 3; do apt-get update && apt-get install -q -y gnupg && apt-get clean && break || if [ $i -lt 3 ]; then sleep 5; else false; fi; done 20:45:43 ---> Using cache 20:45:43 ---> 6e6ab279d32b 20:45:43 Step 12/30 : 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 20:45:43 ---> Using cache 20:45:43 ---> e3dd9cf3da06 20:45:43 Step 13/30 : RUN echo "-----BEGIN PGP PUBLIC KEY BLOCK-----\nVersion: SKS 1.1.6\nComment: Hostname: keyserver.ubuntu.com\n\nmQINBFzvJpYBEADY8l1YvO7iYW5gUESyzsTGnMvVUmlV3XarBaJz9bGRmgPXh7jcVFrQhE0L\n/HV7LOfoLI9H2GWYyHBqN5ERBlcA8XxG3ZvX7t9nAZPQT2Xxe3GT3trou5oCR+SyHN9xPnUw\nDuqUSvJ2eqMYb9B/Hph3OmtjG30jSNq9kOF5bBTk1hOTGPH4K/AY0jzT6OpHfXU6ytlFsI47\nZKsnTUhipGsKucQ1CXlyirndZ3V3k70YaooZ55rGaIoAWlx2H0J7sAHmqS29N9jV9mo135d+\nd+TdLBXI0PXtiHzE9IPaX+ctdSUrPnp+TwR99lxglpIG6hLuvOMAaxiqFBB/Jf3XJ8OBakfS\n6nHrWH2WqQxRbiITl0irkQozpwNEF2Bv0+Jvs1UFEdVGz5a8xexQHst/RmKrtHLct3iOCvBN\nqoAQRbvWvBhPjO/pV5cYeUljZ5wpHyFkaEViClaVWqa6PIsyLqmyjsruPCWlURLsQoQxABcL\n8bwxX7UThM6CtH6tGlYZ85RIzRifIm2oudzV5l+8oRgFr9yVcwyOFT6JCioqkwldW52P1pk/\n/SnuexC6LYqqDuHUs5NnokzzpfS6QaWfTY5P5tz4KHJfsjDIktly3mKVfY0fSPVVokdGpcUz\nvz2hq1fqjxB6MlB/1vtk0bImfcsoxBmF7H+4E9ZN1sX/tSb0KQARAQABtCZPcGVuIFJvYm90\naWNzIDxpbmZvQG9zcmZvdW5kYXRpb24ub3JnPokCVAQTAQoAPhYhBMHPbjHmut6IaLFytPQu\n1vurF8ZUBQJc7yaWAhsDBQkDwmcABQsJCAcCBhUKCQgLAgQWAgMBAh4BAheAAAoJEPQu1vur\nF8ZUkhIP/RbZY1ErvCEUy8iLJm9aSpLQnDZl5xILOxyZlzpg+Ml5bb0EkQDr92foCgcvLeAN\nKARNCaGLyNIWkuyDovPV0xZJrEy0kgBrDNb3++NmdI/+GA92pkedMXXioQvqdsxUagXAIB/s\nNGByJEhs37F05AnFvZbjUhceq3xTlvAMcrBWrgB4NwBivZY6IgLvl/CRQpVYwANShIQdbvHv\nZSxRonWhNXr6v/Wcf8rsp7g2VqJ2N2AcWT84aa9BLQ3Oe/SgrNx4QEhA1y7rc3oaqPVu5ZXO\nK+4O14JrpbEZ3Xs9YEjrcOuEDEpYktA8qqUDTdFyZrxb9S6BquUKrA6jZgT913kjJ4e7YAZo\nbC4rH0w4u0PrqDgYOkXA9Mo7L601/7ZaDJob80UcK+Z12ZSw73IgBix6DiJVfXuWkk5PM2zs\nFn6UOQXUNlZlDAOj5NC01V0fJ8P0v6GO9YOSSQx0j5UtkUbRfp/4W7uCPFvwAatWEHJhlM3s\nQNiMNStJFegr56xQu1a/cbJH7GdbseMhG/f0BaKQqXCI3ffB5y5AOLc9Hw7PYiTFQsuY1ePR\nhE+J9mejgWRZxkjAH/FlAubqXkDgterCh+sLkzGf+my2IbsMCuc+3aeNMJ5Ej/vlXefCH/Mp\nPWAHCqpQhe2DET/jRSaM53USAHNx8kw4MPUkxExgI7Sd\n=4Ofr\n-----END PGP PUBLIC KEY BLOCK-----\n" > /tmp/keys/1.key && apt-key add /tmp/keys/1.key 20:45:43 ---> Using cache 20:45:43 ---> 70778070df25 20:45:43 Step 14/30 : RUN echo deb http://10.210.9.154/ubuntu/building bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list 20:45:43 ---> Using cache 20:45:43 ---> ab533b0a05e7 20:45:43 Step 15/30 : RUN echo deb http://packages.ros.org/ros/ubuntu bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list 20:45:43 ---> Using cache 20:45:43 ---> aa21e6326d50 20:45:43 Step 16/30 : RUN mkdir /tmp/wrapper_scripts 20:45:43 ---> Using cache 20:45:43 ---> 4c07c70a260f 20:45:43 Step 17/30 : 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 'Failed to stat',\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 'has no installation candidate',\n 'corrupted package archive',\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('')\n print('Invocation failed due to the following known error '\n 'conditions: ' + ', '.join(known_error_conditions))\n print('')\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 20:45:43 ---> Using cache 20:45:43 ---> 3899ea0707c5 20:45:43 Step 18/30 : 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 20:45:43 ---> Using cache 20:45:43 ---> c85d5b6f2ca7 20:45:43 Step 19/30 : RUN echo "2020-04-02 (+0000)" 20:45:43 ---> Using cache 20:45:43 ---> fc9877046fe3 20:45:43 Step 20/30 : RUN for i in 1 2 3; do apt-get update && apt-get install -q -y python3 && apt-get clean && break || if [ $i -lt 3 ]; then sleep 5; else false; fi; done 20:45:43 ---> Using cache 20:45:43 ---> 55f000d9de18 20:45:43 Step 21/30 : RUN python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y dh-python 20:45:43 ---> Using cache 20:45:43 ---> 650f79dc3ddc 20:45:43 Step 22/30 : 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 20:45:43 ---> Using cache 20:45:43 ---> 74874909b4af 20:45:43 Step 23/30 : COPY .git-credentials /home/buildfarm/.git-credentials 20:45:43 ---> Using cache 20:45:43 ---> 98424d8c5af2 20:45:43 Step 24/30 : RUN chmod 600 /home/buildfarm/.git-credentials 20:45:43 ---> Using cache 20:45:43 ---> eea25c574482 20:45:43 Step 25/30 : RUN chown buildfarm /home/buildfarm/.git-credentials 20:45:43 ---> Using cache 20:45:43 ---> 6acb12824662 20:45:43 Step 26/30 : USER buildfarm 20:45:43 ---> Using cache 20:45:43 ---> 353bb89b3723 20:45:43 Step 27/30 : RUN git config --global credential.helper 'store' 20:45:43 ---> Using cache 20:45:43 ---> 55dce26775ea 20:45:43 Step 28/30 : RUN git config --global http.sslVerify false 20:45:43 ---> Using cache 20:45:43 ---> 11509321af24 20:45:43 Step 29/30 : ENTRYPOINT sh -c 20:45:43 ---> Using cache 20:45:43 ---> 3751b30a8103 20:45:43 Step 30/30 : 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 melodic image_to_v4l2loopback ubuntu bionic 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 bionic --source-dir /tmp/sourcedeb/source 20:45:43 ---> Using cache 20:45:43 ---> bc37b22caa80 20:45:43 Successfully built bc37b22caa80 20:45:43 Successfully tagged sourcedeb.melodic_ubuntu_bionic_image_to_v4l2loopback:latest 20:45:43 + echo # END SECTION 20:45:43 # END SECTION20:45:59 [Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source] $ /bin/sh -xe /tmp/jenkins6190830432896366864.sh 20:45:59 + [ false = false ] 20:45:59 + echo # BEGIN SECTION: Clean up to save disk space on agents10. Run Dockerfile - generate sourcedebHide Details
20:45:43 # BEGIN SECTION: Run Dockerfile - generate sourcedeb 20:45:43 + rm -fr /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/sourcedeb 20:45:43 + mkdir -p /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/sourcedeb/source 20:45:43 + docker run --rm --cidfile=/home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/docker_sourcedeb/docker.cid -e=TRAVIS= --net=host -v /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/ros_buildfarm:/tmp/ros_buildfarm:ro -v /home/jenkins-slave/workspace/Msrc_uB__image_to_v4l2loopback__ubuntu_bionic__source/sourcedeb:/tmp/sourcedeb sourcedeb.melodic_ubuntu_bionic_image_to_v4l2loopback10.1. get sourcesHide Details
20:45:44 # BEGIN SUBSECTION: get sources 20:45:51 Invoking 'git clone --branch debian/ros-melodic-image-to-v4l2loopback_0.1.2-1_bionic --depth 1 --no-single-branch https://github.com/lcas-releases/image_to_v4l2loopback.git /tmp/sourcedeb/source' 20:45:51 Cloning into '/tmp/sourcedeb/source'... 20:45:52 Note: checking out '6f106021b832de0cb6602c46b0e0841365de6e5d'. 20:45:52 20:45:52 You are in 'detached HEAD' state. You can look around, make experimental 20:45:52 changes and commit them, and you can discard any commits you make in this 20:45:52 state without impacting any branches by performing another checkout. 20:45:52 20:45:52 If you want to create a new branch to retain commits you create, you may 20:45:52 do so (now or later) by using -b with the checkout command again. Example: 20:45:52 20:45:52 git checkout -b <new-branch-name> 20:45:52 20:45:53 No tarball found at 'http://10.210.9.154/ubuntu/building/pool/main/r/ros-melodic-image-to-v4l2loopback/ros-melodic-image-to-v4l2loopback_0.1.2.orig.tar.gz' 20:45:53 No tarball found at 'http://packages.ros.org/ros/ubuntu/pool/main/r/ros-melodic-image-to-v4l2loopback/ros-melodic-image-to-v4l2loopback_0.1.2.orig.tar.gz' 20:45:53 Package 'image_to_v4l2loopback' version: 0.1.2-1bionic 20:45:53 Package maintainer emails: marc@hanheide.net 20:45:53 # END SUBSECTION20:45:59 + echo # END SECTION 20:45:59 # END SECTION10.2. build sourcedebHide Details
20:45:53 # BEGIN SUBSECTION: build sourcedeb 20:45:53 Invoking 'gbp buildpackage --git-ignore-new --git-ignore-branch -S -d -ui -us -uc --lintian-opts --suppress-tags newer-standards-version' in '/tmp/sourcedeb/source' 20:45:53 gbp:warning: Old style config section [git-buildpackage] found please rename to [buildpackage] 20:45:54 gbp:info: Creating ros-melodic-image-to-v4l2loopback_0.1.2.orig.tar.gz from 'release/melodic/image_to_v4l2loopback/0.1.2-1' 20:45:54 gbp:info: Performing the build 20:45:54 dpkg-buildpackage -rfakeroot -us -uc -ui -i -I -S -d 20:45:54 dpkg-buildpackage: info: source package ros-melodic-image-to-v4l2loopback 20:45:54 dpkg-buildpackage: info: source version 0.1.2-1bionic 20:45:54 dpkg-buildpackage: info: source distribution bionic 20:45:54 dpkg-buildpackage: info: source changed by Marc Hanheide <marc@hanheide.net> 20:45:54 dpkg-source -i -I --before-build source 20:45:55 dpkg-source: info: using options from source/debian/source/options: --auto-commit 20:45:55 fakeroot debian/rules clean 20:45:55 dh clean -v --buildsystem=cmake 20:45:55 dh_testdir -O-v -O--buildsystem=cmake 20:45:55 dh_auto_clean -O-v -O--buildsystem=cmake 20:45:55 dh_clean -O-v -O--buildsystem=cmake 20:45:55 rm -f debian/debhelper-build-stamp 20:45:55 rm -rf debian/.debhelper/ 20:45:55 rm -f -- debian/ros-melodic-image-to-v4l2loopback.substvars debian/files 20:45:55 rm -fr -- debian/ros-melodic-image-to-v4l2loopback/ debian/tmp/ 20:45:55 find . \( \( \ 20:45:55 \( -path .\*/.git -o -path .\*/.svn -o -path .\*/.bzr -o -path .\*/.hg -o -path .\*/CVS -o -path .\*/.pc -o -path .\*/_darcs \) -prune -o -type f -a \ 20:45:55 \( -name '#*#' -o -name '.*~' -o -name '*~' -o -name DEADJOE \ 20:45:55 -o -name '*.orig' -o -name '*.rej' -o -name '*.bak' \ 20:45:55 -o -name '.*.orig' -o -name .*.rej -o -name '.SUMS' \ 20:45:55 -o -name TAGS -o \( -path '*/.deps/*' -a -name '*.P' \) \ 20:45:55 \) -exec rm -f {} + \) -o \ 20:45:55 \( -type d -a -name autom4te.cache -prune -exec rm -rf {} + \) \) 20:45:55 dpkg-source -i -I -b source 20:45:56 dpkg-source: info: using options from source/debian/source/options: --auto-commit 20:45:56 dpkg-source: info: using source format '3.0 (quilt)' 20:45:56 dpkg-source: info: building ros-melodic-image-to-v4l2loopback using existing ./ros-melodic-image-to-v4l2loopback_0.1.2.orig.tar.gz 20:45:56 dpkg-source: info: building ros-melodic-image-to-v4l2loopback in ros-melodic-image-to-v4l2loopback_0.1.2-1bionic.debian.tar.xz 20:45:56 dpkg-source: info: building ros-melodic-image-to-v4l2loopback in ros-melodic-image-to-v4l2loopback_0.1.2-1bionic.dsc 20:45:56 dpkg-genbuildinfo --build=source 20:45:56 dpkg-genchanges --build=source >../ros-melodic-image-to-v4l2loopback_0.1.2-1bionic_source.changes 20:45:56 dpkg-genchanges: info: including full source code in upload 20:45:56 dpkg-source -i -I --after-build source 20:45:56 dpkg-source: info: using options from source/debian/source/options: --auto-commit 20:45:56 dpkg-buildpackage: info: full upload (original source is included) 20:45:56 Now running lintian --suppress-tags newer-standards-version ros-melodic-image-to-v4l2loopback_0.1.2-1bionic_source.changes ... 20:45:58 E: ros-melodic-image-to-v4l2loopback source: latest-debian-changelog-entry-without-new-date 20:45:58 W: ros-melodic-image-to-v4l2loopback source: no-debian-copyright 20:45:58 W: ros-melodic-image-to-v4l2loopback source: ancient-standards-version 3.9.2 (released 2011-04-07) (current is 4.1.4) 20:45:59 Finished running lintian. 20:45:59 # END SUBSECTION20:45:59 SSH: Connecting from host [lcas-buildfarm-slave-1] 20:45:59 SSH: Connecting with configuration [repo] ... 20:46:00 SSH: Disconnecting configuration [repo] ... 20:46:00 SSH: Transferred 5 file(s) 20:46:00 Build step 'Send files or execute commands over SSH' changed build result to SUCCESS 20:46:00 Waiting for the completion of Mrel_import-package 20:46:00 Mrel_import-package #358 started. 20:46:12 Mrel_import-package #358 completed. Result was SUCCESS11. Clean up to save disk space on agentsHide Details
20:45:59 # BEGIN SECTION: Clean up to save disk space on agents 20:45:59 + rm -fr sourcedeb/source 20:45:59 + echo # END SECTION 20:45:59 # END SECTION20:46:12 $ ssh-agent -k 20:46:12 unset SSH_AUTH_SOCK; 20:46:12 unset SSH_AGENT_PID; 20:46:12 echo Agent pid 10326 killed; 20:46:12 [ssh-agent] Stopped. 20:46:12 [description-setter] Description set: 0.1.2-1bionic 20:46:12 Triggering a new build of Mbin_uB64__image_to_v4l2loopback__ubuntu_bionic_amd64__binary 20:46:12 Finished: SUCCESS12. Check if triggered build failedHide Details
20:46:12 # BEGIN SECTION: Check if triggered build failed 20:46:12 Pattern not found in build log, continuing... 20:46:12 # END SECTION