npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

protractor-test-objects

v0.3.0

Published

A library to help with use of page/component objects when testing with protractor

Downloads

14

Readme

Protractor Test Objects

A library to help with the use of page/component objects when testing with Protractor. It also adds additonal functionality on top of protractor that is useful for testing.

It is intended that tests written with this library will move of Protractor specific code into page/component objects in order to make the test files themselves simplier, cleaner, and easier to understand. This should allow for better reuse of code as each action and assertions should have it own method.

You will also noticed one liner methods and those are there to again make the test simple to read/write. I find it much easier to remember and read this:

page.sendKeysToPage('s');

compared to this:

browser.actions().sendKeys('s').perform();

The goals is that the test files should be easy to read, have a consistent API, and have not Protractor or webdriver specific code in them.

Installation

npm install protractor-test-objects

Usage

NOTE: Code examples assume Mocha/Chai setup.

Creating Component Object

var protractorTestObjects = require('protractor-test-objects');
var helpComponent = protractorTestObjects.baseComponent.create();

//all selectors are defined here and are accessed through the getSelector() method
//that way if you do make a change to DOM, all selectors are located in one place,
//at the top of the file
helpComponent.selectors = {
  handle: '.handle',
  chat: '.chat'
};

helpComponent.clickChat = function() {
  $(this.getSelector('chat')).click();
};

helpComponent.isVisible = function() {
  expect($(this.getSelector('handle')).isDisplayed()).to.eventually.be.true;
};

module.exports = {
  create: function(baseSelector) {
    var newComponent = Object.create(helpComponent);
    newComponent.baseSelector = baseSelector;
    return newComponent;
  }
};

Creating Page Objects

var protractorTestObjects = require('protractor-test-objects');
var helpComponentFactory = require('../components/help');
var desktopPage = protractorTestObjects.basePage.create();

desktopPage.baseSelector = '.desktop-page';
desktopPage.baseUrl = '/desktop?uiTestingMode=true';

desktopPage.isVisible = function() {
  expect($(this.getSelector()).isDisplayed()).to.eventually.be.true;
};

desktopPage.getHelpComponent = function() {
  return helpComponentFactory.create(desktopPage.baseSelector + ' > .help');
};

module.exports = {
  create: function(appendUrl, autoOpen) {
    autoOpen = autoOpen === false ? false : true;
    var newDesktopPage = Object.create(desktopPage);

    if(autoOpen === true) {
      newDesktopPage.open(appendUrl);
    }

    return newDesktopPage;
  }
};

API

baseComponent

baseSelector (string)

Base selector that can be prepended with the result of a call to getSelector().

selectors (object)

An object of selectors with the key being the name of the selector (used in method like getSelector()) and the value being the css selector.

getSelector(string name, boolean withBase)

Returns a css selector string.

waitForElement(string selector, number timeToWait)

Wait up to a specified time for the selector to find an elements.

waitForElements(string selector, number timeToWait)

Wait up to a specified time for the selector to find elements.

sendKeysToPage(string keys)

Sends key to the browser but not specific to any element, useful for testing things like general keyboard shortcuts (that are not specifc to any element).

takeScreenshot(string fileName, string path)

Takes a screenshot which is store in screenshots/* relative to the directory in which you started protractor (unless path is specificed).

resizeBrowser(number width, number height)

Resize the browser.

setImplicitWait(number timeToWait)

Sets the implicit wait timeout for web driver calls.

repeatKey

Repeat a certain keys (or group of keys).

basePage

baseUrl (string)

Base URL for the page object.

open(string appendUrl)

Open the browser to a url.

License

MIT