我有这个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,
});
});
}
在这里,它提供了向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部分
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
你们中有谁知道为什么会发生这些错误以及如何修复它们吗?他们在完成项目后就开始了。在它运行所有测试没有错误之前?
1条答案
按热度按时间mzaanser1#
如果问题是在docker之后开始的,那么可能您实际上正在运行到本地数据库的迁移,并在docker中针对db运行应用程序。
无论如何,这个问题目前没有足够的关于安装的信息来给出明确的答案。请平,如果你添加更多信息的问题,我会更新答案。
我们需要知道你是如何运行你的停靠设置。如何运行迁移。你有本地mysql安装和docker mysql服务器同时运行吗。您是否在某个时候停止了容器(从而丢失了迁移的数据设置)。基本上完整的代码再现您的问题将是必要的。