19:00:45# BEGIN SECTION: Check upstream projects
19:00:45Verify that no recursive upstream project is broken:
19:00:4519:00:45- 'Mbin_uB64__turtlebot_actions__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__turtlebot_bringup__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__kobuki_bumper2pc__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__kobuki_msgs__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__kobuki_msgs__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__kobuki_bumper2pc__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__kobuki_node__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__kobuki_keyop__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__yocs_cmd_vel_mux__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__yocs_cmd_vel_mux__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__kobuki_keyop__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__kobuki_safety_controller__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__yocs_controllers__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__yocs_controllers__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__kobuki_safety_controller__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__kobuki_node__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__turtlebot_capabilities__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__turtlebot_capabilities__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__turtlebot_description__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__kobuki_description__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__kobuki_description__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__turtlebot_description__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__turtlebot_bringup__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__turtlebot_actions__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45- 'Mbin_uB64__turtlebot_calibration__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__turtlebot_calibration__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45- 'Mbin_uB64__turtlebot_follower__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__turtlebot_msgs__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__turtlebot_msgs__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__turtlebot_teleop__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__turtlebot_teleop__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__turtlebot_follower__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45- 'Mbin_uB64__turtlebot_navigation__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__turtlebot_navigation__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45- 'Mbin_uB64__turtlebot_rapps__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Mbin_uB64__robot_pose_publisher__ubuntu_bionic_amd64__binary' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__robot_pose_publisher__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45 - 'Msrc_uB__turtlebot_rapps__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45- 'Msrc_uB__turtlebot_apps__ubuntu_bionic__source' build '1' has result 'SUCCESS'
19:00:45All recursive upstream projects are (un)stable
19:00:45# END SECTION
19:00:45
2. Check free disk space
Hide Details
19:00:45# BEGIN SECTION: Check free disk space
19:00:45Usable disk space = 79390445568 bytes
19:00:45Free space threshold = 5368709120 bytes
19:00:45# END SECTION
19:00:45[Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary] $ /bin/sh -xe /tmp/jenkins837951548716161131.sh
19:00:45+ echo # BEGIN SECTION: docker version
3. docker version
Hide Details
19:00:45# BEGIN SECTION: docker version
19:00:45+ docker version
19:00:45Client:
19:00:45 Version: 17.05.0-ce
19:00:45 API version: 1.29
19:00:45 Go version: go1.7.5
19:00:45 Git commit: 89658be
19:00:45 Built: Thu May 4 22:06:06 2017
19:00:45 OS/Arch: linux/amd64
19:00:4519:00:45Server:
19:00:45 Version: 17.05.0-ce
19:00:45 API version: 1.29 (minimum version 1.12)
19:00:45 Go version: go1.7.5
19:00:45 Git commit: 89658be
19:00:45 Built: Thu May 4 22:06:06 2017
19:00:45 OS/Arch: linux/amd64
19:00:45 Experimental: false
19:00:45+ echo # END SECTION
19:00:45# END SECTION
19:00:54# BEGIN SECTION: Embed wrapper scripts
19:00:54+ rm -fr wrapper_scripts
19:00:54+ mkdir wrapper_scripts
19:00:54+ 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())
19:00:54+ echo # END SECTION
19:00:54# END SECTION
19:00:59# BEGIN SECTION: Generate Dockerfile - binarydeb task
19:00:59+ export TZ=GMT+00
19:00:59+ export PYTHONPATH=/home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/ros_buildfarm:
19:00:59+ python3 -u /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/ros_buildfarm/scripts/release/run_binarydeb_job.py --rosdistro-index-url https://raw.githubusercontent.com/LCAS/rosdistro/master/index.yaml melodic turtlebot_apps ubuntu bionic amd64 --distribution-repository-urls http://10.210.9.154/ubuntu/buildinghttp://packages.ros.org/ros/ubuntu --distribution-repository-key-files /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/keys/0.key /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/keys/1.key --target-repository http://10.210.9.154/ubuntu/building --binarydeb-dir /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/binarydeb --dockerfile-dir /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/docker_generating_docker --env-vars --append-timestamp
19:00:59Using the following distribution repositories:
19:00:59http://10.210.9.154/ubuntu/building (/home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/keys/0.key)
19:00:59http://packages.ros.org/ros/ubuntu (/home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/keys/1.key)
19:00:59Generating Dockerfile '/home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/docker_generating_docker/Dockerfile':
19:00:59 # generated from release/binarydeb_create_task.Dockerfile.em
19:00:5919:00:59 FROM ubuntu:bionic
19:00:5919:00:59 VOLUME ["/var/cache/apt/archives"]
19:00:5919:00:59 ENV DEBIAN_FRONTEND noninteractive
19:00:5919:00:5919:00:59 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
19:00:59 RUN echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen
19:00:59 RUN locale-gen en_US.UTF-8
19:00:59 ENV LANG en_US.UTF-8
19:00:59 ENV TZ GMT+00
19:00:5919:00:5919:00:59 RUN useradd -u 1002 -l -m buildfarm
19:00:5919:00:59 RUN mkdir /tmp/keys
19:00:59 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
19:00:59 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
19:00:59 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
19:00:59 RUN echo deb http://10.210.9.154/ubuntu/building bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list
19:00:59 RUN echo deb-src http://10.210.9.154/ubuntu/building bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list
19:00:59 RUN echo deb http://packages.ros.org/ros/ubuntu bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list
19:00:5919:00:59 RUN grep -q -F -e "deb http://old-releases.ubuntu.com" /etc/apt/sources.list && ((grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list)) || ((grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list))
19:00:5919:00:59 RUN mkdir /tmp/wrapper_scripts
19:00:59 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
19:00:59 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
19:00:5919:00:59 # automatic invalidation once every day
19:00:59 RUN echo "2021-01-08 (+0000)"
19:00:5919:00:59 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
19:00:5919:00:59 RUN python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y devscripts dpkg-dev python3-apt python3-catkin-pkg-modules python3-empy python3-rosdistro-modules python3-yaml openssl
19:00:5919:00:59 # always invalidate to actually have the latest apt repo state
19:00:59 RUN echo "2021-01-08 19:00:59 +0000"
19:00:59 RUN python3 -u /tmp/wrapper_scripts/apt.py update
19:00:5919:00:59 USER buildfarm
19:00:59 ENTRYPOINT ["sh", "-c"]
19:00:59 CMD ["PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH python3 -u /tmp/ros_buildfarm/scripts/release/get_sourcedeb.py --rosdistro-index-url https://raw.githubusercontent.com/LCAS/rosdistro/master/index.yaml melodic turtlebot_apps --sourcedeb-dir /tmp/binarydeb && PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH python3 -u /tmp/ros_buildfarm/scripts/release/append_build_timestamp.py melodic turtlebot_apps --sourcedeb-dir /tmp/binarydeb && PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH python3 -u /tmp/ros_buildfarm/scripts/release/create_binarydeb_task_generator.py --rosdistro-index-url https://raw.githubusercontent.com/LCAS/rosdistro/master/index.yaml melodic turtlebot_apps ubuntu bionic amd64 --distribution-repository-urls http://10.210.9.154/ubuntu/buildinghttp://packages.ros.org/ros/ubuntu --distribution-repository-key-files /tmp/keys/0.key /tmp/keys/1.key --binarydeb-dir /tmp/binarydeb --env-vars --dockerfile-dir /tmp/docker_build_binarydeb"]
19:00:59+ echo # END SECTION
19:00:59# END SECTION
19:00:59+ echo # BEGIN SECTION: Build Dockerfile - binarydeb task
10. Build Dockerfile - binarydeb task
Hide Details
19:00:59# BEGIN SECTION: Build Dockerfile - binarydeb task
19:00:59+ cd /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/docker_generating_docker
19:00:59+ python3 -u /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/ros_buildfarm/scripts/misc/docker_pull_baseimage.py
19:00:59Get base image name from Dockerfile 'Dockerfile': ubuntu:bionic
19:00:59Check docker base image for updates: docker pull ubuntu:bionic
19:01:01bionic: Pulling from library/ubuntu
19:01:02Digest: sha256:fd25e706f3dea2a5ff705dbc3353cf37f08307798f3e360a13e9385840f73fb3
19:01:02Status: Image is up to date for ubuntu:bionic
19:01:02+ docker build --force-rm -t binarydeb_task_generation.melodic_ubuntu_bionic_amd64_turtlebot_apps .
19:01:02Sending build context to Docker daemon 20.99kB
19:01:02Step 1/28 : FROM ubuntu:bionic
19:01:02 ---> 2c047404e52d
19:01:02Step 2/28 : VOLUME /var/cache/apt/archives
19:01:02 ---> Using cache
19:01:02 ---> 332a11ca41a7
19:01:02Step 3/28 : ENV DEBIAN_FRONTEND noninteractive
19:01:02 ---> Using cache
19:01:02 ---> f125c944ca83
19:01:02Step 4/28 : 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
19:01:02 ---> Using cache
19:01:02 ---> df80996c5c31
19:01:02Step 5/28 : RUN echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen
19:01:02 ---> Using cache
19:01:02 ---> 867d7c5bc67e
19:01:02Step 6/28 : RUN locale-gen en_US.UTF-8
19:01:02 ---> Using cache
19:01:02 ---> 0575af1b0ce2
19:01:02Step 7/28 : ENV LANG en_US.UTF-8
19:01:02 ---> Using cache
19:01:02 ---> 6bc40073e03c
19:01:02Step 8/28 : ENV TZ GMT+00
19:01:02 ---> Using cache
19:01:02 ---> d72810c849b4
19:01:02Step 9/28 : RUN useradd -u 1002 -l -m buildfarm
19:01:02 ---> Using cache
19:01:02 ---> 3a598eac2e0f
19:01:02Step 10/28 : RUN mkdir /tmp/keys
19:01:02 ---> Using cache
19:01:02 ---> 623796486f57
19:01:02Step 11/28 : 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
19:01:02 ---> Using cache
19:01:02 ---> 853df0bc49ca
19:01:02Step 12/28 : 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
19:01:02 ---> Using cache
19:01:02 ---> 62096b410269
19:01:02Step 13/28 : 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
19:01:02 ---> Using cache
19:01:02 ---> 9267d02da6f1
19:01:02Step 14/28 : RUN echo deb http://10.210.9.154/ubuntu/building bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list
19:01:02 ---> Using cache
19:01:02 ---> a608beac98e9
19:01:02Step 15/28 : RUN echo deb-src http://10.210.9.154/ubuntu/building bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list
19:01:02 ---> Using cache
19:01:02 ---> 7178b8d3f8d6
19:01:02Step 16/28 : RUN echo deb http://packages.ros.org/ros/ubuntu bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list
19:01:02 ---> Using cache
19:01:02 ---> 98947f49e3a2
19:01:02Step 17/28 : RUN grep -q -F -e "deb http://old-releases.ubuntu.com" /etc/apt/sources.list && ((grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list)) || ((grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list))
19:01:02 ---> Using cache
19:01:02 ---> c4e9178a2807
19:01:02Step 18/28 : RUN mkdir /tmp/wrapper_scripts
19:01:02 ---> Using cache
19:01:02 ---> f6ac317037c2
19:01:02Step 19/28 : 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
19:01:02 ---> Using cache
19:01:02 ---> 8d289139c085
19:01:02Step 20/28 : 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
19:01:02 ---> Using cache
19:01:02 ---> c0f7e1cc0df4
19:01:02Step 21/28 : RUN echo "2021-01-08 (+0000)"
19:01:02 ---> Using cache
19:01:02 ---> 5580fe42335d
19:01:02Step 22/28 : 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
19:01:02 ---> Using cache
19:01:02 ---> 929ef5c808a5
19:01:02Step 23/28 : RUN python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y devscripts dpkg-dev python3-apt python3-catkin-pkg-modules python3-empy python3-rosdistro-modules python3-yaml openssl
19:01:02 ---> Using cache
19:01:02 ---> 81236c729b22
19:01:02Step 24/28 : RUN echo "2021-01-08 19:00:59 +0000"
19:01:03 ---> Running in 8b2488c4ecb9
19:01:042021-01-08 19:00:59 +0000
19:01:04 ---> c7194b5be1fc
19:01:04Removing intermediate container 8b2488c4ecb9
19:01:04Step 25/28 : RUN python3 -u /tmp/wrapper_scripts/apt.py update
19:01:04 ---> Running in 081ea6a9b5b2
19:01:06Invoking 'apt-get update'
19:01:06Get:1 http://10.210.9.154/ubuntu/building bionic InRelease [2,826 B]
19:01:06Hit:2 http://archive.ubuntu.com/ubuntu bionic InRelease
19:01:07Get:3 http://archive.ubuntu.com/ubuntu bionic-updates InRelease [88.7 kB]
19:01:07Get:4 http://archive.ubuntu.com/ubuntu bionic-backports InRelease [74.6 kB]
19:01:07Get:5 http://archive.ubuntu.com/ubuntu bionic-security InRelease [88.7 kB]
19:01:07Get:6 http://security.ubuntu.com/ubuntu bionic-security InRelease [88.7 kB]
19:01:07Hit:7 http://packages.ros.org/ros/ubuntu bionic InRelease
19:01:07Get:8 http://10.210.9.154/ubuntu/building bionic/main Sources [159 kB]
19:01:07Get:9 http://10.210.9.154/ubuntu/building bionic/main amd64 Packages [192 kB]
19:01:09Fetched 695 kB in 2s (331 kB/s)
19:01:11Reading package lists...
19:01:12 ---> 0c0365408fba
19:01:12Removing intermediate container 081ea6a9b5b2
19:01:12Step 26/28 : USER buildfarm
19:01:12 ---> Running in 27b4b8da75b8
19:01:13 ---> eaf17586c536
19:01:13Removing intermediate container 27b4b8da75b8
19:01:13Step 27/28 : ENTRYPOINT sh -c
19:01:13 ---> Running in 8376b9bd461c
19:01:13 ---> cd87765ffdc8
19:01:13Removing intermediate container 8376b9bd461c
19:01:13Step 28/28 : CMD PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH python3 -u /tmp/ros_buildfarm/scripts/release/get_sourcedeb.py --rosdistro-index-url https://raw.githubusercontent.com/LCAS/rosdistro/master/index.yaml melodic turtlebot_apps --sourcedeb-dir /tmp/binarydeb && PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH python3 -u /tmp/ros_buildfarm/scripts/release/append_build_timestamp.py melodic turtlebot_apps --sourcedeb-dir /tmp/binarydeb && PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH python3 -u /tmp/ros_buildfarm/scripts/release/create_binarydeb_task_generator.py --rosdistro-index-url https://raw.githubusercontent.com/LCAS/rosdistro/master/index.yaml melodic turtlebot_apps ubuntu bionic amd64 --distribution-repository-urls http://10.210.9.154/ubuntu/buildinghttp://packages.ros.org/ros/ubuntu --distribution-repository-key-files /tmp/keys/0.key /tmp/keys/1.key --binarydeb-dir /tmp/binarydeb --env-vars --dockerfile-dir /tmp/docker_build_binarydeb
19:01:14 ---> Running in 33d3cd5c8dce
19:01:14 ---> 463820297d30
19:01:14Removing intermediate container 33d3cd5c8dce
19:01:14Successfully built 463820297d30
19:01:14Successfully tagged binarydeb_task_generation.melodic_ubuntu_bionic_amd64_turtlebot_apps:latest
19:01:14+ echo # END SECTION
19:01:14# END SECTION
19:01:14+ echo # BEGIN SECTION: Run Dockerfile - binarydeb task
19:01:15# BEGIN SUBSECTION: get sourcedeb
19:01:23Invoking '/usr/bin/python3 /tmp/ros_buildfarm/ros_buildfarm/wrapper/apt.py source --download-only --only-source ros-melodic-turtlebot-apps=3.0.1-1bionic'
19:01:25Invoking 'apt-get source --download-only --only-source ros-melodic-turtlebot-apps=3.0.1-1bionic'
19:01:25Reading package lists...
19:01:25Need to get 5,764 B of source archives.
19:01:25Get:1 http://10.210.9.154/ubuntu/building bionic/main ros-melodic-turtlebot-apps 3.0.1-1bionic (dsc) [1,027 B]
19:01:25Get:2 http://10.210.9.154/ubuntu/building bionic/main ros-melodic-turtlebot-apps 3.0.1-1bionic (tar) [2,537 B]
19:01:25Get:3 http://10.210.9.154/ubuntu/building bionic/main ros-melodic-turtlebot-apps 3.0.1-1bionic (diff) [2,200 B]
19:01:25Fetched 5,764 B in 0s (256 kB/s)
19:01:25Download complete and in download only mode
19:01:25Invoking 'dpkg-source -x ros-melodic-turtlebot-apps_3.0.1-1bionic.dsc'
19:01:26dpkg-source: warning: extracting unsigned source package (ros-melodic-turtlebot-apps_3.0.1-1bionic.dsc)
19:01:26dpkg-source: info: extracting ros-melodic-turtlebot-apps in ros-melodic-turtlebot-apps-3.0.1
19:01:26dpkg-source: info: unpacking ros-melodic-turtlebot-apps_3.0.1.orig.tar.gz
19:01:26dpkg-source: info: unpacking ros-melodic-turtlebot-apps_3.0.1-1bionic.debian.tar.xz
19:01:26Package maintainer emails: marc@hanheide.net
19:01:26# END SUBSECTION
11.2. append build timestamp
Hide Details
19:01:26# BEGIN SUBSECTION: append build timestamp
19:01:26Invoking 'debchange -v 3.0.1-1bionic.20210108.190126 -p -D bionic -u high -m Append timestamp when binarydeb was built.' in '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:26# END SUBSECTION
19:01:30Looking for the '.dsc' file of package 'ros-melodic-turtlebot-apps' with version '3.0.1-1'
19:01:32Using the following distribution repositories:
19:01:32http://10.210.9.154/ubuntu/building (/tmp/keys/0.key)
19:01:32http://packages.ros.org/ros/ubuntu (/tmp/keys/1.key)
19:01:32Generating Dockerfile '/tmp/docker_build_binarydeb/Dockerfile':
19:01:32 # generated from release/binarydeb_task.Dockerfile.em
19:01:3219:01:3219:01:32 FROM ubuntu:bionic
19:01:3219:01:32 VOLUME ["/var/cache/apt/archives"]
19:01:3219:01:32 ENV DEBIAN_FRONTEND noninteractive
19:01:3219:01:3219:01:32 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
19:01:32 RUN echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen
19:01:32 RUN locale-gen en_US.UTF-8
19:01:32 ENV LANG en_US.UTF-8
19:01:32 ENV TZ GMT+00
19:01:3219:01:32 RUN useradd -u 1002 -l -m buildfarm
19:01:3219:01:32 RUN mkdir /tmp/keys
19:01:32 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
19:01:32 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
19:01:32 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
19:01:32 RUN echo deb http://10.210.9.154/ubuntu/building bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list
19:01:32 RUN echo deb http://packages.ros.org/ros/ubuntu bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list
19:01:3219:01:32 RUN grep -q -F -e "deb http://old-releases.ubuntu.com" /etc/apt/sources.list && ((grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list)) || ((grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list))
19:01:3219:01:32 RUN mkdir /tmp/wrapper_scripts
19:01:32 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
19:01:32 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
19:01:3219:01:32 # automatic invalidation once every day
19:01:32 RUN echo "2021-01-08 (+0000)"
19:01:3219:01:32 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
19:01:3219:01:32 RUN python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y dh-python
19:01:3219:01:32 RUN python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y ccache gcc build-essential
19:01:3219:01:3219:01:32 # for each dependency: echo version, apt update, apt install, apt clean
19:01:32 RUN echo "apt-src: 0.25.2" && python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y -o Debug::pkgProblemResolver=yes apt-src
19:01:32 RUN echo "debhelper: 12.1.1ubuntu1~ubuntu18.04.1" && python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y -o Debug::pkgProblemResolver=yes debhelper
19:01:32 RUN echo "ros-melodic-catkin: 0.7.29-1bionic.20201014.191449" && python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y -o Debug::pkgProblemResolver=yes ros-melodic-catkin
19:01:3219:01:3219:01:32 USER buildfarm
19:01:32 ENTRYPOINT ["sh", "-c"]
19:01:32 CMD ["PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH PATH=/usr/lib/ccache:$PATH python3 -u /tmp/ros_buildfarm/scripts/release/build_binarydeb.py melodic turtlebot_apps --sourcedeb-dir /tmp/binarydeb"]
19:01:32Mount the following volumes when running the container:
19:01:32 -v /tmp/ros_buildfarm:/tmp/ros_buildfarm:ro
19:01:32 -v /tmp/binarydeb:/tmp/binarydeb
19:01:33+ echo # END SECTION
19:01:33# END SECTION
19:01:34# BEGIN SECTION: Build Dockerfile - build binarydeb
19:01:34+ cd /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/docker_build_binarydeb
19:01:34+ python3 -u /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/ros_buildfarm/scripts/misc/docker_pull_baseimage.py
19:01:34Get base image name from Dockerfile 'Dockerfile': ubuntu:bionic
19:01:34Check docker base image for updates: docker pull ubuntu:bionic
19:01:36bionic: Pulling from library/ubuntu
19:01:36Digest: sha256:fd25e706f3dea2a5ff705dbc3353cf37f08307798f3e360a13e9385840f73fb3
19:01:36Status: Image is up to date for ubuntu:bionic
19:01:36+ docker build --force-rm -t binarydeb_build.melodic_ubuntu_bionic_amd64_turtlebot_apps .
19:01:36Sending build context to Docker daemon 20.48kB
19:01:36Step 1/29 : FROM ubuntu:bionic
19:01:36 ---> 2c047404e52d
19:01:36Step 2/29 : VOLUME /var/cache/apt/archives
19:01:36 ---> Using cache
19:01:36 ---> 332a11ca41a7
19:01:36Step 3/29 : ENV DEBIAN_FRONTEND noninteractive
19:01:36 ---> Using cache
19:01:36 ---> f125c944ca83
19:01:36Step 4/29 : 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
19:01:36 ---> Using cache
19:01:36 ---> df80996c5c31
19:01:36Step 5/29 : RUN echo "en_US.UTF-8 UTF-8" >> /etc/locale.gen
19:01:36 ---> Using cache
19:01:36 ---> 867d7c5bc67e
19:01:36Step 6/29 : RUN locale-gen en_US.UTF-8
19:01:36 ---> Using cache
19:01:36 ---> 0575af1b0ce2
19:01:36Step 7/29 : ENV LANG en_US.UTF-8
19:01:36 ---> Using cache
19:01:36 ---> 6bc40073e03c
19:01:36Step 8/29 : ENV TZ GMT+00
19:01:36 ---> Using cache
19:01:36 ---> d72810c849b4
19:01:36Step 9/29 : RUN useradd -u 1002 -l -m buildfarm
19:01:36 ---> Using cache
19:01:36 ---> 3a598eac2e0f
19:01:36Step 10/29 : RUN mkdir /tmp/keys
19:01:36 ---> Using cache
19:01:36 ---> 623796486f57
19:01:36Step 11/29 : 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
19:01:36 ---> Using cache
19:01:36 ---> 853df0bc49ca
19:01:36Step 12/29 : 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
19:01:36 ---> Using cache
19:01:36 ---> 62096b410269
19:01:36Step 13/29 : 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
19:01:36 ---> Using cache
19:01:36 ---> 9267d02da6f1
19:01:36Step 14/29 : RUN echo deb http://10.210.9.154/ubuntu/building bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list
19:01:36 ---> Using cache
19:01:36 ---> a608beac98e9
19:01:36Step 15/29 : RUN echo deb http://packages.ros.org/ros/ubuntu bionic main | tee -a /etc/apt/sources.list.d/buildfarm.list
19:01:36 ---> Using cache
19:01:36 ---> e0081dc17da7
19:01:36Step 16/29 : RUN grep -q -F -e "deb http://old-releases.ubuntu.com" /etc/apt/sources.list && ((grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://old-releases\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb http://old-releases.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://old-releases\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z]+)*" /etc/apt/sources.list || echo "deb-src http://old-releases.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list)) || ((grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic-updates ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic-updates multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb http://archive\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb http://archive.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list) && (grep -q -E -x -e "deb-src http://archive\.ubuntu\.com/ubuntu/? bionic-security ([-a-z]+ )*multiverse( [-a-z])*" /etc/apt/sources.list || echo "deb-src http://archive.ubuntu.com/ubuntu/ bionic-security multiverse" >> /etc/apt/sources.list))
19:01:36 ---> Using cache
19:01:36 ---> dc71454b0d7f
19:01:36Step 17/29 : RUN mkdir /tmp/wrapper_scripts
19:01:36 ---> Using cache
19:01:36 ---> 6e9bbd3bf1b0
19:01:36Step 18/29 : 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
19:01:36 ---> Using cache
19:01:36 ---> 9127ca9b271f
19:01:36Step 19/29 : 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
19:01:36 ---> Using cache
19:01:36 ---> cda8bda50e50
19:01:36Step 20/29 : RUN echo "2021-01-08 (+0000)"
19:01:36 ---> Using cache
19:01:36 ---> 3970408b43c5
19:01:36Step 21/29 : 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
19:01:36 ---> Using cache
19:01:36 ---> f4dc5aa7f4b9
19:01:36Step 22/29 : RUN python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y dh-python
19:01:36 ---> Using cache
19:01:36 ---> 4f2cf266cdf2
19:01:36Step 23/29 : RUN python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y ccache gcc build-essential
19:01:36 ---> Using cache
19:01:36 ---> 2a4c9143d9a3
19:01:36Step 24/29 : RUN echo "apt-src: 0.25.2" && python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y -o Debug::pkgProblemResolver=yes apt-src
19:01:36 ---> Using cache
19:01:36 ---> 8182600cc87f
19:01:36Step 25/29 : RUN echo "debhelper: 12.1.1ubuntu1~ubuntu18.04.1" && python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y -o Debug::pkgProblemResolver=yes debhelper
19:01:36 ---> Using cache
19:01:36 ---> 59fd429aa3a2
19:01:36Step 26/29 : RUN echo "ros-melodic-catkin: 0.7.29-1bionic.20201014.191449" && python3 -u /tmp/wrapper_scripts/apt.py update-install-clean -q -y -o Debug::pkgProblemResolver=yes ros-melodic-catkin
19:01:36 ---> Using cache
19:01:36 ---> d2449671cab8
19:01:36Step 27/29 : USER buildfarm
19:01:36 ---> Using cache
19:01:36 ---> 45cefb47acc3
19:01:36Step 28/29 : ENTRYPOINT sh -c
19:01:36 ---> Using cache
19:01:36 ---> 3c869d9c80a3
19:01:36Step 29/29 : CMD PYTHONPATH=/tmp/ros_buildfarm:$PYTHONPATH PATH=/usr/lib/ccache:$PATH python3 -u /tmp/ros_buildfarm/scripts/release/build_binarydeb.py melodic turtlebot_apps --sourcedeb-dir /tmp/binarydeb
19:01:37 ---> Running in f3c5c65cd392
19:01:37 ---> c511ce89fc45
19:01:37Removing intermediate container f3c5c65cd392
19:01:37Successfully built c511ce89fc45
19:01:37Successfully tagged binarydeb_build.melodic_ubuntu_bionic_amd64_turtlebot_apps:latest
19:01:37+ echo # END SECTION
19:01:37# END SECTION
19:01:37+ echo # BEGIN SECTION: Run Dockerfile - build binarydeb
13. Run Dockerfile - build binarydeb
Hide Details
19:01:37# BEGIN SECTION: Run Dockerfile - build binarydeb
19:01:37+ docker run --rm --cidfile=/home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/docker_build_binarydeb/docker.cid -e=HOME= -e=TRAVIS= --net=host -v /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/ros_buildfarm:/tmp/ros_buildfarm:ro -v /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/binarydeb:/tmp/binarydeb -v /home/jenkins-slave/.ccache:/home/buildfarm/.ccache binarydeb_build.melodic_ubuntu_bionic_amd64_turtlebot_apps
13.1. build binarydeb
Hide Details
19:01:37# BEGIN SUBSECTION: build binarydeb
19:01:37Package 'ros-melodic-turtlebot-apps' version: 3.0.1-1bionic.20210108.190126
19:01:40Invoking 'apt-src build ros-melodic-turtlebot-apps' in '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:42I: Building in /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1 ..
19:01:43dpkg-buildpackage: info: source package ros-melodic-turtlebot-apps
19:01:43dpkg-buildpackage: info: source version 3.0.1-1bionic.20210108.190126
19:01:43dpkg-buildpackage: info: source distribution bionic
19:01:43dpkg-buildpackage: info: source changed by Marc Hanheide <marc@hanheide.net>
19:01:43 dpkg-source --before-build ros-melodic-turtlebot-apps-3.0.1
19:01:43dpkg-buildpackage: info: host architecture amd64
19:01:43dpkg-source: info: using options from ros-melodic-turtlebot-apps-3.0.1/debian/source/options: --auto-commit
19:01:43 fakeroot debian/rules clean
19:01:43dh clean -v --buildsystem=cmake
19:01:44 dh_testdir -O-v -O--buildsystem=cmake
19:01:44 dh_auto_clean -O-v -O--buildsystem=cmake
19:01:44 dh_clean -O-v -O--buildsystem=cmake
19:01:44 rm -f debian/debhelper-build-stamp
19:01:44 rm -rf debian/.debhelper/
19:01:44 rm -f -- debian/ros-melodic-turtlebot-apps.substvars debian/files
19:01:44 rm -fr -- debian/ros-melodic-turtlebot-apps/ debian/tmp/
19:01:44 find . \( \( \
19:01:44 \( -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 \
19:01:44 \( -name '#*#' -o -name '.*~' -o -name '*~' -o -name DEADJOE \
19:01:44 -o -name '*.orig' -o -name '*.rej' -o -name '*.bak' \
19:01:44 -o -name '.*.orig' -o -name .*.rej -o -name '.SUMS' \
19:01:44 -o -name TAGS -o \( -path '*/.deps/*' -a -name '*.P' \) \
19:01:44 \) -exec rm -f {} + \) -o \
19:01:44 \( -type d -a -name autom4te.cache -prune -exec rm -rf {} + \) \)
19:01:44 debian/rules build
19:01:44dh build -v --buildsystem=cmake
19:01:44 dh_testdir -O-v -O--buildsystem=cmake
19:01:44 dh_update_autotools_config -O-v -O--buildsystem=cmake
19:01:44 debian/rules override_dh_auto_configure
19:01:44make[1]: Entering directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:44# In case we're installing to a non-standard location, look for a setup.sh
19:01:44# in the install tree that was dropped by catkin, and source it. It will
19:01:44# set things like CMAKE_PREFIX_PATH, PKG_CONFIG_PATH, and PYTHONPATH.
19:01:44if [ -f "/opt/ros/melodic/setup.sh" ]; then . "/opt/ros/melodic/setup.sh"; fi && \
19:01:44dh_auto_configure -- \
19:01:44 -DCATKIN_BUILD_BINARY_PACKAGE="1" \
19:01:44 -DCMAKE_INSTALL_PREFIX="/opt/ros/melodic" \
19:01:44 -DCMAKE_PREFIX_PATH="/opt/ros/melodic"
19:01:44 install -d obj-x86_64-linux-gnu
19:01:44 cd obj-x86_64-linux-gnu && cmake .. -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_VERBOSE_MAKEFILE=ON -DCMAKE_BUILD_TYPE=None -DCMAKE_INSTALL_SYSCONFDIR=/etc -DCMAKE_INSTALL_LOCALSTATEDIR=/var -DCMAKE_EXPORT_NO_PACKAGE_REGISTRY=ON -DCMAKE_FIND_PACKAGE_NO_PACKAGE_REGISTRY=ON -DCATKIN_BUILD_BINARY_PACKAGE=1 -DCMAKE_INSTALL_PREFIX=/opt/ros/melodic -DCMAKE_PREFIX_PATH=/opt/ros/melodic
19:01:44-- The C compiler identification is GNU 7.5.0
19:01:44-- The CXX compiler identification is GNU 7.5.0
19:01:44-- Check for working C compiler: /usr/bin/cc
19:01:45-- Check for working C compiler: /usr/bin/cc -- works
19:01:45-- Detecting C compiler ABI info
19:01:45-- Detecting C compiler ABI info - done
19:01:45-- Detecting C compile features
19:01:45-- Detecting C compile features - done
19:01:45-- Check for working CXX compiler: /usr/bin/c++
19:01:46-- Check for working CXX compiler: /usr/bin/c++ -- works
19:01:46-- Detecting CXX compiler ABI info
19:01:46-- Detecting CXX compiler ABI info - done
19:01:46-- Detecting CXX compile features
19:01:47-- Detecting CXX compile features - done
19:01:47-- Using CATKIN_DEVEL_PREFIX: /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu/devel
19:01:47-- Using CMAKE_PREFIX_PATH: /opt/ros/melodic
19:01:47-- This workspace overlays: /opt/ros/melodic
19:01:47-- Found PythonInterp: /usr/bin/python (found version "2.7.17")
19:01:47-- Using PYTHON_EXECUTABLE: /usr/bin/python
19:01:47-- Using Debian Python package layout
19:01:47-- Using empy: /usr/bin/empy
19:01:47-- Using CATKIN_ENABLE_TESTING: ON
19:01:47-- Skip enable_testing() when building binary package
19:01:47-- Using CATKIN_TEST_RESULTS_DIR: /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu/test_results
19:01:47-- Found gtest sources under '/usr/src/googletest': gtests will be built
19:01:47-- Found gmock sources under '/usr/src/googletest': gmock will be built
19:01:47-- Looking for pthread.h
19:01:47-- Looking for pthread.h - found
19:01:47-- Looking for pthread_create
19:01:47-- Looking for pthread_create - not found
19:01:47-- Looking for pthread_create in pthreads
19:01:47-- Looking for pthread_create in pthreads - not found
19:01:47-- Looking for pthread_create in pthread
19:01:47-- Looking for pthread_create in pthread - found
19:01:47-- Found Threads: TRUE
19:01:47-- Using Python nosetests: /usr/bin/nosetests-2.7
19:01:47-- catkin 0.7.29
19:01:47-- BUILD_SHARED_LIBS is on
19:01:48-- Configuring done
19:01:48-- Generating done
19:01:48CMake Warning:
19:01:48 Manually-specified variables were not used by the project:
19:01:4819:01:48 CMAKE_EXPORT_NO_PACKAGE_REGISTRY
19:01:48 CMAKE_INSTALL_LOCALSTATEDIR
19:01:48 CMAKE_INSTALL_SYSCONFDIR
19:01:4819:01:4819:01:48-- Build files have been written to: /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu
19:01:48make[1]: Leaving directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:48 debian/rules override_dh_auto_build
19:01:48make[1]: Entering directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:48# In case we're installing to a non-standard location, look for a setup.sh
19:01:48# in the install tree that was dropped by catkin, and source it. It will
19:01:48# set things like CMAKE_PREFIX_PATH, PKG_CONFIG_PATH, and PYTHONPATH.
19:01:48if [ -f "/opt/ros/melodic/setup.sh" ]; then . "/opt/ros/melodic/setup.sh"; fi && \
19:01:48dh_auto_build
19:01:48 cd obj-x86_64-linux-gnu && make -j1
19:01:48make[2]: Entering directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu'
19:01:48/usr/bin/cmake -H/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1 -B/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu --check-build-system CMakeFiles/Makefile.cmake 0
19:01:48/usr/bin/cmake -E cmake_progress_start /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu/CMakeFiles /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu/CMakeFiles/progress.marks
19:01:48make -f CMakeFiles/Makefile2 all
19:01:48make[3]: Entering directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu'
19:01:48make[3]: Nothing to be done for 'all'.
19:01:48make[3]: Leaving directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu'
19:01:48/usr/bin/cmake -E cmake_progress_start /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu/CMakeFiles 0
19:01:48make[2]: Leaving directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu'
19:01:48make[1]: Leaving directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:48 debian/rules override_dh_auto_test
19:01:48make[1]: Entering directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:48# In case we're installing to a non-standard location, look for a setup.sh
19:01:48# in the install tree that was dropped by catkin, and source it. It will
19:01:48# set things like CMAKE_PREFIX_PATH, PKG_CONFIG_PATH, and PYTHONPATH.
19:01:48echo -- Running tests. Even if one of them fails the build is not canceled.
19:01:48-- Running tests. Even if one of them fails the build is not canceled.
19:01:48if [ -f "/opt/ros/melodic/setup.sh" ]; then . "/opt/ros/melodic/setup.sh"; fi && \
19:01:48dh_auto_test || true
19:01:48make[1]: Leaving directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:48 fakeroot debian/rules binary
19:01:48dh binary -v --buildsystem=cmake
19:01:49 dh_testroot -O-v -O--buildsystem=cmake
19:01:49 dh_prep -O-v -O--buildsystem=cmake
19:01:49 rm -f -- debian/ros-melodic-turtlebot-apps.substvars
19:01:49 rm -fr -- debian/.debhelper/generated/ros-melodic-turtlebot-apps/ debian/ros-melodic-turtlebot-apps/ debian/tmp/
19:01:49 dh_installdirs -O-v -O--buildsystem=cmake
19:01:49 install -d debian/ros-melodic-turtlebot-apps
19:01:49 debian/rules override_dh_auto_install
19:01:49make[1]: Entering directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:49# In case we're installing to a non-standard location, look for a setup.sh
19:01:49# in the install tree that was dropped by catkin, and source it. It will
19:01:49# set things like CMAKE_PREFIX_PATH, PKG_CONFIG_PATH, and PYTHONPATH.
19:01:49if [ -f "/opt/ros/melodic/setup.sh" ]; then . "/opt/ros/melodic/setup.sh"; fi && \
19:01:49dh_auto_install
19:01:49 cd obj-x86_64-linux-gnu && make -j1 install DESTDIR=/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/debian/ros-melodic-turtlebot-apps AM_UPDATE_INFO_DIR=no
19:01:49make[2]: Entering directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu'
19:01:49/usr/bin/cmake -H/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1 -B/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu --check-build-system CMakeFiles/Makefile.cmake 0
19:01:49/usr/bin/cmake -E cmake_progress_start /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu/CMakeFiles /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu/CMakeFiles/progress.marks
19:01:49make -f CMakeFiles/Makefile2 all
19:01:49make[3]: Entering directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu'
19:01:49make[3]: Nothing to be done for 'all'.
19:01:49make[3]: Leaving directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu'
19:01:49/usr/bin/cmake -E cmake_progress_start /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu/CMakeFiles 0
19:01:49make -f CMakeFiles/Makefile2 preinstall
19:01:49make[3]: Entering directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu'
19:01:49make[3]: Nothing to be done for 'preinstall'.
19:01:49make[3]: Leaving directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu'
19:01:49Install the project...
19:01:49/usr/bin/cmake -P cmake_install.cmake
19:01:49-- Install configuration: "None"
19:01:49-- Installing: /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/debian/ros-melodic-turtlebot-apps/opt/ros/melodic/share/turtlebot_apps/package.xml
19:01:49make[2]: Leaving directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu'
19:01:49make[1]: Leaving directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:49 dh_install -O-v -O--buildsystem=cmake
19:01:49 install -d debian/.debhelper/generated/ros-melodic-turtlebot-apps
19:01:49 dh_installdocs -O-v -O--buildsystem=cmake
19:01:49 install -d debian/ros-melodic-turtlebot-apps/usr/share/doc/ros-melodic-turtlebot-apps
19:01:49 dh_installchangelogs -O-v -O--buildsystem=cmake
19:01:49 install -p -m0644 debian/changelog debian/ros-melodic-turtlebot-apps/usr/share/doc/ros-melodic-turtlebot-apps/changelog.Debian
19:01:49 dh_installexamples -O-v -O--buildsystem=cmake
19:01:49 dh_installman -O-v -O--buildsystem=cmake
19:01:50 dh_installcatalogs -O-v -O--buildsystem=cmake
19:01:50 dh_installcron -O-v -O--buildsystem=cmake
19:01:50 dh_installdebconf -O-v -O--buildsystem=cmake
19:01:50 install -d debian/ros-melodic-turtlebot-apps/DEBIAN
19:01:50 dh_installemacsen -O-v -O--buildsystem=cmake
19:01:50 dh_installifupdown -O-v -O--buildsystem=cmake
19:01:50 dh_installinfo -O-v -O--buildsystem=cmake
19:01:50 dh_installinit -O-v -O--buildsystem=cmake
19:01:50 dh_installmenu -O-v -O--buildsystem=cmake
19:01:50 dh_installmime -O-v -O--buildsystem=cmake
19:01:50 dh_installmodules -O-v -O--buildsystem=cmake
19:01:50 dh_installlogcheck -O-v -O--buildsystem=cmake
19:01:50 dh_installlogrotate -O-v -O--buildsystem=cmake
19:01:50 dh_installpam -O-v -O--buildsystem=cmake
19:01:50 dh_installppp -O-v -O--buildsystem=cmake
19:01:50 dh_installudev -O-v -O--buildsystem=cmake
19:01:51 dh_installgsettings -O-v -O--buildsystem=cmake
19:01:51 dh_bugfiles -O-v -O--buildsystem=cmake
19:01:51 dh_ucf -O-v -O--buildsystem=cmake
19:01:51 dh_lintian -O-v -O--buildsystem=cmake
19:01:51 dh_gconf -O-v -O--buildsystem=cmake
19:01:51 dh_icons -O-v -O--buildsystem=cmake
19:01:51 dh_perl -O-v -O--buildsystem=cmake
19:01:51 dh_usrlocal -O-v -O--buildsystem=cmake
19:01:51 dh_link -O-v -O--buildsystem=cmake
19:01:51 dh_installwm -O-v -O--buildsystem=cmake
19:01:51 dh_installxfonts -O-v -O--buildsystem=cmake
19:01:51 dh_strip_nondeterminism -O-v -O--buildsystem=cmake
19:01:51 dh_compress -O-v -O--buildsystem=cmake
19:01:51 cd debian/ros-melodic-turtlebot-apps
19:01:51 chmod a-x usr/share/doc/ros-melodic-turtlebot-apps/changelog.Debian
19:01:51 gzip -9nf usr/share/doc/ros-melodic-turtlebot-apps/changelog.Debian
19:01:51 cd '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:51 dh_fixperms -O-v -O--buildsystem=cmake
19:01:51 find debian/ros-melodic-turtlebot-apps -true -print0 2>/dev/null | xargs -0r chown --no-dereference 0:0
19:01:51 find debian/ros-melodic-turtlebot-apps ! -type l -a -true -a -true -print0 2>/dev/null | xargs -0r chmod go=rX,u+rw,a-s
19:01:51 find debian/ros-melodic-turtlebot-apps/usr/share/doc -type f -a -true -a ! -regex 'debian/ros-melodic-turtlebot-apps/usr/share/doc/[^/]*/examples/.*' -print0 2>/dev/null | xargs -0r chmod 0644
19:01:52 find debian/ros-melodic-turtlebot-apps/usr/share/doc -type d -a -true -a -true -print0 2>/dev/null | xargs -0r chmod 0755
19:01:52 find debian/ros-melodic-turtlebot-apps -type f \( -name '*.so.*' -o -name '*.so' -o -name '*.la' -o -name '*.a' -o -name '*.js' -o -name '*.css' -o -name '*.scss' -o -name '*.sass' -o -name '*.jpeg' -o -name '*.jpg' -o -name '*.png' -o -name '*.gif' -o -name '*.cmxs' \) -a -true -a -true -print0 2>/dev/null | xargs -0r chmod 0644
19:01:52 dh_missing -O-v -O--buildsystem=cmake
19:01:52 dh_strip -O-v -O--buildsystem=cmake
19:01:52 dh_makeshlibs -O-v -O--buildsystem=cmake
19:01:52 rm -f debian/ros-melodic-turtlebot-apps/DEBIAN/shlibs
19:01:52 debian/rules override_dh_shlibdeps
19:01:52make[1]: Entering directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:52# In case we're installing to a non-standard location, look for a setup.sh
19:01:52# in the install tree that was dropped by catkin, and source it. It will
19:01:52# set things like CMAKE_PREFIX_PATH, PKG_CONFIG_PATH, and PYTHONPATH.
19:01:52if [ -f "/opt/ros/melodic/setup.sh" ]; then . "/opt/ros/melodic/setup.sh"; fi && \
19:01:52dh_shlibdeps -l/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1/debian/ros-melodic-turtlebot-apps//opt/ros/melodic/lib/
19:01:52make[1]: Leaving directory '/tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1'
19:01:52 dh_installdeb -O-v -O--buildsystem=cmake
19:01:52 dh_gencontrol -O-v -O--buildsystem=cmake
19:01:52 echo misc:Depends= >> debian/ros-melodic-turtlebot-apps.substvars
19:01:52 echo misc:Pre-Depends= >> debian/ros-melodic-turtlebot-apps.substvars
19:01:52 dpkg-gencontrol -pros-melodic-turtlebot-apps -ldebian/changelog -Tdebian/ros-melodic-turtlebot-apps.substvars -Pdebian/ros-melodic-turtlebot-apps -UMulti-Arch
19:01:52dpkg-gencontrol: warning: Depends field of package ros-melodic-turtlebot-apps: unknown substitution variable ${shlibs:Depends}
19:01:52 chmod 0644 -- debian/ros-melodic-turtlebot-apps/DEBIAN/control
19:01:52 chown 0:0 -- debian/ros-melodic-turtlebot-apps/DEBIAN/control
19:01:52 dh_md5sums -O-v -O--buildsystem=cmake
19:01:52 (cd debian/ros-melodic-turtlebot-apps >/dev/null ; find . -type f ! -regex './DEBIAN/.*' -printf '%P\0' | LC_ALL=C sort -z | xargs -r0 md5sum | perl -pe 'if (s@^\\@@) { s/\\\\/\\/g; }' > DEBIAN/md5sums) >/dev/null
19:01:52 chmod 0644 -- debian/ros-melodic-turtlebot-apps/DEBIAN/md5sums
19:01:52 chown 0:0 -- debian/ros-melodic-turtlebot-apps/DEBIAN/md5sums
19:01:52 dh_builddeb -O-v -O--buildsystem=cmake
19:01:52 dpkg-deb --build debian/ros-melodic-turtlebot-apps ..
19:01:52dpkg-deb: building package 'ros-melodic-turtlebot-apps' in '../ros-melodic-turtlebot-apps_3.0.1-1bionic.20210108.190126_amd64.deb'.
19:01:53 dpkg-genbuildinfo --build=binary
19:01:53 dpkg-genchanges --build=binary >../ros-melodic-turtlebot-apps_3.0.1-1bionic.20210108.190126_amd64.changes
19:01:53dpkg-genchanges: info: binary-only upload (no source code included)
19:01:53 dpkg-source --after-build ros-melodic-turtlebot-apps-3.0.1
19:01:53dpkg-source: info: using options from ros-melodic-turtlebot-apps-3.0.1/debian/source/options: --auto-commit
19:01:53dpkg-buildpackage: info: binary-only upload (no source included)
19:01:53I: Successfully built in /tmp/binarydeb/ros-melodic-turtlebot-apps-3.0.1
19:01:53# END SUBSECTION
19:01:53+ echo # END SECTION
19:01:53# END SECTION
19:01:53[Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary] $ /bin/sh -xe /tmp/jenkins4763630648638225715.sh
19:01:53+ [ false = false ]
19:01:53+ echo # BEGIN SECTION: Clean up to save disk space on agents
14. Clean up to save disk space on agents
Hide Details
19:01:53# BEGIN SECTION: Clean up to save disk space on agents
19:01:53+ chmod -R u+w /home/jenkins-slave/workspace/Mbin_uB64__turtlebot_apps__ubuntu_bionic_amd64__binary/binarydeb
19:01:53+ rm -fr binarydeb/ros-melodic-turtlebot-apps-3.0.1/CHANGELOG.rst binarydeb/ros-melodic-turtlebot-apps-3.0.1/CMakeLists.txt binarydeb/ros-melodic-turtlebot-apps-3.0.1/debian binarydeb/ros-melodic-turtlebot-apps-3.0.1/obj-x86_64-linux-gnu binarydeb/ros-melodic-turtlebot-apps-3.0.1/package.xml
19:01:53+ echo # END SECTION
19:01:53# END SECTION
19:01:54SSH: Connecting from host [lcas-buildfarm-slave-2]
19:01:54SSH: Connecting with configuration [repo] ...
19:01:55SSH: Disconnecting configuration [repo] ...
19:01:55SSH: Transferred 2 file(s)
19:01:55Build step 'Send files or execute commands over SSH' changed build result to SUCCESS
19:01:55Waiting for the completion of Mrel_import-package19:01:55Mrel_import-package #817 started.
19:02:04Mrel_import-package #817 completed. Result was SUCCESS
19:02:04$ ssh-agent -k
19:02:04unset SSH_AUTH_SOCK;
19:02:04unset SSH_AGENT_PID;
19:02:04echo Agent pid 15874 killed;
19:02:04[ssh-agent] Stopped.
19:02:04[description-setter] Description set: 3.0.1-1bionic.20210108.190126
19:02:04Triggering a new build of Mrel_sync-packages-to-testing_bionic_amd6419:02:04Finished: SUCCESS