Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

WebdriverIO: How to read baseURL value from wdio.conf.js. inside step definition file

I am using WebdriverIO for test automation. In wdio.conf.js file I have configured the 'baseUrl' property.

I want to read the 'baseUrl' property value inside my test .js file. How can I do this?

like image 731
Thangakumar D Avatar asked Jun 15 '17 15:06

Thangakumar D


People also ask

What is base URL in WebDriverIO?

// With a base URL of http://example.com/site, the following url parameters resolve as such: // When providing a scheme: // https://webdriver.io. browser.

How do you skip a test on Wdio?

It. skip command is used to Skip test cases from n number of test cases present in describe block. In This Article we will use same code base which is present in our WebDriverIO-Using Xpath Locators and append our command i.e., “it. skip” to skip one of the test case out of two test cases present in describe block.


2 Answers

❒ wdio-v5

Lately, after writing a lot of tests for a project rewrite I've came to believe the best way to store/access global config variables is via the global object.

You can define them inside the wdio.conf.js file's hooks. I defined mine in the before hook:

before: function (capabilities, specs) {
  // =================
  // Assertion Library
  // =================
  const chai    = require('chai');
  global.expect = chai.expect;
  global.assert = chai.assert;
  global.should = chai.should();
  // ======================
  // Miscellaneous Packages
  // ======================
  global.langCode = langCode;
  global.countryCode = countryCode;
  global.request = require('superagent');
  global.allowedStatusCodes = [200, 301],
  // ===============
  // Custom Commands
  // ===============
  require('./test/custom_commands/aFancyMethod');
  require('./test/custom_commands/anotherOne');
  require('./test/custom_commands/andAnotherOne');
},

Then, you can access them directly, anywhere in your test-files, or page-objects. This way, you greatly reduce the test-file's footprint (errr... codeprint) because you can call these directly in your test case:

describe(`Testing a random URL`, () => {
  it('Should return a HTTP valid status code', async () => {
    // Issue a HTTP request for the given URL:
    await request
      .head('https://random.org')
      .then(res => {
        console.info(`\n> Status code found: ${res.status} | MIME type found: '${res.type}'\n`);
        foundStatusCode = res.status;
      })
      .catch(err => {
        console.info(`\n> Status code found: ${err.status} | Error response found: '${JSON.stringify(err.response)}'\n`);
        foundStatusCode = err.status;
      });
    // Assert the HTTP Status Code:
    assert.include(allowedStatusCodes, foundStatusCode, `!AssertError: Route yields a bad status code! Got: ${foundStatusCode} | Expected: ${allowedStatusCodes}`);
  }); 

As opposed to always doing await browser.options.request.head(..., browser.options.baseUrl, etc.


❒ wdio-v4

All the wdio.conf.js file attributes (basically the config object name-value pairs) are also stored inside the browser.options object.

Thus, a more elegant approach to access your global config values from inside your tests would be as presented below:

> browser.options
{ port: 4444,
  protocol: 'http',
  waitforTimeout: 10000,
  waitforInterval: 500,
  coloredLogs: true,
  deprecationWarnings: false,
  logLevel: 'verbose',
  baseUrl: 'http://localhost',
  // ... etc ...
}

> browser.options.baseUrl
'http://localhost'

I'll go on a limb here and presume you want to read the baseUrl value from your wdio.config.js file, into your test.js file.

TL;DR: In your test.js file heading, add the following:

var config = require('<pathToWdioConfJS>/wdio.conf.js').config;

You can then access any wdio.config.js value via the config.<configOption>, in your case config.baseUrl.


Lastly, I would greatly recommend you read about exports and module exports.

WebdriverIO is built on NodeJS, so you will shoot yourself in the foot on the long run if you don't know how and when to use exports, module.exports, require, or the difference between them.

like image 178
iamdanchiv Avatar answered Oct 05 '22 19:10

iamdanchiv


Use browser.options.baseUrl . If you use require, you're hard coding from that one file, which is fine, but you cannot do a wdio --baseUrl=http://myTestSite2.net to override the "global" baseUrl. Which you might want to do in multiple deployments in the future.

like image 39
Nate R Avatar answered Oct 05 '22 20:10

Nate R