#*************************************************************************** # _ _ ____ _ # Project ___| | | | _ \| | # / __| | | | |_) | | # | (__| |_| | _ <| |___ # \___|\___/|_| \_\_____| # # Copyright (C) Daniel Stenberg, , et al. # # This software is licensed as described in the file COPYING, which # you should have received as part of this distribution. The terms # are also available at https://curl.se/docs/copyright.html. # # You may opt to use, copy, modify, merge, publish, distribute and/or sell # copies of the Software, and permit persons to whom the Software is # furnished to do so, under the terms of the COPYING file. # # This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY # KIND, either express or implied. # # SPDX-License-Identifier: curl # ########################################################################### # View these jobs in the browser: https://app.circleci.com/pipelines/github/curl/curl # Use the latest 2.1 version of CircleCI pipeline process engine. See: https://circleci.com/docs/configuration-reference/ version: 2.1 commands: install-cares: steps: - run: command: | sudo apt-get update && sudo apt-get install -y libc-ares-dev install-libssh: steps: - run: command: | sudo apt-get update && sudo apt-get install -y libssh-dev install-deps: steps: - run: command: | sudo apt-get update && sudo apt-get install -y libpsl-dev libbrotli-dev libzstd-dev zlib1g-dev python3-pip libpsl-dev sudo python3 -m pip install impacket install-wolfssl: steps: - run: command: | # renovate: datasource=github-tags depName=wolfSSL/wolfssl versioning=semver extractVersion=^v?(?.+)-stable$ registryUrl=https://github.com WOLFSSL_VER=5.6.0 echo "Installing wolfSSL $WOLFSSL_VER" curl -LOsSf --retry 6 --retry-connrefused --max-time 999 https://github.com/wolfSSL/wolfssl/archive/v$WOLFSSL_VER-stable.tar.gz tar -xzf v$WOLFSSL_VER-stable.tar.gz cd wolfssl-$WOLFSSL_VER-stable ./autogen.sh ./configure --disable-dependency-tracking --enable-tls13 --enable-all --enable-harden --prefix=$HOME/wssl make install install-wolfssh: steps: - run: command: | # renovate: datasource=github-tags depName=wolfSSL/wolfssh versioning=semver extractVersion=^v?(?.+)-stable$ registryUrl=https://github.com WOLFSSH_VER=1.4.12 echo "Installing wolfSSH $WOLFSSH_VER" curl -LOsSf --retry 6 --retry-connrefused --max-time 999 https://github.com/wolfSSL/wolfssh/archive/v$WOLFSSH_VER-stable.tar.gz tar -xzf v$WOLFSSH_VER-stable.tar.gz cd wolfssh-$WOLFSSH_VER-stable ./autogen.sh ./configure --disable-dependency-tracking --with-wolfssl=$HOME/wssl --prefix=$HOME/wssh --enable-scp --enable-sftp --disable-examples make install configure: steps: - run: command: | autoreconf -fi ./configure --disable-dependency-tracking --enable-unity --enable-test-bundles --enable-werror --enable-warnings \ --with-openssl \ || { tail -1000 config.log; false; } configure-openssl-no-verbose: steps: - run: command: | autoreconf -fi ./configure --disable-dependency-tracking --enable-unity --enable-test-bundles --enable-werror \ --with-openssl --disable-verbose \ || { tail -1000 config.log; false; } configure-no-proxy: steps: - run: command: | autoreconf -fi ./configure --disable-dependency-tracking --enable-unity --enable-test-bundles --enable-werror \ --with-openssl --disable-proxy \ || { tail -1000 config.log; false; } configure-libssh: steps: - run: command: | autoreconf -fi ./configure --disable-dependency-tracking --enable-unity --enable-test-bundles --enable-werror --enable-warnings \ --with-openssl --with-libssh \ || { tail -1000 config.log; false; } configure-cares: steps: - run: command: | autoreconf -fi ./configure --disable-dependency-tracking --enable-unity --enable-test-bundles --enable-werror --enable-warnings \ --with-openssl --enable-ares \ || { tail -1000 config.log; false; } configure-wolfssh: steps: - run: command: | autoreconf -fi LDFLAGS="-Wl,-rpath,$HOME/wssh/lib" \ ./configure --disable-dependency-tracking --enable-unity --enable-test-bundles --enable-werror --enable-warnings \ --with-wolfssl=$HOME/wssl --with-wolfssh=$HOME/wssh \ || { tail -1000 config.log; false; } configure-cares-debug: steps: - run: command: | autoreconf -fi ./configure --disable-dependency-tracking --enable-unity --enable-test-bundles --enable-werror --enable-debug \ --with-openssl --enable-ares \ || { tail -1000 config.log; false; } build: steps: - run: make -j3 V=1 - run: make -j3 V=1 examples test: steps: - run: make -j3 V=1 test-ci TFLAGS='-j14' executors: ubuntu: machine: image: ubuntu-2004:2024.01.1 jobs: basic: executor: ubuntu steps: - checkout - install-deps - configure - build - test no-verbose: executor: ubuntu steps: - checkout - install-deps - configure-openssl-no-verbose - build wolfssh: executor: ubuntu steps: - checkout - install-deps - install-wolfssl - install-wolfssh - configure-wolfssh - build no-proxy: executor: ubuntu steps: - checkout - install-deps - configure-no-proxy - build - test cares: executor: ubuntu steps: - checkout - install-deps - install-cares - configure-cares - build - test libssh: executor: ubuntu steps: - checkout - install-deps - install-libssh - configure-libssh - build - test arm: machine: image: ubuntu-2004:2024.01.1 resource_class: arm.medium steps: - checkout - install-deps - configure - build - test arm-cares: machine: image: ubuntu-2004:2024.01.1 resource_class: arm.medium steps: - checkout - install-deps - install-cares - configure-cares-debug - build - test workflows: x86-openssl: jobs: - basic openssl-c-ares: jobs: - cares openssl-libssh: jobs: - libssh openssl-no-proxy: jobs: - no-proxy openssl-no-verbose: jobs: - no-verbose wolfssl-wolfssh: jobs: - wolfssh arm-openssl: jobs: - arm arm-openssl-c-ares: jobs: - arm-cares