Update CI, fix Embedded server, improve tests, adjust to MySQL 8 #123
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI | |
on: | |
push: | |
branches: '*' | |
pull_request: | |
branches: '*' | |
jobs: | |
build-matrix: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: mikefarah/yq@master | |
- name: Build matrix | |
id: set-matrix | |
run: | | |
# For each perl-version, dbi-version, server-version and client-version from below list | |
# create build matrix with tupples filled up with default versions of other field. Plus | |
# include combinations specified in include list. Default version is the last specified | |
# in every field. This reduced number of jobs because full build matrix is too big. | |
{ printf "matrix="; yq -o=json '.' | jq -M -c '{ "include" : [ . as $top | del(.include) | map_values(last) as $defaults | ( $top | (keys | map(select(. != "include"))[] | { (.) : $top[.][] }) , .include[] ) | . = $defaults * . ] }'; } << EOF >> $GITHUB_OUTPUT | |
perl-version: | |
- 5.8.1 | |
- 5.8.2 | |
- 5.8.8 | |
- 5.8.9 | |
- 5.10.0 | |
- 5.12.0 | |
- 5.14.0 | |
- 5.16.0 | |
- 5.18.0 | |
- 5.20.0 | |
- 5.22.0 | |
- 5.24.0 | |
- 5.26.0 | |
- 5.28.0 | |
- 5.30.0 | |
- 5.32.0 | |
- 5.34.0 | |
- 5.36.0 | |
- 5.38.0 | |
- system | |
dbi-version: | |
- 1.627 | |
- 1.641 | |
- latest | |
server-version: | |
- mysql-4.1.22 | |
- mysql-5.0.15 | |
- mysql-5.0.96 | |
- mysql-5.1.30 | |
- mysql-5.1.72 | |
- mysql-5.1.73 | |
- mysql-5.5.8 | |
- mysql-5.5.47 | |
- mysql-5.5.49 | |
- mysql-5.5.54 | |
- mysql-5.5.55 | |
- mysql-5.5.56 | |
- mysql-5.5.57 | |
- mysql-5.5.58 | |
- mysql-5.5.60 | |
- mysql-5.5.62 | |
- mysql-5.6.10 | |
- mysql-5.6.30 | |
- mysql-5.6.35 | |
- mysql-5.6.36 | |
- mysql-5.6.37 | |
- mysql-5.6.38 | |
- mysql-5.6.39 | |
- mysql-5.6.40 | |
- mysql-5.6.41 | |
- mysql-5.6.43 | |
- mysql-5.6.45 | |
- mysql-5.6.51 | |
- mysql-5.7.8-rc | |
- mysql-5.7.11 | |
- mysql-5.7.12 | |
- mysql-5.7.17 | |
- mysql-5.7.18 | |
- mysql-5.7.19 | |
- mysql-5.7.20 | |
- mysql-5.7.21 | |
- mysql-5.7.22 | |
- mysql-5.7.23 | |
- mysql-5.7.25 | |
- mysql-5.7.27 | |
- mysql-5.7.43 | |
- mysql-8.0.0-dmr | |
- mysql-8.0.1-dmr | |
- mysql-8.0.2-dmr | |
- mysql-8.0.3-rc | |
- mysql-8.0.4-rc | |
- mysql-8.0.11 | |
- mysql-8.0.12 | |
- mysql-8.0.13 | |
- mysql-8.0.14 | |
- mysql-8.0.15 | |
- mysql-8.0.16 | |
- mysql-8.0.17 | |
- mysql-8.0.20 | |
- mysql-8.0.21 | |
- mysql-8.0.22 | |
- mysql-8.0.33 | |
- mysql-8.0.34 | |
- mysql-8.0.35 | |
- mariadb-5.5.40 | |
- mariadb-5.5.44 | |
- mariadb-5.5.47 | |
- mariadb-5.5.52 | |
- mariadb-5.5.54 | |
- mariadb-5.5.55 | |
- mariadb-5.5.56 | |
- mariadb-5.5.57 | |
- mariadb-5.5.58 | |
- mariadb-5.5.59 | |
- mariadb-5.5.60 | |
- mariadb-5.5.61 | |
- mariadb-5.5.63 | |
- mariadb-5.5.65 | |
- mariadb-5.5.68 | |
- mariadb-10.0.14 | |
- mariadb-10.0.20 | |
- mariadb-10.0.23 | |
- mariadb-10.0.29 | |
- mariadb-10.0.30 | |
- mariadb-10.0.31 | |
- mariadb-10.0.32 | |
- mariadb-10.0.34 | |
- mariadb-10.0.36 | |
- mariadb-10.0.38 | |
- mariadb-10.1.2 | |
- mariadb-10.1.8 | |
- mariadb-10.1.11 | |
- mariadb-10.1.20 | |
- mariadb-10.1.22 | |
- mariadb-10.1.24 | |
- mariadb-10.1.30 | |
- mariadb-10.1.31 | |
- mariadb-10.1.33 | |
- mariadb-10.1.36 | |
- mariadb-10.1.37 | |
- mariadb-10.1.38 | |
- mariadb-10.1.41 | |
- mariadb-10.1.48 | |
- mariadb-10.2.0 | |
- mariadb-10.2.1 | |
# Incompatible, broken mysql_config | |
# - mariadb-10.2.2 | |
# - mariadb-10.2.3 | |
- mariadb-10.2.4 | |
- mariadb-10.2.5 | |
- mariadb-10.2.6 | |
- mariadb-10.2.7 | |
- mariadb-10.2.8 | |
- mariadb-10.2.9 | |
- mariadb-10.2.10 | |
- mariadb-10.2.11 | |
- mariadb-10.2.12 | |
- mariadb-10.2.13 | |
- mariadb-10.2.15 | |
- mariadb-10.2.18 | |
- mariadb-10.2.19 | |
- mariadb-10.2.20 | |
- mariadb-10.2.21 | |
- mariadb-10.2.22 | |
- mariadb-10.2.26 | |
- mariadb-10.2.44 | |
- mariadb-10.3.0 | |
- mariadb-10.3.1 | |
- mariadb-10.3.2 | |
- mariadb-10.3.3 | |
- mariadb-10.3.4 | |
- mariadb-10.3.6 | |
- mariadb-10.3.7 | |
- mariadb-10.3.8 | |
- mariadb-10.3.10 | |
- mariadb-10.3.11 | |
- mariadb-10.3.12 | |
- mariadb-10.3.17 | |
- mariadb-10.3.39 | |
- mariadb-10.4.0 | |
- mariadb-10.4.1 | |
- mariadb-10.4.2 | |
# Incompatible, unsupported by MySQL::Sandbox | |
# - mariadb-10.4.3 | |
# - mariadb-10.4.4 | |
# - mariadb-10.4.5 | |
# - mariadb-10.4.6 | |
# - mariadb-10.4.7 | |
- system | |
client-version: | |
- mysqlconc-6.0.0-beta | |
- mysqlconc-6.0.2 | |
- mysqlconc-6.1.0 | |
- mysqlconc-6.1.9 | |
- mysqlconc-6.1.10 | |
- mysqlconc-6.1.11 | |
- mysqlconc-6.2.0-labs | |
# Incompatible, broken buffer for prepared statements | |
# - mariadbconc-2.2.0 | |
# - mariadbconc-2.2.3 | |
# - mariadbconc-2.3.0 | |
- mariadbconc-2.3.1 | |
- mariadbconc-2.3.2 | |
- mariadbconc-2.3.3 | |
- mariadbconc-2.3.4 | |
- mariadbconc-2.3.5 | |
- mariadbconc-2.3.6 | |
- mariadbconc-2.3.7 | |
# Incompatible, client library freeze | |
# - mariadbconc-3.0.0-alpha | |
# Incompatible, missing header files | |
# - mariadbconc-3.0.1-beta | |
- mariadbconc-3.0.2 | |
# Incompatible, broken buffer for prepared statements | |
# - mariadbconc-3.0.3 | |
- mariadbconc-3.0.4 | |
- mariadbconc-3.0.5 | |
- mariadbconc-3.0.6 | |
- mariadbconc-3.0.7 | |
- mariadbconc-3.0.8 | |
- mariadbconc-3.0.9 | |
- mariadbconc-3.0.10 | |
- mariadbconc-3.1.0 | |
- mariadbconc-3.1.1 | |
- mariadbconc-3.1.2 | |
- mariadbconc-3.1.3 | |
- mariadbconc-3.1.10 | |
- mariadbconc-3.1.21 | |
- mariadbconc-3.2.0 | |
- mariadbconc-3.2.7 | |
- mariadbconc-3.3.0-rc1 | |
- mariadbconc-3.3.5 | |
- system | |
- same-as-server | |
include: | |
- server-version: mysql-5.0.96 | |
client-version: mariadbconc-2.3.4 | |
- server-version: mysql-5.1.72 | |
client-version: mariadbconc-3.0.2 | |
- server-version: mariadb-5.5.40 | |
client-version: mysqlconc-6.1.11 | |
- server-version: mysql-8.0.3-rc | |
client-version: mariadbconc-2.3.0 | |
- server-version: mariadb-10.3.3 | |
client-version: mysqlconc-6.0.0-beta | |
- server-version: mariadb-10.3.3 | |
client-version: mysqlconc-6.1.11 | |
- server-version: mysql-8.0.3-rc | |
client-version: mariadbconc-3.0.2 | |
- server-version: mysql-5.6.38 | |
client-version: mysqlconc-6.1.11 | |
- server-version: mariadb-10.1.30 | |
client-version: mariadbconc-3.0.2 | |
- server-version: mysql-4.1.22 | |
client-version: mariadbconc-3.0.6 | |
# MySQL client versions 8.0.4 - 8.0.34 and 8.1.0 have bug which | |
# prevents connection to MySQL server versions prior 5.5.7 | |
- server-version: mysql-4.1.22 | |
client-version: mysql-8.0.38 | |
- server-version: mysql-4.1.22 | |
client-version: mysql-8.0.39 | |
- server-version: mysql-4.1.22 | |
client-version: mysql-8.0.40 | |
- server-version: mysql-4.1.22 | |
client-version: mysql-8.4.0 | |
- server-version: mysql-4.1.22 | |
client-version: mysql-8.4.1 | |
- server-version: mysql-4.1.22 | |
client-version: mysql-8.4.2 | |
- server-version: mysql-4.1.22 | |
client-version: mysql-8.4.3 | |
- server-version: mysql-5.1.72 | |
client-version: mysql-8.0.3-rc | |
- server-version: system-pic | |
client-version: system-pic | |
- server-version: mysql-5.7.43 | |
client-version: system-pic | |
- server-version: mysql-8.0.35 | |
client-version: system-pic | |
- server-version: mariadb-5.5.40 | |
client-version: system-pic | |
- server-version: mariadb-10.0.38 | |
client-version: system-pic | |
- server-version: mariadb-10.2.44 | |
client-version: system-pic | |
- server-version: mariadb-10.4.2 | |
client-version: system-pic | |
- server-version: none | |
client-version: system | |
- perl-version: 5.12.0 | |
dbi-version: 1.608 | |
EOF | |
outputs: | |
matrix: ${{ steps.set-matrix.outputs.matrix }} | |
build-n-test: | |
name: perl-${{ matrix.perl-version }}/${{ matrix.server-version }}/${{ matrix.client-version }}/dbi-${{ matrix.dbi-version }} | |
needs: build-matrix | |
runs-on: ubuntu-22.04 | |
strategy: | |
fail-fast: false | |
matrix: ${{ fromJson(needs.build-matrix.outputs.matrix) }} | |
steps: | |
- name: Checkout git commit ${{ github.sha }} | |
if: github.event_name != 'pull_request' | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.sha }} | |
- name: Checkout git commit ${{ github.event.pull_request.head.sha }} (fixup for pull request) | |
if: github.event_name == 'pull_request' | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ github.event.pull_request.head.sha }} | |
- name: Setup cpan sources cache | |
uses: actions/cache@v4 | |
with: | |
path: ~/.cpan/sources | |
key: cache-cpan | |
- name: Uninstall system MySQL/MariaDB | |
run: | | |
sudo apt purge `{ dpkg --get-selections '*mysql*'; dpkg --get-selections '*mariadb*'; } | sed 's/[:\t].*//'` | |
- name: Install client dependences (1) | |
if: ${{ matrix.client-version != 'system' && ( matrix.server-version != 'system' || matrix.client-version != 'same-as-server' ) }} | |
run: | | |
sudo apt install libgnutls28-dev libncurses5 libncursesw5 libstdc++5 | |
- name: Install client dependences (2) | |
if: ${{ matrix.client-version != 'system' && ( matrix.server-version != 'system' || matrix.client-version != 'same-as-server' ) }} | |
run: | | |
wget --progress=bar:force http://security.ubuntu.com/ubuntu/pool/main/o/openssl1.0/libssl1.0.0_1.0.2n-1ubuntu5_amd64.deb -O /tmp/libssl1.0.0_1.0.2n-1ubuntu5_amd64.deb | |
wget --progress=bar:force http://security.ubuntu.com/ubuntu/pool/universe/j/jemalloc/libjemalloc1_3.6.0-11_amd64.deb -O /tmp/libjemalloc1_3.6.0-11_amd64.deb | |
sudo dpkg -i /tmp/libssl1.0.0_1.0.2n-1ubuntu5_amd64.deb /tmp/libjemalloc1_3.6.0-11_amd64.deb | |
- name: Install MariaDB client system | |
if: ${{ matrix.client-version == 'system' || ( matrix.server-version == 'system' && matrix.client-version == 'same-as-server' ) }} | |
run: | | |
sudo apt install libmariadb-dev | |
- name: Install MariaDB server system | |
if: ${{ matrix.server-version == 'system' }} | |
run: | | |
sudo apt install mariadb-server | |
sudo systemctl start mariadb.service | |
sudo mariadb -e "GRANT ALL PRIVILEGES ON test.* TO 'test'@'localhost' IDENTIFIED BY 'test'" | |
- name: Install MySQL embedded PIC library | |
if: ${{ matrix.client-version == 'system-pic' || matrix.server-version == 'system-pic' }} | |
run: | | |
wget --progress=bar:force http://archive.ubuntu.com/ubuntu/pool/universe/m/mysql-5.5/libmysqld-pic_5.5.62-0ubuntu0.14.04.1_amd64.deb -O /tmp/libmysqld-pic_5.5.62-0ubuntu0.14.04.1_amd64.deb | |
wget --progress=bar:force http://archive.ubuntu.com/ubuntu/pool/main/m/mysql-5.5/libmysqlclient-dev_5.5.62-0ubuntu0.14.04.1_amd64.deb -O /tmp/libmysqlclient-dev_5.5.62-0ubuntu0.14.04.1_amd64.deb | |
wget --progress=bar:force http://archive.ubuntu.com/ubuntu/pool/main/m/mysql-5.5/libmysqlclient18_5.5.62-0ubuntu0.14.04.1_amd64.deb -O /tmp/libmysqlclient18_5.5.62-0ubuntu0.14.04.1_amd64.deb | |
wget --progress=bar:force http://archive.ubuntu.com/ubuntu/pool/main/g/glibc/multiarch-support_2.27-3ubuntu1.6_amd64.deb -O /tmp/multiarch-support_2.27-3ubuntu1.6_amd64.deb | |
sudo apt install libaio-dev libwrap0-dev | |
sudo apt install /tmp/libmysqld-pic_5.5.62-0ubuntu0.14.04.1_amd64.deb /tmp/libmysqlclient-dev_5.5.62-0ubuntu0.14.04.1_amd64.deb /tmp/libmysqlclient18_5.5.62-0ubuntu0.14.04.1_amd64.deb /tmp/multiarch-support_2.27-3ubuntu1.6_amd64.deb | |
echo 'extern int sched_yield(void); int pthread_yield(void) { return sched_yield(); }' > "$HOME/libpthread_yield.c" | |
gcc -O2 -o "$HOME/libpthread_yield.o" -c "$HOME/libpthread_yield.c" | |
rm -f "$HOME/libpthread_yield.a" | |
ar rcs "$HOME/libpthread_yield.a" "$HOME/libpthread_yield.o" | |
sudo cp "$HOME/libpthread_yield.a" /usr/lib/mysql/ | |
- name: Install Perl system | |
if: ${{ matrix.perl-version == 'system' }} | |
run: | | |
sudo apt install perl cpanminus liblocal-lib-perl | |
mkdir -p "$HOME"/perl5 | |
- name: Install Perl ${{ matrix.perl-version }} | |
if: ${{ matrix.perl-version != 'system' }} | |
uses: shogo82148/actions-setup-perl@v1 | |
with: | |
perl-version: ${{ matrix.perl-version }} | |
- name: Download and Install MariaDB/MySQL server ${{ matrix.server-version }} and client ${{ matrix.client-version }} | |
run: | | |
if [ "${{ matrix.perl-version }}" = "system" ]; then | |
eval $(perl -I"$HOME/perl5/lib/perl5" -Mlocal::lib) | |
fi | |
mkdir -p "$HOME/cache" | |
case "${{ matrix.server-version }}" in | |
mysql*) DB=MySQL ;; | |
mariadb*) DB=MariaDB ;; | |
none) DB=""; ;; | |
system) DB=""; ;; | |
system-pic) DB=""; ;; | |
*) DB=unknown ;; | |
esac | |
case "${{ matrix.client-version }}" in | |
mysql-*) CLIENT_DB=MySQL-Server ;; | |
mysqlconc-*) CLIENT_DB=MySQL-ConC ;; | |
mariadbconc-*) CLIENT_DB=MariaDB-ConC ;; | |
system) CLIENT_DB=""; ;; | |
system-pic) CLIENT_DB=""; ;; | |
same-as-server) CLIENT_DB=""; ;; | |
*) CLIENT_DB=unknown ;; | |
esac | |
VERSION=`echo "${{ matrix.server-version }}" | sed 's/^[^-]*-//'` | |
CLIENT_VERSION=`echo "${{ matrix.client-version }}" | sed 's/^[^-]*-//'` | |
if [ "$DB" = "MySQL" ]; then | |
case "$VERSION" in | |
4.1.*) SANDBOX_URL=https://mysql.linux.cz/Downloads/MySQL-4.1/mysql-standard-$VERSION-unknown-linux-gnu-x86_64-glibc23.tar.gz ;; | |
5.0.[012]*) SANDBOX_URL=https://downloads.mysql.com/archives/get/p/23/file/mysql-standard-$VERSION-linux-x86_64-glibc23.tar.gz ;; | |
5.[01].*) SANDBOX_URL=https://downloads.mysql.com/archives/get/p/23/file/mysql-$VERSION-linux-x86_64-glibc23.tar.gz ;; | |
5.5.?) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux2.6-x86_64.tar.gz ;; | |
5.5.[1234]*) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux2.6-x86_64.tar.gz ;; | |
5.5.5[012345]*) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux2.6-x86_64.tar.gz ;; | |
5.5.56*) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux-glibc2.5-x86_64.tar.gz ;; | |
5.5.*) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux-glibc2.12-x86_64.tar.gz ;; | |
5.6.[12]*) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux-glibc2.5-x86_64.tar.gz ;; | |
5.6.3[0123456]*) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux-glibc2.5-x86_64.tar.gz ;; | |
5.6.*) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux-glibc2.12-x86_64.tar.gz ;; | |
5.7.19*|5.7.[234]*) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux-glibc2.12-x86_64.tar.gz ;; | |
5.7.*) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux-glibc2.5-x86_64.tar.gz ;; | |
8.0.?-*|8.0.11) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux-glibc2.12-x86_64.tar.gz ;; | |
8.0.*) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux-glibc2.12-x86_64.tar.xz ;; | |
8.1.*) SANDBOX_URL=https://dev.mysql.com/get/mysql-$VERSION-linux-glibc2.28-x86_64.tar.xz ;; | |
*) echo "Unsupported MySQL version '$VERSION'"; exit 1 ;; | |
esac | |
SANDBOX_CACHE_FILE="$HOME/cache/$(basename "$SANDBOX_URL")" | |
elif [ "$DB" = "MariaDB" ]; then | |
case "$VERSION" in | |
5.*|10.[012].*) SANDBOX_URL=https://downloads.mariadb.com/MariaDB/mariadb-$VERSION/bintar-linux-x86_64/mariadb-$VERSION-linux-x86_64.tar.gz ;; | |
10.[34].*) SANDBOX_URL=https://downloads.mariadb.com/MariaDB/mariadb-$VERSION/bintar-linux-glibc_214-x86_64/mariadb-$VERSION-linux-glibc_214-x86_64.tar.gz ;; | |
*) echo "Unsupported MariaDB version '$VERSION'"; exit 1 ;; | |
esac | |
SANDBOX_CACHE_FILE="$HOME/cache/$(basename "$SANDBOX_URL")" | |
elif [ -n "$DB" ]; then | |
echo "Unsupported DB '$DB'"; exit 1 | |
fi | |
if [ -n "$DB" ]; then | |
export SANDBOX_HOME="$HOME/sandbox" | |
export SANDBOX_BINARY="$SANDBOX_HOME/binary" | |
export SANDBOX_FILE="$SANDBOX_HOME/$(basename "$SANDBOX_CACHE_FILE")" | |
if [ ! -f "$SANDBOX_CACHE_FILE" ]; then wget --progress=bar:force "$SANDBOX_URL" -O "$SANDBOX_CACHE_FILE" || exit 1; fi | |
mkdir -p "$SANDBOX_HOME" || exit 1 | |
ln -s "$SANDBOX_CACHE_FILE" "$SANDBOX_FILE" || exit 1 | |
if [ `echo "$VERSION" | sed 's/\.//;s/\..*//'` -ge 55 ]; then | |
SANDBOX_OPTIONS="$SANDBOX_OPTIONS --init_options=--innodb_use_native_aio=0 --my_clause=innodb_use_native_aio=0 --my_clause=performance_schema=ON" | |
fi | |
fi | |
if [ "$CLIENT_DB" = "MySQL-ConC" ]; then | |
case "$CLIENT_VERSION" in | |
*-labs) CLIENT_URL=https://downloads.mysql.com/snapshots/pb/mysql-connector-c-$CLIENT_VERSION/mysql-connector-c-$CLIENT_VERSION-linux-glibc2.5-x86_64.tar.gz ;; | |
6.0.*) CLIENT_URL=https://dev.mysql.com/get/mysql-connector-c-$CLIENT_VERSION-linux-glibc2.3-x86-64bit.tar.gz ;; | |
6.1.[0123456789]) CLIENT_URL=https://dev.mysql.com/get/mysql-connector-c-$CLIENT_VERSION-linux-glibc2.5-x86_64.tar.gz ;; | |
6.1.*) CLIENT_URL=https://dev.mysql.com/get/mysql-connector-c-$CLIENT_VERSION-linux-glibc2.12-x86_64.tar.gz ;; | |
*) echo "Unsupported MySQL Connector/C version '$CLIENT_VERSION'"; exit 1 ;; | |
esac | |
CLIENT_FILE="$HOME/cache/$(basename "$CLIENT_URL")" | |
elif [ "$CLIENT_DB" = "MariaDB-ConC" ]; then | |
case "$CLIENT_VERSION" in | |
3.0.*) CLIENT_URL=https://downloads.mariadb.com/Connectors/c/connector-c-${CLIENT_VERSION/-*/}/mariadb-connector-c-$CLIENT_VERSION-linux-x86_64.tar.gz ;; | |
3.1.[01234567]) CLIENT_URL=https://downloads.mariadb.com/Connectors/c/connector-c-${CLIENT_VERSION/-*/}/mariadb-connector-c-$CLIENT_VERSION-linux-x86_64.tar.gz ;; | |
3.*) CLIENT_URL=https://downloads.mariadb.com/Connectors/c/connector-c-${CLIENT_VERSION/-*/}/mariadb-connector-c-$CLIENT_VERSION-ubuntu-focal-amd64.tar.gz ;; | |
*) CLIENT_URL=https://downloads.mariadb.com/Connectors/c/connector-c-${CLIENT_VERSION/-*/}/mariadb-connector-c-$CLIENT_VERSION-linux-x86_64.tar.gz ;; | |
esac | |
CLIENT_FILE="$HOME/cache/$(basename "$CLIENT_URL")" | |
elif [ "$CLIENT_DB" = "MySQL-Server" ]; then | |
case "$CLIENT_VERSION" in | |
# FIXME: Only MySQL 8.x server versions are defined here for usage as client library for now | |
8.0.?-*|8.0.11) CLIENT_URL=https://dev.mysql.com/get/mysql-$CLIENT_VERSION-linux-glibc2.12-x86_64.tar.gz ;; | |
8.0.*) CLIENT_URL=https://dev.mysql.com/get/mysql-$CLIENT_VERSION-linux-glibc2.12-x86_64.tar.xz ;; | |
8.1.*) CLIENT_URL=https://dev.mysql.com/get/mysql-$CLIENT_VERSION-linux-glibc2.28-x86_64.tar.xz ;; | |
*) echo "Unsupported MySQL version '$CLIENT_VERSION'"; exit 1 ;; | |
esac | |
CLIENT_FILE="$HOME/cache/$(basename "$CLIENT_URL")" | |
elif [ -n "$CLIENT_DB" ]; then | |
echo "Unsupported Connector/C '$CLIENT_DB'"; exit 1 | |
fi | |
if [ -n "$CLIENT_DB" ]; then | |
if [ ! -f "$CLIENT_FILE" ]; then wget --progress=bar:force "$CLIENT_URL" -O "$CLIENT_FILE" || exit 1; fi | |
fi | |
if [ "${{ matrix.client-version }}" = "system-pic" ]; then | |
sed 's/-L\$pkglibdir *-lmysqld/-L\/usr\/lib\/mysql -lmysqld_pic -lpthread_yield /' `which mysql_config_pic` > "$HOME/mysql_config_pic" | |
chmod +x $HOME/mysql_config_pic | |
fi | |
if [ "${{ matrix.client-version }}" = "system-pic" ] || [ "${{ matrix.server-version }}" = "system-pic" ]; then | |
wget --progress=bar:force http://archive.ubuntu.com/ubuntu/pool/main/m/mysql-5.5/mysql-server-core-5.5_5.5.62-0ubuntu0.14.04.1_amd64.deb -O /tmp/mysql-server-core-5.5_5.5.62-0ubuntu0.14.04.1_amd64.deb | |
dpkg -x /tmp/mysql-server-core-5.5_5.5.62-0ubuntu0.14.04.1_amd64.deb $HOME/mysql-server-core-5.5 | |
mkdir -p "$HOME/datadir" | |
fi | |
if [ -n "$DB" ]; then | |
cpanm --quiet --notest --skip-satisfied MySQL::Sandbox || exit 1 | |
if [[ $SANDBOX_FILE =~ .xz$ ]]; then | |
unxz < "$SANDBOX_FILE" | gzip -1 > "${SANDBOX_FILE%.xz}.gz" | |
SANDBOX_FILE="${SANDBOX_FILE%.xz}.gz" | |
fi | |
make_sandbox --export_binaries "$SANDBOX_FILE" -- --sandbox_port 3310 --sandbox_directory msb --no_confirm --verbose $SANDBOX_OPTIONS || exit 1 | |
sed 's/-lzlib //g' -i $SANDBOX_HOME/*/bin/mysql_config | |
rm -f $SANDBOX_HOME/*/bin/mariadb_config | |
printf '#!/bin/sh\nexec %s/msb/my sql_config "$@"\n' $SANDBOX_HOME > "$HOME/mysql_config" | |
chmod +x $HOME/mysql_config | |
fi | |
if [ -n "$CLIENT_DB" ]; then | |
mkdir -p "$HOME/client" | |
tar --strip-components=1 --directory="$HOME/client" -xf "$CLIENT_FILE" || exit 1 | |
if $HOME/client/bin/mysql_config 2>&1 | grep -q /usr/local; then | |
rm -f $HOME/client/bin/mysql_config | |
fi | |
if [ -x $HOME/client/bin/mysql_config ]; then | |
sed 's/-l "/-lmysqlclient "/g' -i "$HOME/client/bin/mysql_config" || exit 1 | |
fi | |
fi | |
- name: Setup DBD_MARIADB_* env | |
run: | | |
if [ "${{ matrix.perl-version }}" = "system" ]; then | |
eval $(perl -I"$HOME/perl5/lib/perl5" -Mlocal::lib) | |
fi | |
if [ "${{ matrix.server-version }}" = "system" ]; then | |
export DBD_MARIADB_TESTUSER=test | |
export DBD_MARIADB_TESTPASSWORD=test | |
export DBD_MARIADB_TESTHOST=127.0.0.1 | |
export DBD_MARIADB_TESTPORT=3306 | |
elif [ "${{ matrix.server-version }}" = "system-pic" ]; then | |
export DBD_MARIADB_TESTHOST=embedded | |
export DBD_MARIADB_TESTEMBDATADIR="$HOME/datadir" | |
elif [ "${{ matrix.server-version }}" = "none" ]; then | |
export DBD_MARIADB_TESTHOST=0.0.0.0 | |
export DBD_MARIADB_TESTPORT=0 | |
else | |
export DBD_MARIADB_TESTUSER=msandbox | |
export DBD_MARIADB_TESTPASSWORD=msandbox | |
export DBD_MARIADB_TESTHOST=127.0.0.1 | |
export DBD_MARIADB_TESTPORT=3310 | |
fi | |
if [[ ${{ matrix.client-version }} =~ mysql-8 ]]; then | |
export DBD_MARIADB_TESTAUTHPLUGIN=mysql_native_password | |
fi | |
if [ "${{ matrix.client-version }}" != "system" ] && [ "${{ matrix.client-version }}" != "system-pic" ] && [ "${{ matrix.client-version }}" != "same-as-server" ]; then | |
if [ -x $HOME/client/bin/mysql_config ]; then | |
export DBD_MARIADB_CONFIG="$HOME/client/bin/mysql_config" | |
else | |
INCLUDE_PATH=`find "$HOME/client" -name "mysql.h" | sort | head -1` | |
if [ -z "$INCLUDE_PATH" ]; then echo "File mysql.h was not found"; exit 1; fi | |
LIB_PATH=`find "$HOME/client" -name "lib*.so" | sort | head -1` | |
if [ -z "$INCLUDE_PATH" ]; then echo "File lib*.so was not found"; exit 1; fi | |
export DBD_MARIADB_CFLAGS="-I`dirname $INCLUDE_PATH`" | |
export DBD_MARIADB_LIBS="-L`dirname $LIB_PATH` -l`echo $LIB_PATH | sed 's/.*\/lib//;s/\.so//'`" | |
export DBD_MARIADB_CONFIG="skip" | |
fi | |
elif [ "${{ matrix.client-version }}" = "same-as-server" ] && [ "${{ matrix.server-version }}" != "system" ]; then | |
export DBD_MARIADB_CONFIG="$HOME/mysql_config" | |
export DBD_MARIADB_TESTEMBOPTIONS="--language=`find $HOME/sandbox/* -name english | sed 's/english//'`,--log-error=/dev/null" | |
elif [ "${{ matrix.client-version }}" = "system-pic" ]; then | |
export DBD_MARIADB_CONFIG="$HOME/mysql_config_pic" | |
export DBD_MARIADB_TESTEMBOPTIONS="--language=$HOME/mysql-server-core-5.5/usr/share/mysql/,--log-error=/dev/null" | |
export DBD_MARIADB_REQUIREEMBSUP=1 | |
fi | |
export | sed 's/^declare -x //;s/="/=/;s/"$//' | grep '^DBD_MARIADB_' >> $GITHUB_ENV | |
- name: Install dependences | |
run: | | |
if [ "${{ matrix.perl-version }}" = "system" ]; then | |
eval $(perl -I"$HOME/perl5/lib/perl5" -Mlocal::lib) | |
fi | |
perl '-MExtUtils::MakeMaker 7.00' -e '' || cpanm --quiet --notest ExtUtils::[email protected] | |
perl '-MCPAN::Meta 2.112580' -e '' || cpanm --quiet --notest CPAN::[email protected] | |
perl '-Mv5.12' -e '' || cpanm --quiet --notest Test::[email protected] | |
if [ "${{ matrix.dbi-version }}" != "latest" ]; then cpanm --quiet --notest DBI@${{ matrix.dbi-version }}; fi | |
cpanm --quiet --notest --skip-satisfied DBI~1.608 Devel::CheckLib~1.12 | |
cpanm --quiet --notest --skip-satisfied --installdeps --with-configure --with-develop --with-recommends --with-suggests . &> $HOME/cpanm_fail || { cat "$HOME"/cpanm_fail ; cat `grep -o '/home/runner.*log' "$HOME"/cpanm_fail` ; exit 1; } | |
- name: Configure | |
run: | | |
if [ "${{ matrix.perl-version }}" = "system" ]; then | |
eval $(perl -I"$HOME/perl5/lib/perl5" -Mlocal::lib) | |
fi | |
make realclean || true | |
perl Makefile.PL | |
- name: Build | |
run: | | |
if [ "${{ matrix.perl-version }}" = "system" ]; then | |
eval $(perl -I"$HOME/perl5/lib/perl5" -Mlocal::lib) | |
fi | |
make | |
- name: Test | |
run: | | |
if [ "${{ matrix.perl-version }}" = "system" ]; then | |
eval $(perl -I"$HOME/perl5/lib/perl5" -Mlocal::lib) | |
fi | |
if [ "${{ matrix.server-version }}" != "system-pic" ]; then | |
export HARNESS_OPTIONS=j4 | |
fi | |
export RELEASE_TESTING=1 | |
if [ "${{ matrix.server-version }}" != "none" ]; then | |
export CONNECTION_TESTING=1 | |
fi | |
make test |