travis:如何对不同的mysql后端运行测试?

dhxwm5r4  于 2021-06-25  发布在  Mysql
关注(0)|答案(2)|浏览(762)

如何使用一个.travis.yml文件对不同的mysql后端运行测试?
就像这里,使用 matrix->include . 例如:
对MySQL5.5运行测试
对MySQL5.6运行测试
对MySQL5.7运行测试
对mysql 8.0运行测试
我现在发现的是:
在travis中使用MySQL5.7:https://gist.github.com/gocanto/46b8d39576f612f9c6b8b4ffb3efac98
有关如何在travis上设置数据库的常规信息:https://docs.travis-ci.com/user/database-setup/
后者提到
你也可以在支持sudo的ubuntu trusty上安装mysql 5.7。
但没有提到如何使用5.6和5.7,例如。
可能的解决方法(如果没有“travis”解决方法):
方法:创建不同的docker设置,每个都有特定的mysql版本,并手动测试我的脚本。但这会严重影响我的开发环境,而且相当耗时。
根据相关的环境变量(例如mysql\u version==5.5),从sources/通过apt安装所需的mysql服务器。使用特定的配置来访问它。
感谢您的反馈!

zed5wv10

zed5wv101#

我将回答我自己的问题,但我愿意接受其他方法。

解决方案

以下解决方案基于pymysql项目中的.travis.yml:https://github.com/pymysql/pymysql/blob/master/.travis.yml
您需要脚本和.travis.yml配置的组合。

脚本

如果要重用以下代码,请在项目中使用以下路径:.travis/install-and-init-db.sh
以下脚本将以所需版本安装数据库:


# debug

set -x

# verbose

set -v

if [ ! -z "${DB}" ]; then
    # disable existing database server in case of accidential connection
    sudo service mysql stop

    docker pull ${DB}
    docker run -it --name=mysqld -d -e MYSQL_ALLOW_EMPTY_PASSWORD=yes -p 3306:3306 ${DB}
    sleep 10

    mysql() {
        docker exec mysqld mysql "${@}"
    }
    while :
    do
        sleep 5
        mysql -e 'select version()'
        if [ $? = 0 ]; then
            break
        fi
        echo "server logs"
        docker logs --tail 5 mysqld
    done

    mysql -e 'select VERSION()'

    if [ $DB == 'mysql:8.0' ]; then
        WITH_PLUGIN='with mysql_native_password'
        mysql -e 'SET GLOBAL local_infile=on'
        docker cp mysqld:/var/lib/mysql/public_key.pem "${HOME}"
        docker cp mysqld:/var/lib/mysql/ca.pem "${HOME}"
        docker cp mysqld:/var/lib/mysql/server-cert.pem "${HOME}"
        docker cp mysqld:/var/lib/mysql/client-key.pem "${HOME}"
        docker cp mysqld:/var/lib/mysql/client-cert.pem "${HOME}"
    else
        WITH_PLUGIN=''
    fi

    mysql -uroot -e 'create database testdb DEFAULT CHARACTER SET utf8mb4'
else
    cat ~/.my.cnf

    mysql -e 'select VERSION()'
    mysql -e 'create database testdb DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_general_ci;'
fi

特拉维斯·伊梅尔

您必须使用矩阵->包含块。对于php,请参阅以下代码。在前面提到的pymysql中,您将找到一种python方法。

sudo: required

language: php

services:
  - docker

matrix:
    fast_finish: true
    include:
        #
        # Define versions of MySQL and MariaDB to test against.
        #
        # mysql 5.5
        - php: 5.6
          env: DB=mysql:5.5
        - php: 7.0
          env: DB=mysql:5.5
        - php: 7.1
          env: DB=mysql:5.5
        - php: 7.2
          env: DB=mysql:5.5
        # mysql 5.6
        - php: 5.6
          env: DB=mysql:5.6
        # ...
        # mariadb 10.0
        - php: 5.6
          env: DB=mariadb:10.0
        - php: 7.0
          env: DB=mariadb:10.0
        - php: 7.1
          env: DB=mariadb:10.0
        - php: 7.2
          env: DB=mariadb:10.0
        # ...

before_script:
    #
    # install and init database (see matrix => include => env)
    #
    - ./.travis/install-and-init-db.sh

    #
    # setup and run tests
    #
    # Install composer packages, will also trigger dump-autoload
    - travis_retry composer install --no-interaction

script:
    - vendor/bin/phpunit --coverage-clover gen/coverage/clover.xml

创建和使用连接

使用以下参数创建到数据库服务器的连接:

$dbConfig = array(
    'db_name' => 'testdb',
    'db_user' => 'root',
    'db_pwd'  => '',
    'db_host' => '127.0.0.1',
);
8fsztsew

8fsztsew2#

我以@k00ni在pymysql中链接到的示例为例 initializedb.sh 脚本并将其归结为更简单的内容,因为我的测试不需要tls或自定义用户。这就是问题所在 linux-mysql 脚本:


# !/bin/bash

if [ $MYSQL = 'system' ]; then
    exit
fi

# Derived from https://github.com/PyMySQL/PyMySQL/blob/master/.travis/initializedb.sh

set -e
sudo service mysql stop
docker pull ${MYSQL}
RUN_MYSQL="docker run -it --name=mysqld -d -e MYSQL_ALLOW_EMPTY_PASSWORD=yes -p 3306:3306"
export MYSQL_URI=db:mysql://root@127.0.0.1/information_schema

if [ $MYSQL == 'mysql:8.0' ]; then
    ${RUN_MYSQL} ${MYSQL} --default-authentication-plugin=mysql_native_password
else
    ${RUN_MYSQL} ${MYSQL}
fi

它出口 MYSQL_URI 所以测试不知道如何连接;根据您自己的测试进行适当的修改。
这个脚本不需要等待mysql完成启动,因为sqitch测试在运行连接到数据库的测试之前需要花费一两分钟的时间来做一些其他的事情。如果您的项目需要等待mysql启动,请将以下内容附加到脚本末尾:

while ! docker exec mysqld mysqladmin ping --host localhost --silent &> /dev/null ; do
    echo "Waiting for database connection..."
    sleep 2
done

不管怎样,`.travis.yml都会创建一个构建阶段来运行多个版本的mysql:

jobs:
  include:
    # https://hub.docker.com/_/mysql
    # https://hub.docker.com/_/mariadb
    - &mysql
      stage: ? MySQL
      if: branch = master
      services: docker
      env: MYSQL=mysql:8.0
      before_install:
        - source dev/linux-mysql
        - source dev/linux-prereqs
      script:
        - LIVE_MYSQL_REQUIRED=1 prove -lr --directives --comments t/mysql.t
    - <<: *mysql
      env: MYSQL=mysql:5.7
    - <<: *mysql
      env: MYSQL=mysql:5.6
    - <<: *mysql
      env: MYSQL=mysql:5.5
    - <<: *mysql
      env: MYSQL=mariadb:10.4
    - <<: *mysql
      env: MYSQL=mariadb:10.3
    - <<: *mysql
      env: MYSQL=mariadb:10.2
    - <<: *mysql
      env: MYSQL=mariadb:10.1
    - <<: *mysql
      env: MYSQL=mariadb:10.0
    - <<: *mysql
      env: MYSQL=mariadb:5.5

请参阅此构建以了解其最终结果(以及许多其他数据库测试)。

相关问题