量角器通过ssh忽略与DB的连接

时间:2017-10-27 09:28:26

标签: mysql selenium ssh protractor

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

我们通过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驱动程序创建测试并使用节点运行它,但这是额外的工作。

1 个答案:

答案 0 :(得分:0)

您需要使用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提供done或done.fail方法,以等待此规范结束,然后再转到下一个规范。

调试

查看mysql-ssh的依赖关系,它使用了promise包装器。 https://github.com/sidorares/node-mysql2/blob/master/documentation/Promise-Wrapper.md。但是,在查看node-mysql2 repo之后,不清楚这些是异步还是同步。

添加额外的日志记录:

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();
    });