Skip to main content

Flexible Metadata Format

Project description

Flexible Metadata Format

Description

The fmf Python module and command line tool implement a flexible format for defining metadata in plain text files which can be stored close to the source code and structured in a hierarchical way with support for inheritance.

Although the proposal initially originated from user stories centered around test execution, the format is general and thus can be used in broader scenarios, e.g. test coverage mapping.

Using this approach it’s also possible to combine both test execution metadata and test coverage information. Thanks to elasticity and hierarchy it provides ability to organize data into well-sized text documents while preventing duplication.

Synopsis

Command line usage is straightforward:

fmf command [options]

There are following commands available:

fmf ls      List identifiers of available objects
fmf show    Show metadata of available objects
fmf init    Initialize a new metadata tree

Examples

List names of all objects stored in the metadata tree:

fmf ls

Show all test metadata (with ‘test’ attribute defined):

fmf show --key test

Show metadata for all tree nodes (not only leaves):

fmf show --key test --whole

List all attributes for the /recursion tests:

fmf show --key test --name /recursion

Show all covered requirements:

fmf show --key requirement --key coverage

Search for all tests with the Tier1 tag defined and show a brief summary of what was found:

fmf show --key test --filter tags:Tier1 --verbose

Initialize a new metadata tree in the current directory:

fmf init

Check help message of individual commands for the full list of available options.

Options

Here is the list of the most frequently used options.

Select

Limit which metadata should be listed.

--key=KEYS

Key content definition (required attributes)

--name=NAMES

List objects with name matching regular expression

--filter=FLTRS

Apply advanced filter when selecting objects

--whole

Consider the whole tree (leaves only by default)

For filtering regular expressions can be used as well. See pydoc fmf.filter for advanced filtering options.

Format

Choose the best format for showing the metadata.

--format=FMT

Custom output format using the {} expansion

--value=VALUES

Values for the custom formatting string

See online documentation for details about custom format.

Utils

Various utility options.

--path PATHS

Path to the metadata tree (default: current directory)

--verbose

Print additional information standard error output

--debug

Turn on debugging output, do not catch exceptions

Check help message of individual commands for the full list of available options.

Install

The fmf package is available in Fedora and EPEL:

dnf install fmf

Install the latest version from the Copr repository:

dnf copr enable psss/fmf
dnf install fmf

or use PIP (sudo required if not in a virtualenv):

pip install fmf

See documentation for more details about installation options.

Authors

Petr Šplíchal, Jakub Krysl, Jan Ščotka, Alois Mahdal and Cleber Rosa.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

fmf-0.6.1-py3-none-any.whl (15.8 kB view details)

Uploaded Python 3

fmf-0.6.1-py2-none-any.whl (18.5 kB view details)

Uploaded Python 2

File details

Details for the file fmf-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: fmf-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 15.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.18.4 setuptools/19.6.2 requests-toolbelt/0.8.0 tqdm/4.23.4 CPython/3.4.9

File hashes

Hashes for fmf-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 fedc406c28297bac92b1af4940c8e61c5de8b32a43370fb7102f4c46193b5119
MD5 d0cf858faaec9033fcca5ec16621d15a
BLAKE2b-256 0dda386154d219842c3ea13aa6a6f4a18439c69185d3e91a4fa1d82bfcb27721

See more details on using hashes here.

File details

Details for the file fmf-0.6.1-py2-none-any.whl.

File metadata

  • Download URL: fmf-0.6.1-py2-none-any.whl
  • Upload date:
  • Size: 18.5 kB
  • Tags: Python 2
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.18.4 setuptools/19.6.2 requests-toolbelt/0.8.0 tqdm/4.23.4 CPython/3.4.9

File hashes

Hashes for fmf-0.6.1-py2-none-any.whl
Algorithm Hash digest
SHA256 546e60a63330bb8199c281561e1cc904565814b08dbe5ffeeea1f6f96feb4679
MD5 f7e9c1e6da41c65572cf5778e3fba1a0
BLAKE2b-256 aa0757a1d4eb4b7be34334c5f2639dfacd81237ef94b88ba28df9456ff99acb9

See more details on using hashes here.

Supported by

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