Skip to main content

Create your http(s)-tests in simple yaml files, and run them with command line, against various environments

Project description

reqman (3.X)

Reqman is a postman killer ;-)

Reqman is a postman killer. It shares the same goal, but without GUI ... the GUI is simply your favorite text editor, because requests/tests are only simple yaml files. Reqman is a command line tool, available on any platforms.

Video (1minute)

All configurations is done via simple yaml files, editable with any text editors. Results are displayed in console and in an html output. It's scriptable, and can be used as a daemon/cron task to automate your tests.

Documentation

Changelog !

Online tool to convert swagger/openapi3, OR postman collections to reqman's tests

DEMO

Features

  • Light (simple py3 module, 3000 lines of code, and x3 lines for unittests, in TDD mind ... cov:97%)
  • Powerful (at least as postman free version)
  • tests are simple (no code !)
  • Variable pool
  • can create(save)/re-use variables per request
  • "procedures" (declarations & re-use/call), local or global
  • Environment aware (switch easily)
  • https/ssl ok (bypass)
  • http 1.0, 1.1, 2.0
  • proxy support (thru a reqman.conf var "proxy")
  • headers inherits
  • tests inherits
  • timed requests + average times
  • html tests renderer (with request/response contents)
  • encoding aware (western occident & utf8 (prefer!))
  • cookie handling
  • color output in console (when colorama is present)
  • variables can be computed/transformed (in a chain way)
  • tests files extension : .yml or .rml (ReqManLanguage)
  • generate conf/rml (with 'new' command)
  • can paralleliz tests (option --p)
  • versionning
  • NEW 2.0 :
    • rewrite from scratch, a lot stronger & speeder !
    • advanced save mechanisms
    • new switches system
    • a lot of new options (auto open browser, set html filename, compare, ...)
    • ability to save the state, to compare with newer ones
    • ability to replay given tests (rmr file)
    • dual mode : compare switches vs others switches (-env1 +env2) in html output
    • shebang mode
    • better html output
    • fully compatible with reqman1 conf/ymls
    • xml/xpath support tests
    • used as a lib/module, you can add easily your own features (see below)
  • NEW 3.0 : (simple py file -> real python module (multiple files))
    • full rewrite of resolving mechanism (more robust, more maintanable) (the big improvment)
    • "wait:" commands (time expressed in ms)
    • "ignorable vars" (avoid ResolveException, with <<var?>>)
    • --f option : to output full exchanges in html output
    • --j && --j:file.xml : to output junit-xml file

TODO : need to rewrite this ^^ ;-)

Getting started : installation

If you are on an *nix platform, you can start with pip :

$ pip3 install reqman

it will install the reqman script in your path (perhaps, you'll need to Add the path ~/.local/bin to the PATH environment variable.)

If you are on microsoft windows, just download reqman.exe (v3). The old reqman.exe V2, is still there, and add it in your path. The old reqman.exe V1, is still there, and add it in your path.

Getting started : let's go

Imagine that you want to test the json api from pypi.org, to verify that it finds me ;-) (if you are on windows, just replace reqman with reqman.exe)

You can start a new project in your folder, like that:

$ reqman new https://pypi.org/pypi/reqman/json

It's the first start ; it will create a conf file reqman.conf and a (basic) test file 0010_test.rml. Theses files are YAML, so ensure that your editor understand them ! (Following 'new' command will just create another fresh rml file if a reqman.conf exists)

Now, you can run/test it :

$ reqman .

It will scan your folder "." and run all test files (*.rml or *.yml) against the reqman.conf ;-)

It will show you what's happened in your console. And generate a reqman.html with more details (open it to have an idea)!

If you edit the reqman.conf, you will see :

root: https://pypi.org
headers:
    User-Agent: reqman (https://github.com/manatlan/reqman)

the root is a special var which will be prependded to all relative urls in your requests tests. the headers (which is a special var too) is a set of http headers which will be added to all your requests.

Change it to, and save it :

root: https://pypi.org
headers:
    User-Agent: reqman (https://github.com/manatlan/reqman)

switches:
    test:
        root: https://test.pypi.org

Now, you have created your first switch. And try to run your tests like this:

$ reqman.py . -test

It will run your tests against the root defined in test section ; and the test is KO, because reqman doesn't exist on test.pypi.org ! In fact; all declared things under test will replace those at the top ! So you can declare multiple environments, with multiple switches !

But you can declare what you want, now edit reqman.conf like this :

root: https://pypi.org
headers:
    User-Agent: reqman (https://github.com/manatlan/reqman)

package: reqman

switches:
    test:
        root: https://test.pypi.org

You have declared a var package ! let's edit the test file 0010_test.rml like this :

- GET: /pypi/<<package>>/json
  tests:
    - status: 200

Now, your test will use the package var which was declared in reqman.conf ! So, you can create a switch to change the package thru the command line, simply edit your reqman.conf like that :

root: https://pypi.org
headers:
    User-Agent: reqman (https://github.com/manatlan/reqman)

package: reqman

switches:
    test:
        root: https://test.pypi.org

    colorama:
        package: colorama

Now, you can check that 'colorama' exists on pypi.org, like that :

$ reqman . -colorama

And you can check that 'colorama' exists on test.pypi.org, like that :

$ reqman . -colorama -test

As you can imagine, it's possible to make a lot of fun things easily. (see a more complex reqman.conf)

Now, you can edit your rml file, and try the things available in this tuto. Organize your tests as you want : you can make many requests in a rml file, you can make many files with many requests, you can make folders which contain many rml files. Reqman will not scan sub-folders starting with "_" or ".".

reqman will return an exit code which contains the number of KO tests : 0 if everything is OK, or -1 if there is a trouble (tests can't be runned) : so it's easily scriptable in your automated workflows !

Ability to override reqman's features for your propers needs (reqman>=2.8.1)

Now, it's super easy to override reqman with your own features. Using 'reqman' as a lib/module for your python's code. You can declare your own methods, to fulfill your specials needs (hide special mechanism, use external libs, ...): (Thoses real python methods, just needs to respect the same signature as pyhon methods declared in confs.)

import reqman

reqman.__usage__ = "USAGE: reqmanBis ..."   # override usage or not ;-)

@reqman.expose
def SpecialMethod(x,ENV):
    """
    Do what you want ...

    Args:
        'x'   : the input var (any) or None.
        'ENV' : the current env (dict)

    Returns:
        any
    """
    ...
    return "What you need"

if __name__ == "__main__":
    sys.exit(reqman.main())

Now, you can use SpecialMethod in your scripts, ex: <<value|SpecialMethod>> or <<SpecialMethod>>!

Use and abuse !

huntr

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

reqman-3.5.3.tar.gz (41.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

reqman-3.5.3-py3-none-any.whl (45.5 kB view details)

Uploaded Python 3

File details

Details for the file reqman-3.5.3.tar.gz.

File metadata

  • Download URL: reqman-3.5.3.tar.gz
  • Upload date:
  • Size: 41.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for reqman-3.5.3.tar.gz
Algorithm Hash digest
SHA256 c323dd261ffaf87ba385f0efb0b812643902da7ac35f1dddc8beb78377fe7963
MD5 4f5edaab2e36d5ef13e44239ffec566b
BLAKE2b-256 36ede72a43ac06e40cf4d7f857821fa8b2f2bcf34985ee78a5c6e9ae6b340c37

See more details on using hashes here.

Provenance

The following attestation bundles were made for reqman-3.5.3.tar.gz:

Publisher: publish_on_pypi.yml on manatlan/reqman

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file reqman-3.5.3-py3-none-any.whl.

File metadata

  • Download URL: reqman-3.5.3-py3-none-any.whl
  • Upload date:
  • Size: 45.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for reqman-3.5.3-py3-none-any.whl
Algorithm Hash digest
SHA256 7ff08cb38183673d600703da409db28ce5b07a0788e276652ca05fb410ca10d6
MD5 edd6d8abf84cfb5410df11009d6f727c
BLAKE2b-256 136f3587d8bb0b371a7d915c67baf40ec24285f028bdddfb59e965585ba59108

See more details on using hashes here.

Provenance

The following attestation bundles were made for reqman-3.5.3-py3-none-any.whl:

Publisher: publish_on_pypi.yml on manatlan/reqman

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page