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

vibranium-cli

v0.0.3-7

Published

API testing and data generation made easy

Downloads

15

Readme

Vibranium

npm version npm node-current

Vibranium is a CLI based API testing and data generation tool built on Node JS.

All the tests in Vibranium are written using JSON, making it readable by any person, irrespective of the programming languages they usually use.

Top Features

Some of the biggest features of Vibranium are:

  • JSON based tests JSON is a very simple and maintainable way to represent any data and so writing tests in JSON makes Vibranium very simple and fasts to get started with. This also means that Vibranium tests are easily maintainable.

  • Reusability One of the biggest issue with API tests and data generation logic is that you have a lot of dependent objects that are reused in multiple places. Once these objects are defined in Vibranium, all you need to do is mention this as the dependency for the other object and the objects become highly reusable.

  • Assertions Writing assertions in Vibranium is plain simple and supports JS in JSON syntax. We can also fail the tests if the time taken to execute an API exceeds a given value. You can also validate API responses by just specifying the expected schema. Vibranium will run the API, validate it against the schema and report all errors, and so writing tests are pretty easy

  • Simple Data Parsing Want to parse a JSON response and get some value? You can use simple Javascript dot notation to parse the JSON. You can easily specify to pick a random value in JSON array or to do a map of an array inside the JSON tests.

  • Data generation tools Filling dummy data in APIs is pretty easy with Vibranium. You can easily generate Lorem Ipsum strings of given length, random string just by specifying the regex matching it, use inbuilt data sets like names of Harry Potter, Game of Thrones, Star Wars, Marvel, Pokemon and other characters.

  • Reports HTML, Excel, JUnit and JSON report formats are supported. Vibranium measures the time taken per call for each API endpoint and helps compare the reports of the previous executions. (Check below for a screenshot of the report server UI)

  • Declarative tests The tests are written in JSON, by mentioning just the required properties of the test and then the expected values. No need to worry about how things work.

Installation

Vibranium is a Node JS based app, available in npm. To install Vibranium, all you need to do is run the following command in the terminal

  npm install -g vibranium-cli

Getting Started

The following pages will help you in getting started with Vibranium.

Documentation

The documentation for Vibranium hosted in Github Pages and is available here.

Sample Tests

  • Simplest Test: Check if an API is up and running

      {
          "name": "01_get_all_users",
          "description": "List all users",
          "url": "/api/v1/users"
      }

    This JSON snippet is enough to check if the API endpoint GET /api/v1/usersis up and returns Status code 200

  • Check the response of an API by validating it with a schema

      {
          "name": "get_all_users",
          "description": "List all users",
          "url": "/api/v1/users",
          "expect": {
              "response": {
                  "schema": "!userSchemas/allUsers"
              }
          }
      }

    This JSON will validate if the response matches the schema specified in schemas/userSchemas/allUsers.json file.

  • Call the users list api to get all user details and validate if

    • API returns a status code of 200
    • The Time to first byte should be less than 300ms
    • The total time taken by API should be less than 700ms
    • The response is of content type JSON
    • Response should have more than 10 entries
    • At least one user is admin
    • All users have proper IDs
    {
        "name": "get_all_users",
        "description": "List all users",
        "url": "/api/v1/users",
        "method": "GET",
        "expect": {
            "status": 200,
            "headers": {
                "content-type": "application/json"
            },
            "response": {
                "There should be more than 10 users": "{response.length} > 10",
                "At least one user should be admin": "{response.all.isAdmin}.filter(isAdmin => isAdmin).length >= 1",
                "All users have an ID of 32 characters": "{response.all.id}.every(id => id.length === 32)"
            },
            "timing": {
                "total": "<700",
                "firstByte": "<300"
            }
        }
    }
  • Create 10 new users and the validate if

    • API returns a status code of 200
    • The Time to first byte should be less than 300ms
    • The total time taken by API should be less than 700ms
    • The response is of content type JSON
    • User name should be same as in the payload
    • User Id should be valid
    • User should not be admin
        {
        "name": "create_user",
        "description": "Create new User",
        "url": "/api/v1/users",
        "method": "POST",
        "variables": {
            "userName": "{dataset.names}"
        },
        "payload": {
            "name": "{userName}"
        },
        "repeat": 10,
        "expect": {
            "status": 200,
            "headers": {
                "content-type": "application/json"
            },
            "response": {
                "User ID is valid": "{response.id.length} === 32",
                "User name should be same as input": "'{response.name}' === '{userName}'",
                "User should not be an admin": "{response.isAdmin} === false"
            },
            "timing": {
                "total": "<700",
                "firstByte": "<300"
            }
        }
    }
  • Update a user and validate if

    • API returns a status code of 200
    • The Time to first byte should be less than 300ms
    • The total time taken by API should be less than 700ms
    • The response is of content type JSON
    • User name should be same as in the payload
    • User Id should be valid
    • User should not be admin
    {
        "name": "update_user_details",
        "description": "Update user details",
        "url": "/api/v1/users/{userId}",
        "method": "PUT",
        "variables": {
            "newUserName": "{dataset.names}"
        },
        "payload": {
            "name": "{newUserName}"
        },
        "dependencies":[
        {
            "api": "02_create_user",
            "variable": {
                "userId": "response.id",
                "oldUserName": "response.name"
            }
        }  
        ],
        "expect": {
            "status": 200,
            "headers": {
                "content-type": "application/json"
            },
            "response": {
                "User ID is valid": "'{response.id}' === '{userId}'",
                "User name should be same as input": "'{response.name}' === '{newUserName}'",
                "User should not be an admin": "{response.isAdmin} === false"
            },
            "timing": {
                "total": "<700",
                "firstByte": "<300"
            }
        }
    }

More examples available in the documentation.

Contributing to the Project

If you would like to contribute to the project development, you're always welcome. Feel free to make changes and raise a PR, and/or raise issues in GitHub.