mirror of
https://github.com/opnsense/src.git
synced 2026-02-18 18:20:26 -05:00
Release notes are available at https://www.openssh.com/txt/release-9.1 9.1 contains fixes for three minor memory safety problems; these have lready been merged to the copy of OpenSSH 9.0 that is in the FreeBSD base system. Some highlights copied from the release notes: Potentially-incompatible changes -------------------------------- * ssh(1), sshd(8): SetEnv directives in ssh_config and sshd_config are now first-match-wins to match other directives. Previously if an environment variable was multiply specified the last set value would have been used. bz3438 * ssh-keygen(8): ssh-keygen -A (generate all default host key types) will no longer generate DSA keys, as these are insecure and have not been used by default for some years. New features ------------ * ssh(1), sshd(8): add a RequiredRSASize directive to set a minimum RSA key length. Keys below this length will be ignored for user authentication and for host authentication in sshd(8). * sftp-server(8): add a "users-groups-by-id@openssh.com" extension request that allows the client to obtain user/group names that correspond to a set of uids/gids. * sftp(1): use "users-groups-by-id@openssh.com" sftp-server extension (when available) to fill in user/group names for directory listings. * sftp-server(8): support the "home-directory" extension request defined in draft-ietf-secsh-filexfer-extensions-00. This overlaps a bit with the existing "expand-path@openssh.com", but some other clients support it. * ssh-keygen(1), sshd(8): allow certificate validity intervals, sshsig verification times and authorized_keys expiry-time options to accept dates in the UTC time zone in addition to the default of interpreting them in the system time zone. YYYYMMDD and YYMMDDHHMM[SS] dates/times will be interpreted as UTC if suffixed with a 'Z' character. Also allow certificate validity intervals to be specified in raw seconds-since-epoch as hex value, e.g. -V 0x1234:0x4567890. This is intended for use by regress tests and other tools that call ssh-keygen as part of a CA workflow. bz3468 * sftp(1): allow arguments to the sftp -D option, e.g. sftp -D "/usr/libexec/sftp-server -el debug3" * ssh-keygen(1): allow the existing -U (use agent) flag to work with "-Y sign" operations, where it will be interpreted to require that the private keys is hosted in an agent; bz3429 MFC after: 2 weeks Relnotes: Yes Sponsored by: The FreeBSD Foundation
122 lines
5.2 KiB
YAML
122 lines
5.2 KiB
YAML
name: C/C++ CI
|
|
|
|
on:
|
|
push:
|
|
branches: [ master, ci, V_9_0 ]
|
|
paths: [ '**.c', '**.h', '**.m4', '**.sh', '.github/**', 'Makefile.in', 'configure.ac' ]
|
|
pull_request:
|
|
branches: [ master ]
|
|
paths: [ '**.c', '**.h', '**.m4', '**.sh', '.github/**', 'Makefile.in', 'configure.ac' ]
|
|
|
|
jobs:
|
|
ci:
|
|
if: github.repository != 'openssh/openssh-portable-selfhosted'
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
# First we test all OSes in the default configuration.
|
|
os: [ubuntu-20.04, ubuntu-22.04, macos-11, macos-12, windows-2019, windows-2022]
|
|
configs: [default]
|
|
# Then we include any extra configs we want to test for specific VMs.
|
|
# Valgrind slows things down quite a bit, so start them first.
|
|
include:
|
|
- { os: windows-2019, configs: cygwin-release }
|
|
- { os: windows-2022, configs: cygwin-release }
|
|
- { os: ubuntu-20.04, configs: valgrind-1 }
|
|
- { os: ubuntu-20.04, configs: valgrind-2 }
|
|
- { os: ubuntu-20.04, configs: valgrind-3 }
|
|
- { os: ubuntu-20.04, configs: valgrind-4 }
|
|
- { os: ubuntu-20.04, configs: valgrind-unit }
|
|
- { os: ubuntu-20.04, configs: c89 }
|
|
- { os: ubuntu-20.04, configs: clang-6.0 }
|
|
- { os: ubuntu-20.04, configs: clang-8 }
|
|
- { os: ubuntu-20.04, configs: clang-9 }
|
|
- { os: ubuntu-20.04, configs: clang-10 }
|
|
- { os: ubuntu-20.04, configs: clang-11 }
|
|
- { os: ubuntu-20.04, configs: clang-12-Werror }
|
|
- { os: ubuntu-20.04, configs: clang-sanitize-address }
|
|
- { os: ubuntu-20.04, configs: clang-sanitize-undefined }
|
|
- { os: ubuntu-20.04, configs: gcc-sanitize-address }
|
|
- { os: ubuntu-20.04, configs: gcc-sanitize-undefined }
|
|
- { os: ubuntu-20.04, configs: gcc-7 }
|
|
- { os: ubuntu-20.04, configs: gcc-8 }
|
|
- { os: ubuntu-20.04, configs: gcc-10 }
|
|
- { os: ubuntu-20.04, configs: gcc-11-Werror }
|
|
- { os: ubuntu-20.04, configs: pam }
|
|
- { os: ubuntu-20.04, configs: kitchensink }
|
|
- { os: ubuntu-20.04, configs: hardenedmalloc }
|
|
- { os: ubuntu-20.04, configs: tcmalloc }
|
|
- { os: ubuntu-20.04, configs: musl }
|
|
- { os: ubuntu-latest, configs: libressl-master }
|
|
- { os: ubuntu-latest, configs: libressl-2.2.9 }
|
|
- { os: ubuntu-latest, configs: libressl-2.8.3 }
|
|
- { os: ubuntu-latest, configs: libressl-3.0.2 }
|
|
- { os: ubuntu-latest, configs: libressl-3.2.6 }
|
|
- { os: ubuntu-latest, configs: libressl-3.3.6 }
|
|
- { os: ubuntu-latest, configs: libressl-3.4.3 }
|
|
- { os: ubuntu-latest, configs: libressl-3.5.3 }
|
|
- { os: ubuntu-latest, configs: openssl-master }
|
|
- { os: ubuntu-latest, configs: openssl-noec }
|
|
- { os: ubuntu-latest, configs: openssl-1.0.1 }
|
|
- { os: ubuntu-latest, configs: openssl-1.0.1u }
|
|
- { os: ubuntu-latest, configs: openssl-1.0.2u }
|
|
- { os: ubuntu-latest, configs: openssl-1.1.0h }
|
|
- { os: ubuntu-latest, configs: openssl-1.1.1 }
|
|
- { os: ubuntu-latest, configs: openssl-1.1.1k }
|
|
- { os: ubuntu-latest, configs: openssl-1.1.1n }
|
|
- { os: ubuntu-latest, configs: openssl-1.1.1p }
|
|
- { os: ubuntu-latest, configs: openssl-3.0.0 }
|
|
- { os: ubuntu-latest, configs: openssl-3.0.5 }
|
|
- { os: ubuntu-latest, configs: openssl-1.1.1_stable } # stable branch
|
|
- { os: ubuntu-latest, configs: openssl-3.0 } # stable branch
|
|
- { os: ubuntu-22.04, configs: pam }
|
|
- { os: ubuntu-22.04, configs: krb5 }
|
|
- { os: ubuntu-22.04, configs: heimdal }
|
|
- { os: ubuntu-22.04, configs: libedit }
|
|
- { os: ubuntu-22.04, configs: sk }
|
|
- { os: ubuntu-22.04, configs: selinux }
|
|
- { os: ubuntu-22.04, configs: kitchensink }
|
|
- { os: ubuntu-22.04, configs: without-openssl }
|
|
- { os: macos-11, configs: pam }
|
|
- { os: macos-12, configs: pam }
|
|
runs-on: ${{ matrix.os }}
|
|
steps:
|
|
- name: set cygwin git params
|
|
if: ${{ startsWith(matrix.os, 'windows') }}
|
|
run: git config --global core.autocrlf input
|
|
- name: install cygwin
|
|
if: ${{ startsWith(matrix.os, 'windows') }}
|
|
uses: cygwin/cygwin-install-action@master
|
|
- uses: actions/checkout@v2
|
|
- name: setup CI system
|
|
run: sh ./.github/setup_ci.sh ${{ matrix.configs }}
|
|
- name: autoreconf
|
|
run: sh -c autoreconf
|
|
- name: configure
|
|
run: sh ./.github/configure.sh ${{ matrix.configs }}
|
|
- name: save config
|
|
uses: actions/upload-artifact@v2
|
|
with:
|
|
name: ${{ matrix.os }}-${{ matrix.configs }}-config
|
|
path: config.h
|
|
- name: make clean
|
|
run: make clean
|
|
- name: make
|
|
run: make -j2
|
|
- name: make tests
|
|
run: sh ./.github/run_test.sh ${{ matrix.configs }}
|
|
env:
|
|
TEST_SSH_UNSAFE_PERMISSIONS: 1
|
|
TEST_SSH_HOSTBASED_AUTH: yes
|
|
- name: save logs
|
|
if: failure()
|
|
uses: actions/upload-artifact@v2
|
|
with:
|
|
name: ${{ matrix.os }}-${{ matrix.configs }}-logs
|
|
path: |
|
|
config.h
|
|
config.log
|
|
regress/*.log
|
|
regress/valgrind-out/
|
|
regress/asan.log.*
|
|
regress/msan.log.*
|