gpt4 book ai didi

mysql - Protractor 忽略通过 SSH 与数据库的连接

转载 作者:行者123 更新时间:2023-11-29 18:16:37 27 4
gpt4 key购买 nike

我有下一个棘手的任务:我需要测试聊天,然后查询数据库并检查计费数据。

我们正在通过 SSH 连接使用 MySQL。我找到了下一个可以使用的库: https://www.npmjs.com/package/mysql-ssh

我试过了,有效。我使用 node test.js 运行它但是,当我尝试在规范中设置它时,我在 console.log 中看不到任何内容,并且即使我将 SQL 查询更改为无效,规范也始终会成功运行:

it('Log in with common form and filled params', function () {
/*var browser2 = browser.forkNewDriverInstance();
browser2.ignoreSynchronization = true;
browser.get(browser.baseUrl);
browser2.get(browser.baseUrl);

browser.pause();
browser2.pause();*/


mysqlssh.connect(
{
host: 'host',
user: 'user',
privateKey: fs.readFileSync('path to key')
},
{
host: 'host',
user: 'user',
password: 'pass',
database: 'db'
}
).
.then(client => {
client.query('SELECT * FROM `agency`', function (err, results) {
if (err) throw err;
console.log(results);
mysqlssh.close()
})
})
.catch(err => {
console.log(err)
});
});

我不知道如何改变它。唯一的解决方法是使用 Selenium 驱动程序创建一个测试并使用 Node 运行它,但这是一项额外的工作。

最佳答案

你需要使用done()

您需要使用 done 函数执行某些操作。请参阅jasmine documentation .

it('Log in with common form and filled params', (done) => {
/*var browser2 = browser.forkNewDriverInstance();
browser2.ignoreSynchronization = true;
browser.get(browser.baseUrl);
browser2.get(browser.baseUrl);

browser.pause();
browser2.pause();*/


mysqlssh.connect(
{
host: 'host',
user: 'user',
privateKey: fs.readFileSync('path to key')
},
{
host: 'host',
user: 'user',
password: 'pass',
database: 'db'
}
).
.then(client => {
client.query('SELECT * FROM `agency`', function (err, results) {
if (err) {
// if this is not caught, maybe use done.fail instead.
throw err;
}
console.log(results);
mysqlssh.close();
done();
});
})
.catch(err => {
console.log(err);
done.fail('some message');
});
});

您需要在异步任务中为 Jasmine 提供 did 或 did.fail 方法,以等待此规范结束,然后再继续下一个规范。

调试

查看 mysql-ssh 的依赖关系,它使用了一个 Promise 包装器。 https://github.com/sidorares/node-mysql2/blob/master/documentation/Promise-Wrapper.md 。然而,在查看了node-mysql2存储库后,并不清楚这些是异步的还是同步的。

添加额外的日志记录:

mysqlssh.connect({ host: 'host', user: 'user', privateKey: fs.readFileSync('path to key')},
{ host: 'host', user: 'user', password: 'pass', database: 'db' }
).then(client => {
console.log('connected');
console.log(client);
client.query('SELECT * FROM `agency`', (err, results, fields) => {
// should try to catch errors, also should validate if
// the query returns a promise or not
// if query returns a promise, there should be a then to close and a catch for errors
// should pick a reasonable place to add a done
// and done.fail calls.

});

}).catch(err => {
console.log('error caught');
done.fail();
});

关于mysql - Protractor 忽略通过 SSH 与数据库的连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46971798/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com