我有这个express.js应用程序,我运行了一组Mocha测试。在不久前的某个时刻,我将该项目停靠。在dockerizing之后,我只有一半的测试通过,因为mysql错误。要生成这些SQL语句,我使用Bookshelf.js / Knex.js。我不会显示所有测试,因为它们都有一个共同的问题。
第一个测试运行此代码。
method.registerUser = (request, callBack) => {
let {
email,
username,
address,
city,
zip,
state,
password,
country,
} = request.body;
password = hashPassword(decrypt(password));
if(!testRegistration(request)) {
return callBack ({
success: false,
});
}
let insert = {
NAME: username,
PASSWORD: password,
EMAIL: email,
ADDRESS: address,
CITY: city,
ZIP: zip,
STATE: state,
COUNTRY: country,
};
User.forge(insert)
.save()
.then((user) => {
return callBack ({
success: true,
});
})
.catch(function (err) {
logger.log(err);
return callBack ({
success: false,
});
});
}
这是它为User模型添加新用户到mysql数据库的地方。用户模型由此json定义。
"database_test" : {
"client": "mysql",
"connection": {
"host": "DB",
"database": "TERRA_TEST",
"user": "root",
"port": "3306",
"password": "goon",
"charset": "utf8"
}
},
我有一系列在每次测试之前运行的迁移,数据库的结果模式如下所示。
+----------+------------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------+------------------+------+-----+---------+----------------+
| id | int(10) unsigned | NO | PRI | NULL | auto_increment |
| NAME | varchar(255) | YES | | NULL | |
| PASSWORD | varchar(255) | YES | | NULL | |
| EMAIL | varchar(255) | YES | | NULL | |
| ADDRESS | varchar(255) | YES | | NULL | |
| CITY | varchar(255) | YES | | NULL | |
| ZIP | varchar(30) | YES | | NULL | |
| STATE | varchar(255) | YES | | NULL | |
| COUNTRY | varchar(255) | YES | | NULL | |
+----------+------------------+------+-----+---------+----------------+
但是,当运行执行该代码以创建新用户的测试时,它将失败并返回此错误。
code: 'ER_BAD_FIELD_ERROR',
errno: 1054,
sqlMessage: 'Unknown column \'COUNTRY\' in \'field list\'',
sqlState: '42S22',
index: 0,
sql: 'insert into `USERS` (`ADDRESS`, `CITY`, `COUNTRY`, `EMAIL`, `NAME`, `PASSWORD`, `STATE`, `ZIP`) values (\'4909 Jean Manors\', \'New Parkerville\', \'Kiribati\', \'Matilde.Wiegand@hotmail.com\', \'Sarina_Anderson\', \'$2a$10$nsaL/4DyHquIlHKQOxjPiObBZJykbNlSZYCJCe0m3fREN4XD0c9o2\', \'Alaska\', \'01524\')' }
当我在mysql CLI中运行此SQL代码时,它的应用没有错误。
另外,这是docker-compose的数据库部分
DB:
image: mysql:5.7
container_name: mysql
restart: always
environment:
- MYSQL_ROOT_PASSWORD=goon
- MYSQL_DATABASE=TERRA_TEST
- MYSQL_USER=tester
- MYSQL_PASSWORD=goon
- DATABASE_HOST=docker-mysql
ports:
- "3306:3306"
networks:
- web_sql_bridge
您是否有任何人知道为什么会发生这些错误以及如何解决这些错误?它们在对项目进行码头化后开始发生。在它运行所有测试之前没有错误?
答案 0 :(得分:0)
如果在docker化之后问题就开始了,也许你实际上正在运行迁移到本地数据库并在docker中运行针对数据库的应用程序。
无论如何,问题目前还没有足够的关于设置的信息来给出明确的答案。如果您在问题中添加更多信息,请ping,我会更新答案。
我们需要知道您是如何运行dockerized设置的。你是如何运行迁移的?你有同时运行的本地mysql安装和docker mysql服务器吗?您是否在某个时刻停止容器(因此通过迁移失去数据设置)。基本上需要完整的代码来重现你的问题。