diff --git a/Jenkinsfile b/Jenkinsfile index 34ffcd9c..79f923c9 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -17,11 +17,13 @@ node('linux-jammy-unprovisioned') { stage('checkout') { checkout scm } + } + dir('src/drake_bazel_external'){ stage('bazel_external setup') { - sh './drake_bazel_external/.github/setup' + sh './.github/setup' } stage('bazel_external build and test') { - sh './drake_bazel_external/.github/ci_build_test' + sh './.github/ci_build_test' } } } catch (e) { @@ -58,11 +60,13 @@ node('linux-jammy-unprovisioned') { stage('checkout') { checkout scm } + } + dir('src/drake_cmake_external'){ stage('cmake_external setup') { - sh './drake_cmake_external/.github/setup' + sh './.github/setup' } stage('cmake_external build and test') { - sh './drake_cmake_external/.github/ci_build_test' + sh './.github/ci_build_test' } } } catch (e) { diff --git a/drake_bazel_external/.bazelignore b/drake_bazel_external/.bazelignore new file mode 100644 index 00000000..f0693510 --- /dev/null +++ b/drake_bazel_external/.bazelignore @@ -0,0 +1,2 @@ +# Used for setup, do not build +drake-master \ No newline at end of file diff --git a/drake_bazel_external/.github/ci_build_test b/drake_bazel_external/.github/ci_build_test index 9efbfe5c..672ca65e 100755 --- a/drake_bazel_external/.github/ci_build_test +++ b/drake_bazel_external/.github/ci_build_test @@ -3,9 +3,5 @@ set -euxo pipefail -pushd drake_bazel_external - bazel version bazel test //... - -popd diff --git a/drake_bazel_external/.github/setup b/drake_bazel_external/.github/setup index 99031d69..9415cff1 100755 --- a/drake_bazel_external/.github/setup +++ b/drake_bazel_external/.github/setup @@ -3,11 +3,8 @@ set -euxo pipefail -cd $(dirname "${BASH_SOURCE}") -sudo ./ubuntu_setup +# CI setup +sudo ./.github/ubuntu_setup -cat > "${HOME}/.bazelrc" << EOF -startup --output_user_root=${WORKSPACE}/_bazel_${USER} -test --color=yes -test --keep_going -EOF +# drake source setup +setup/install_prereqs diff --git a/drake_bazel_external/.github/ubuntu_setup b/drake_bazel_external/.github/ubuntu_setup index 0a1ac2ad..c0d49e9d 100755 --- a/drake_bazel_external/.github/ubuntu_setup +++ b/drake_bazel_external/.github/ubuntu_setup @@ -3,10 +3,20 @@ set -euxo pipefail +if [[ "${EUID:-}" -ne 0 ]]; then + echo 'This script must be run as root' >&2 + exit 2 +fi + echo 'APT::Acquire::Retries "4";' > /etc/apt/apt.conf.d/80-acquire-retries echo 'APT::Get::Assume-Yes "true";' > /etc/apt/apt.conf.d/90-get-assume-yes export DEBIAN_FRONTEND='noninteractive' -cd $(dirname "${BASH_SOURCE}")/.. -setup/install_prereqs +apt-get update +apt-get install --no-install-recommends lsb-release + +if [[ "$(lsb_release -sc)" != 'jammy' ]]; then + echo 'This script requires Ubuntu 22.04 (Jammy)' >&2 + exit 3 +fi diff --git a/drake_bazel_external/README.md b/drake_bazel_external/README.md index fd4fb977..303aff58 100644 --- a/drake_bazel_external/README.md +++ b/drake_bazel_external/README.md @@ -7,13 +7,18 @@ For an introduction to Bazel, refer to ## Instructions -First, install the required Ubuntu packages: +First, run the `install_prereqs` script to download the drake source and run +drake's source setup script to install the required Ubuntu packages: ``` -sudo setup/install_prereqs +mkdir ~/drake_install +wget -O drake.tar.gz \ + https://github.com/RobotLocomotion/drake/archive/master.tar.gz +tar -xf drake.tar.gz -C ~/drake_install +sudo ~/drake_install/drake-master/setup/ubuntu/install_prereqs.sh ``` -Then, to build and test all apps: +Then, build and test all apps: ``` bazel test //... ``` diff --git a/drake_bazel_external/setup/install_prereqs b/drake_bazel_external/setup/install_prereqs index 20ba6acc..4d2ae327 100755 --- a/drake_bazel_external/setup/install_prereqs +++ b/drake_bazel_external/setup/install_prereqs @@ -31,119 +31,18 @@ set -euxo pipefail -ros_humble=0 - -while [ "${1:-}" != "" ]; do - case "$1" in - --ros-humble) - ros_humble=1 - ;; - *) - echo 'Invalid command line argument' >&2 - exit 1 - esac - shift -done - -if [[ "${EUID:-}" -ne 0 ]]; then - echo 'This script must be run as root' >&2 - exit 2 -fi - -apt-get update -apt-get install --no-install-recommends lsb-release - -if [[ "$(lsb_release -sc)" != 'jammy' ]]; then - echo 'This script requires Ubuntu 22.04 (Jammy)' >&2 - exit 3 -fi - -apt-get install --no-install-recommends $(cat < /etc/apt/sources.list.d/bazel.list +# Setup script +tar -xf drake.tar.gz -apt-get update -apt-get install --no-install-recommends $(cat < /etc/apt/sources.list.d/ros2-latest.list - - apt-get update - apt-get install --no-install-recommends $(cat < "${HOME}/.bazelrc" << EOF -startup --output_user_root=${WORKSPACE}/_bazel_${USER} -test --color=yes -test --keep_going -EOF +# drake source setup +setup/install_prereqs diff --git a/drake_cmake_external/.github/ubuntu_setup b/drake_cmake_external/.github/ubuntu_setup index 0a1ac2ad..c0d49e9d 100755 --- a/drake_cmake_external/.github/ubuntu_setup +++ b/drake_cmake_external/.github/ubuntu_setup @@ -3,10 +3,20 @@ set -euxo pipefail +if [[ "${EUID:-}" -ne 0 ]]; then + echo 'This script must be run as root' >&2 + exit 2 +fi + echo 'APT::Acquire::Retries "4";' > /etc/apt/apt.conf.d/80-acquire-retries echo 'APT::Get::Assume-Yes "true";' > /etc/apt/apt.conf.d/90-get-assume-yes export DEBIAN_FRONTEND='noninteractive' -cd $(dirname "${BASH_SOURCE}")/.. -setup/install_prereqs +apt-get update +apt-get install --no-install-recommends lsb-release + +if [[ "$(lsb_release -sc)" != 'jammy' ]]; then + echo 'This script requires Ubuntu 22.04 (Jammy)' >&2 + exit 3 +fi diff --git a/drake_cmake_external/README.md b/drake_cmake_external/README.md index 696e6cc7..69560b69 100644 --- a/drake_cmake_external/README.md +++ b/drake_cmake_external/README.md @@ -2,14 +2,29 @@ This pulls in Drake using the CMake `ExternalProject_Add(drake)` mechanism. -To build all apps using CMake and Make: +## Instructions + +First, run the `install_prereqs` script to download the drake source and run +drake's source setup script to install the required Ubuntu packages: + +``` +./setup/install_prereqs.sh +``` + +Keep in mind that within the top-level CMakeLists, the drake source is once +again downloaded as an external project. If the CMakeLists is modified to use +a specific version of drake other than master, and any dependencies have +changed within that version, then the script ran above must also be modified. + +Once all necessary dependencies have been installed, build and run tests +using CMake: ``` mkdir build cd build cmake .. -make -``` - -**Under Construction** +cmake --build . +cd drake_external_examples +ctest -V . +``` diff --git a/drake_cmake_external/setup/install_prereqs b/drake_cmake_external/setup/install_prereqs index 20ba6acc..4d2ae327 100755 --- a/drake_cmake_external/setup/install_prereqs +++ b/drake_cmake_external/setup/install_prereqs @@ -31,119 +31,18 @@ set -euxo pipefail -ros_humble=0 - -while [ "${1:-}" != "" ]; do - case "$1" in - --ros-humble) - ros_humble=1 - ;; - *) - echo 'Invalid command line argument' >&2 - exit 1 - esac - shift -done - -if [[ "${EUID:-}" -ne 0 ]]; then - echo 'This script must be run as root' >&2 - exit 2 -fi - -apt-get update -apt-get install --no-install-recommends lsb-release - -if [[ "$(lsb_release -sc)" != 'jammy' ]]; then - echo 'This script requires Ubuntu 22.04 (Jammy)' >&2 - exit 3 -fi - -apt-get install --no-install-recommends $(cat < /etc/apt/sources.list.d/bazel.list +# Setup script +tar -xf drake.tar.gz -apt-get update -apt-get install --no-install-recommends $(cat < /etc/apt/sources.list.d/ros2-latest.list - - apt-get update - apt-get install --no-install-recommends $(cat <