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

apigeek-affirm

v1.9.8

Published

Executable English for Software Testing and more

Downloads

112

Readme

ApiGeek CI version dependencies apigeeks

Executable English for Test Teams

ApiGeek:Affirm is an BDD test automation and orchestration tool for software teams.

Affirm uses English (Gherkin) language to describe and execute test cases for APIs and Web Apps.

Test definitions are declarative - which makes them easy to read, write and re-use.

Gherkin is human and machine readable - so business analysts, testers, developers and robots can collaborate.

Since tests are written in English - every stakeholder (including the Project Sponsor :-) can make sense of them.

View the PDF introduction.

I want to automate testing

With Affirm, you write your test cases in a simplified dialect of English - called Gherkin.

Traditional test scripts are often unreadable by our stakeholders and even ourselves.

Affirm uses executable English instructions - actions and assertions - that are easy to read, write and socialise.

Features are lists of related scenarios. It's the scenario's that do all the heavy lifting.

A scenario describes your pre-conditions, actions and outcomes in a way that is both human and machine friendly.

I want to understand Gherkin

The Gherkin (BDD) notation for a feature / scenario is:

Feature: Basic Examples

Scenario: An example
	GIVEN   some context
	WHEN    an action is performed
	THEN    an outcome is expected

The text following the keyword (GIVEN | WHEN | THEN) needs to match a phrase/pattern from a vocabulary.

New features can be created using any simple text editor - where you'd use ApiGeek:Affirm's extensible vocabulary to write them.

You can download pre-packaged vocabularies (called Dialects) and/or roll your own with simple Javascript.

I want to see a working example

ApiGeek:Affirm's features are collections of individual test scenarios.

To improve readability, the keyword AND can be used instead in place of the verbs above.

You can influence what ApiGeek:Affirm understands using @dialect annotations.

@dialects=webapi
Feature: Verify that Google is accessible

Background: Google Scenarios

    Given I am googling

 Scenario: Request Google homepage - with redirects

    Given I enable redirects
    When I GET http://google.com
    Then response code should be 200

 @target=google
 Scenario: Request Google homepage - no redirect

    Given I disable redirects
    When I GET /
    Then response code should be 3xx

I want to test-drive ApiGeek:Affirm

ApiGeek:Affirm is built using NodeJS. If you're new to node, pre-read Getting Started.

You install ApiGeek:Affirm as a system-wide CLI command:

$ npm install apigeek-affirm -g

To run it simply type:

$ affirm

However, It won't do much else until we provide some feature scenarios.

By default, ApiGeek:Affirm looks for ".feature" files recursively, starting in the current directory.

I want to create my first feature

  1. To quickly create a few examples in the ./features folder, type:

     $ affirm --example

This will create the ./features folder and copy some simple examples.

It will also write your default configuration to ./apigeek.json

It won't damage if you run it again, except re-save your ./apigeek.json config.

Or, you can just create the ./features folder and a default "apigeek.json" without the examples:

$ affirm --initialize
  1. To execute your example ".feature" files, type:

     $ affirm
  2. If something goes wrong, enable the built-in debugger.

     $ export DEBUG=apigeek*
     $ affirm

Now, the output is verbose and colour-coded to make your life easier.

To turn off debugging, type:

	$ export DEBUG=
	$ affirm

I want to learn some vocabulary

ApiGeek:Affirm ships with few default vocabularies - variables, files, web apis, web apps, etc.

To discover what phrases exist in the vocabularies, type:

$ affirm --knows

Let's create a trivial example of a hypothetical test case.

Scenario: Trivial Test

    Given I am testing debug
    When debug works
	And I succeed

The steps are executed in sequence.

The GIVEN steps setup pre-conditions. The "Given I am $acting" phrase doesn't do much - except communicate intentions.

The "WHEN ... " steps do useful work that result in desirable outcomes. For example: writing a file, requesting a web page, etc.

In this example, we simply write a debug message to the console, so let's turn on debug output.

$ export DEBUG=apigeek*

You can adjust the logging scope - to see only Web API messages, use:

$ export DEBUG=apigeek:files

The "THEN ..." steps make assertions, that is they test that conditions are met. For example, you can use arbitrary Javascript if necessary:

    Then I assert $some_javascript

The "I succeed", "I pass" always meet their conditions. The inverse "I fail" forces the scenario to abort and report it's failure.

I want to learn more about ApiGeek:Affirm

For runtime options, type:

$ affirm  -h

For more information:

Example Features.

Basic Dialect.

Advanced Dialect.

Something Went Wrong.

Web API Dialect.

Web API Advanced.

Web Apps Dialect.

Web Apps Advanced.

I want to organise my work into folders

If your features are in a different location then use the "--features" or "--epics" option to locate them.

$ affirm --archive ./my-archive --features ./my-features

These folders are not automatically created, they return an error if they're not found.

I want to re-use my features in other projects

ApiGeek:Affirm was designed to support a declarative style so that features are portable.

Supplying a different "config" file for each environment allows features to be re-used across multiple environments.

For example, features can adapt to dev, QA and live environments - injecting hostnames, credentials, etc as required.

Most Dialects configure themselves automatically.

If yours doesn't then there is alternative - use {{mustache}} templates to modify statements prior to execution.

Given I login as {{scope.actor}}

In this way, your BDD features are neatly abstracted from your runtime configuration.

To specify a runtime configuration for your features, type:

$ affirm --config ./my-context.json

By default, ApiGeek:Affirm will try to load a configuration file called "apigeek.json" from your current directory.

If no file is found, then sensible default values are defined.

I want to do something before every scenario

Backgrounds are similar to scenarios, except they do not support annotations.

Any feature can contain a background, in which case the steps that carried out before each scenario.

Background: Authenticate

	GIVEN I login
	AND I use a valid client certificate

I want to know how it works

First, ApiGeek:Affirm parses the command line and initializes the Dialect, Features and Engine components.

Next it loads the default dialects. These can be specified on using the APIGEEK_DIALECT environment variable. Dialects can also be specified using --dialect option and within Feature: definitions using the @dialect annotation.

Each Dialect instructs the parser (Yadda) to match a set of Gherkin phrases to their related function.

The Feature manager converts features and scenarios into executable units.

User defined variables are scoped at the feature-level meaning they are shared between scenarios within the same feature.

The --config file is used as the basis for internal context variables. They are scoped to each scenario.

These variables - such as web requests/responses - can be accessed using the "this." qualifier - with due caution.

Next, the Engine runs each feature using the built-in Mocha runner. Results are correlated and output according to your CLI options.

I want to add comments

It's useful to document your intentions or to prevent a statement from running, for example during development.

Simple, place a # before any line and it will be ignored by Affirm.

# This is ignored by the parser
Scenario: Comments Example

	Given I am using comments
	# Then I fail
	Then I succeed

Instead, you should use @skip or @todo before a Feature: or Scenario: definition.

An @bug scenario will pass normally (skipped) but fail when --debug is used.

@bug=something is broken

Scenario: A Bug
	Given I am a bug
	Then I fail

I want to do run tests on a schedule

Running a "cron job" is familar to DevOps teams who want to schedule regular activities.

Apigeek-Affirm has a built-in cron-like scheduler to provide continuous assurance, see Cron Scheduler for more details.

I want to automate everything

That is our goal too. We'll continue to address the needs of Enterprise Affirms.

Competent software engineers can easily create "blueprints" that capture the patterns, templates and files used to build SDLC artefacts.

Then ApiGeek:Affirm can re-use those blueprints to build customised websites, portals, Apps, APIs, mock servers, micro services and more.

Please share any custom Blueprints and Dialects so that ApiGeek:Affirm becomes more useful for all of us.

If you need support to build or debug your community Blueprints or Dialects, please [email protected]

I want to license ApiGeek:Affirm

This software is licensed under the Apache 2 license, quoted below.

Copyright 2015-2016 Lee Curtis & Troven 2009-2015

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

[http://www.apache.org/licenses/LICENSE-2.0]

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.