fmf


Namefmf JSON
Version 1.6.1 PyPI version JSON
download
home_pageNone
SummaryFlexible Metadata Format
upload_time2025-01-17 06:14:19
maintainerNone
docs_urlNone
authorNone
requires_python>=3.9
licenseNone
keywords metadata testing
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            
======================
    fmf
======================

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
    fmf clean   Remove cache directory and its content


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

Use arbitrary Python expressions to access deeper objects and
create more complex conditions::

    fmf show --condition "execute['how'] == 'shell'"

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

--condition=EXPR
    Use arbitrary Python expression for filtering

--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 @teemtee/fmf
    dnf install fmf

or use PIP::

    pip install fmf

See documentation for more details about installation options.


Variables
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Here is the list of environment variables understood by fmf:

FMF_CACHE_DIRECTORY
    Directory used to cache git clone calls for fmf identifiers.


Links
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Git:
https://github.com/teemtee/fmf

Docs:
http://fmf.readthedocs.io/

Issues:
https://github.com/teemtee/fmf/issues

Releases:
https://github.com/teemtee/fmf/releases

Copr:
http://copr.fedoraproject.org/coprs/g/teemtee/fmf

PIP:
https://pypi.org/project/fmf/


Authors
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Petr Šplíchal, Miro Hrončok, Jakub Krysl, Jan Ščotka, Alois
Mahdal, Cleber Rosa, Miroslav Vadkerti, Lukáš Zachar, František
Nečas, Evgeny Fedin, Pablo Martin, Zhaojuan Guo, Laura Barcziová,
Petr Matyáš, Filip Vágner, Cristian Le, Ondrej Moriš, Martin
Hoyer and Karel Šrot.


Copyright
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Copyright (c) 2018-2021 Red Hat, Inc.

This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of
the License, or (at your option) any later version.

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "fmf",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": "Petr Splichal <psplicha@redhat.com>",
    "keywords": "metadata, testing",
    "author": null,
    "author_email": "Petr Splichal <psplicha@redhat.com>",
    "download_url": "https://files.pythonhosted.org/packages/52/1f/c8e8e74f0c40e9a0230dad81b87b4a4d7afad7c51db54e16350aaecefded/fmf-1.6.1.tar.gz",
    "platform": null,
    "description": "\n======================\n    fmf\n======================\n\nFlexible Metadata Format\n\n\nDescription\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nThe ``fmf`` Python module and command line tool implement a\nflexible format for defining metadata in plain text files which\ncan be stored close to the source code and structured in a\nhierarchical way with support for inheritance.\n\nAlthough the proposal initially originated from user stories\ncentered around test execution, the format is general and thus\ncan be used in broader scenarios, e.g. test coverage mapping.\n\nUsing this approach it's also possible to combine both test\nexecution metadata and test coverage information. Thanks to\nelasticity and hierarchy it provides ability to organize data\ninto well-sized text documents while preventing duplication.\n\n\nSynopsis\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nCommand line usage is straightforward::\n\n    fmf command [options]\n\nThere are following commands available::\n\n    fmf ls      List identifiers of available objects\n    fmf show    Show metadata of available objects\n    fmf init    Initialize a new metadata tree\n    fmf clean   Remove cache directory and its content\n\n\nExamples\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nList names of all objects stored in the metadata tree::\n\n    fmf ls\n\nShow all test metadata (with 'test' attribute defined)::\n\n    fmf show --key test\n\nShow metadata for all tree nodes (not only leaves)::\n\n    fmf show --key test --whole\n\nList all attributes for the ``/recursion`` tests::\n\n    fmf show --key test --name /recursion\n\nShow all covered requirements::\n\n    fmf show --key requirement --key coverage\n\nSearch for all tests with the ``Tier1`` tag defined and show a\nbrief summary of what was found::\n\n    fmf show --key test --filter tags:Tier1 --verbose\n\nUse arbitrary Python expressions to access deeper objects and\ncreate more complex conditions::\n\n    fmf show --condition \"execute['how'] == 'shell'\"\n\nInitialize a new metadata tree in the current directory::\n\n    fmf init\n\nCheck help message of individual commands for the full list of\navailable options.\n\n\nOptions\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nHere is the list of the most frequently used options.\n\nSelect\n------\n\nLimit which metadata should be listed.\n\n--key=KEYS\n    Key content definition (required attributes)\n\n--name=NAMES\n    List objects with name matching regular expression\n\n--filter=FLTRS\n    Apply advanced filter when selecting objects\n\n--condition=EXPR\n    Use arbitrary Python expression for filtering\n\n--whole\n    Consider the whole tree (leaves only by default)\n\nFor filtering regular expressions can be used as well. See\n``pydoc fmf.filter`` for advanced filtering options.\n\nFormat\n------\n\nChoose the best format for showing the metadata.\n\n--format=FMT\n    Custom output format using the {} expansion\n\n--value=VALUES\n    Values for the custom formatting string\n\nSee online documentation for details about custom format.\n\nUtils\n-----\n\nVarious utility options.\n\n--path PATHS\n    Path to the metadata tree (default: current directory)\n\n--verbose\n    Print additional information standard error output\n\n--debug\n    Turn on debugging output, do not catch exceptions\n\nCheck help message of individual commands for the full list of\navailable options.\n\n\nInstall\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nThe fmf package is available in Fedora and EPEL::\n\n    dnf install fmf\n\nInstall the latest version from the Copr repository::\n\n    dnf copr enable @teemtee/fmf\n    dnf install fmf\n\nor use PIP::\n\n    pip install fmf\n\nSee documentation for more details about installation options.\n\n\nVariables\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nHere is the list of environment variables understood by fmf:\n\nFMF_CACHE_DIRECTORY\n    Directory used to cache git clone calls for fmf identifiers.\n\n\nLinks\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nGit:\nhttps://github.com/teemtee/fmf\n\nDocs:\nhttp://fmf.readthedocs.io/\n\nIssues:\nhttps://github.com/teemtee/fmf/issues\n\nReleases:\nhttps://github.com/teemtee/fmf/releases\n\nCopr:\nhttp://copr.fedoraproject.org/coprs/g/teemtee/fmf\n\nPIP:\nhttps://pypi.org/project/fmf/\n\n\nAuthors\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nPetr \u0160pl\u00edchal, Miro Hron\u010dok, Jakub Krysl, Jan \u0160\u010dotka, Alois\nMahdal, Cleber Rosa, Miroslav Vadkerti, Luk\u00e1\u0161 Zachar, Franti\u0161ek\nNe\u010das, Evgeny Fedin, Pablo Martin, Zhaojuan Guo, Laura Barcziov\u00e1,\nPetr Maty\u00e1\u0161, Filip V\u00e1gner, Cristian Le, Ondrej Mori\u0161, Martin\nHoyer and Karel \u0160rot.\n\n\nCopyright\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n\nCopyright (c) 2018-2021 Red Hat, Inc.\n\nThis program is free software; you can redistribute it and/or\nmodify it under the terms of the GNU General Public License as\npublished by the Free Software Foundation; either version 2 of\nthe License, or (at your option) any later version.\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "Flexible Metadata Format",
    "version": "1.6.1",
    "project_urls": {
        "documentation": "https://fmf.readthedocs.io",
        "homepage": "https://github.com/teemtee/fmf"
    },
    "split_keywords": [
        "metadata",
        " testing"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "35d43e2edb84dd451208a5366f8f926cea5fdfe321ea94c4ebaa9e5992d10fc6",
                "md5": "797555a9500d9b50e58c1b8496f2aef6",
                "sha256": "06cbe5354c1b05327a369f907d896f75b7755266209bb761977006b55afe7e91"
            },
            "downloads": -1,
            "filename": "fmf-1.6.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "797555a9500d9b50e58c1b8496f2aef6",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 40637,
            "upload_time": "2025-01-17T06:14:16",
            "upload_time_iso_8601": "2025-01-17T06:14:16.386001Z",
            "url": "https://files.pythonhosted.org/packages/35/d4/3e2edb84dd451208a5366f8f926cea5fdfe321ea94c4ebaa9e5992d10fc6/fmf-1.6.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "521fc8e8e74f0c40e9a0230dad81b87b4a4d7afad7c51db54e16350aaecefded",
                "md5": "b10cc189737e61e73d5a2ef70a7bd477",
                "sha256": "cf80a4ac3ca1d9cad4453fe8205ee02912d27269d6384723d6a6aa1808b43c2e"
            },
            "downloads": -1,
            "filename": "fmf-1.6.1.tar.gz",
            "has_sig": false,
            "md5_digest": "b10cc189737e61e73d5a2ef70a7bd477",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 89755,
            "upload_time": "2025-01-17T06:14:19",
            "upload_time_iso_8601": "2025-01-17T06:14:19.846922Z",
            "url": "https://files.pythonhosted.org/packages/52/1f/c8e8e74f0c40e9a0230dad81b87b4a4d7afad7c51db54e16350aaecefded/fmf-1.6.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-17 06:14:19",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "teemtee",
    "github_project": "fmf",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "fmf"
}
        
Elapsed time: 0.46262s