如何使用docker-compose快速还原新数据库以进行集成测试?

时间:2018-09-28 00:35:59

标签: docker testing docker-compose integration-testing end-to-end

我想在每次运行时都使用已知状态的数据库运行集成和端到端测试,以使测试独立且可重复。一种简单的方法是使用docker-compose创建一个数据库容器,该容器每次都从转储文件中加载方案和数据。但是,这太慢了,无法为每个测试还原数据库。

更好的方法似乎是在docker容器或卷中还原数据库一次,然后将容器/卷数据库文件夹复制(装载?)到测试将使用的数据库容器中,并让每个测试重新复制/装入容器/卷,使其新鲜。

但是,我不确定用docker-compose做到这一点的最佳方法是什么。谁能提供一个最小的例子或解释如何做到这一点?

1 个答案:

答案 0 :(得分:2)

您可以使用主机目录作为其基础数据存储来启动数据库。如果这样做,则可以创建目录的tar文件,并在每次测试运行时重新解压缩该文件。

mkdir mysql
docker run -d -p 3306:3306 -v ./mysql:/var/lib/mysql --name mysql mysql
mysql -h 127.0.0.1 < dump.sql
docker stop mysql
docker rm mysql
tar czf mysql.tar.gz mysql
rm -rf mysql
tar xzf mysql.tar.gz
docker run -d -p 3306:3306 -v ./mysql:/var/lib/mysql --name mysql mysql
MYSQL_HOST=127.0.0.1 ./integration_test
docker stop mysql
docker rm mysql

您必须单独分发数据转储(如果您另外使用AWS,则S3存储桶是一个不错的选择),但是由于它是“只是”测试数据,您可以始终从数据库转储中重新创建它,因此它不是尤其珍贵,您无需跟踪其版本历史记录或尝试将其保留在源代码管理中。