无法在控制台日志中打印定位器(webelement)

时间:2017-02-22 06:46:05

标签: jasmine protractor

我是Protractor的新手。

我将元素声明为变量,如:

txtSearch : element(by.xpath('//input[@type="search"]')),

在某些时候,我想将定位器记录为:

var clickOn = function(webElement)
{
  webElement.click();
  console.log("Successfully clicked on the " + webElement);
};

我从Spec文件调用此函数,如 - clickOn (txtSearch)

Console.log中,我变得像 - Successfully clicked on the [object Object]

请在下面找到所需的详细信息:

  

节点版本:7.5.0

     

量角器版本:5.1.1

     

浏览器:Chrome

量角器配置文件:

exports.config = {
        capabilities: {
            browserName: 'chrome',
          },
   onPrepare: function(){
      jasmine.getEnv().addReporter(reporter);

       global.isAngularSite = function(flag) {
           browser.ignoreSynchronization = !flag;
       };
       browser.manage().timeouts().setScriptTimeout(60000);
       browser.driver.manage().window().maximize();
   },


   seleniumServerJar: '../../protractor/selenium/selenium-server-standalone-2.52.0.jar',
   chromeDriver: '../../protractor/selenium/chromedriver_2.27.exe',
   directConnect: true, 
   framework: 'jasmine2',
   seleniumAddress: 'http://localhost:4444/wd/hub',
   specs: ['../PoC_Protractor/spec.js'],

    jasmineNodeOpts: {
        showColors: true,
        defaultTimeoutInterval: 600000,
        isVerbose: true
    }

我尝试使用webElement.locator().toString(),但它正在投掷 -

  

失败:webElement.locator不是函数

2 个答案:

答案 0 :(得分:0)

您始终可以使用webElement.locator().toString()输出使用的定位器。检查以下代码片段的输出。

量角器规格:

describe('Locator testing by model', function(){
    it('automate user register form', function(){
        browser.get('http://www.way2automation.com/angularjs-protractor/registeration/#/login');
        var search = element(by.model('Auth.user.name'))
        console.log(search.locator())
        console.log("Successfully clicked on the " + search.locator().toString());
        console.log(search.locator().toString())
    });
});

输出:

[14:01:48] I/local - Starting selenium standalone server...
[14:01:48] I/launcher - Running 1 instances of WebDriver
[14:01:49] I/local - Selenium standalone server started at http://10.96.61.119:56341/wd/hub
Started
{ findElementsOverride: [Function], toString: [Function] }
Successfully clicked on the by.model("Auth.user.name")
by.model("Auth.user.name")
.


1 spec, 0 failures
Finished in 0.942 seconds

[14:01:53] I/local - Shutting down selenium standalone server.
[14:01:53] I/launcher - 0 instance(s) of WebDriver still running
[14:01:53] I/launcher - internet explorer #01 passed

答案 1 :(得分:0)

嘿,好像你可能没有以正确的方式解决承诺,尝试使用 -

updated_at